mirror of
https://github.com/DRE2N/DungeonsXL.git
synced 2024-11-24 19:45:43 +01:00
Workaround for glitched blockplace
This commit is contained in:
parent
36d29224b2
commit
7d7f30f3e8
@ -3,6 +3,7 @@ package com.dre.dungeonsxl.listener;
|
|||||||
import org.bukkit.block.Block;
|
import org.bukkit.block.Block;
|
||||||
import org.bukkit.block.Sign;
|
import org.bukkit.block.Sign;
|
||||||
import org.bukkit.entity.Player;
|
import org.bukkit.entity.Player;
|
||||||
|
import org.bukkit.Location;
|
||||||
import org.bukkit.event.EventHandler;
|
import org.bukkit.event.EventHandler;
|
||||||
import org.bukkit.event.EventPriority;
|
import org.bukkit.event.EventPriority;
|
||||||
import org.bukkit.event.Listener;
|
import org.bukkit.event.Listener;
|
||||||
@ -88,6 +89,19 @@ public class BlockListener implements Listener {
|
|||||||
GameWorld gworld = GameWorld.get(block.getWorld());
|
GameWorld gworld = GameWorld.get(block.getWorld());
|
||||||
if (gworld != null) {
|
if (gworld != null) {
|
||||||
if (!GamePlaceableBlock.canBuildHere(block, block.getFace(event.getBlockAgainst()), event.getItemInHand().getType(), gworld)) {
|
if (!GamePlaceableBlock.canBuildHere(block, block.getFace(event.getBlockAgainst()), event.getItemInHand().getType(), gworld)) {
|
||||||
|
|
||||||
|
// Workaround for a bug that would allow 3-Block-high jumping
|
||||||
|
Location loc = event.getPlayer().getLocation();
|
||||||
|
if (loc.getY() > block.getY() + 1.0 && loc.getY() <= block.getY() + 1.5) {
|
||||||
|
if (loc.getX() >= block.getX() - 0.3 && loc.getX() <= block.getX() + 1.3) {
|
||||||
|
if (loc.getZ() >= block.getZ() - 0.3 && loc.getZ() <= block.getZ() + 1.3) {
|
||||||
|
loc.setX(block.getX() + 0.5);
|
||||||
|
loc.setY(block.getY());
|
||||||
|
loc.setZ(block.getZ() + 0.5);
|
||||||
|
event.getPlayer().teleport(loc);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
event.setCancelled(true);
|
event.setCancelled(true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user