From f55c8191850d21599ee8abde2d378cfff3154f80 Mon Sep 17 00:00:00 2001 From: Evoluseis Date: Mon, 17 Dec 2018 19:11:04 -0500 Subject: [PATCH] SPIGOT-2151: Add support for getting simple bounding box of a block --- .../org/bukkit/craftbukkit/block/CraftBlock.java | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java index 1fadbf0547..89c67aa2d1 100644 --- a/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java +++ b/src/main/java/org/bukkit/craftbukkit/block/CraftBlock.java @@ -30,6 +30,7 @@ import org.bukkit.inventory.ItemStack; import org.bukkit.metadata.MetadataValue; import org.bukkit.plugin.Plugin; import org.bukkit.util.BlockVector; +import org.bukkit.util.BoundingBox; import org.bukkit.util.RayTraceResult; import org.bukkit.util.Vector; @@ -648,4 +649,16 @@ public class CraftBlock implements Block { return CraftRayTraceResult.fromNMS(this.getWorld(), nmsHitResult); } + + @Override + public BoundingBox getBoundingBox() { + VoxelShape shape = getData0().g(world, position); // PAIL: getShape + + if (shape.isEmpty()) { + return new BoundingBox(); // Return an empty bounding box if the block has no dimension + } + + AxisAlignedBB aabb = shape.a(); // PAIL: getBoundingBox + return new BoundingBox(getX() + aabb.minX, getY() + aabb.minY, getZ() + aabb.minZ, getX() + aabb.maxX, getY() + aabb.maxY, getZ() + aabb.maxZ); + } }