Better external storage collision
This commit is contained in:
@@ -21,8 +21,8 @@ public class BlockConstructor extends BlockCable {
|
|||||||
public static final AxisAlignedBB HOLDER_EAST_AABB = createAABB(10, 7, 7, 14, 9, 9);
|
public static final AxisAlignedBB HOLDER_EAST_AABB = createAABB(10, 7, 7, 14, 9, 9);
|
||||||
public static final AxisAlignedBB HOLDER_SOUTH_AABB = createAABB(7, 7, 10, 9, 9, 14);
|
public static final AxisAlignedBB HOLDER_SOUTH_AABB = createAABB(7, 7, 10, 9, 9, 14);
|
||||||
public static final AxisAlignedBB HOLDER_WEST_AABB = createAABB(2, 7, 7, 6, 9, 9);
|
public static final AxisAlignedBB HOLDER_WEST_AABB = createAABB(2, 7, 7, 6, 9, 9);
|
||||||
public static final AxisAlignedBB HOLDER_DOWN_AABB = createAABB(7, 2, 7, 9, 6, 9);
|
|
||||||
public static final AxisAlignedBB HOLDER_UP_AABB = createAABB(7, 10, 7, 9, 14, 9);
|
public static final AxisAlignedBB HOLDER_UP_AABB = createAABB(7, 10, 7, 9, 14, 9);
|
||||||
|
public static final AxisAlignedBB HOLDER_DOWN_AABB = createAABB(7, 2, 7, 9, 6, 9);
|
||||||
|
|
||||||
public static final AxisAlignedBB HEAD_NORTH_AABB = createAABB(0, 0, 0, 16, 16, 2);
|
public static final AxisAlignedBB HEAD_NORTH_AABB = createAABB(0, 0, 0, 16, 16, 2);
|
||||||
public static final AxisAlignedBB HEAD_EAST_AABB = createAABB(14, 0, 0, 16, 16, 16);
|
public static final AxisAlignedBB HEAD_EAST_AABB = createAABB(14, 0, 0, 16, 16, 16);
|
||||||
@@ -35,6 +35,7 @@ public class BlockConstructor extends BlockCable {
|
|||||||
super("constructor");
|
super("constructor");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public List<AxisAlignedBB> getNonUnionizedCollisionBoxes(IBlockState state) {
|
public List<AxisAlignedBB> getNonUnionizedCollisionBoxes(IBlockState state) {
|
||||||
List<AxisAlignedBB> boxes = new ArrayList<>();
|
List<AxisAlignedBB> boxes = new ArrayList<>();
|
||||||
|
|
||||||
|
|||||||
@@ -26,6 +26,7 @@ public class BlockDestructor extends BlockCable {
|
|||||||
return new TileDestructor();
|
return new TileDestructor();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public List<AxisAlignedBB> getNonUnionizedCollisionBoxes(IBlockState state) {
|
public List<AxisAlignedBB> getNonUnionizedCollisionBoxes(IBlockState state) {
|
||||||
return RefinedStorageBlocks.CONSTRUCTOR.getNonUnionizedCollisionBoxes(state);
|
return RefinedStorageBlocks.CONSTRUCTOR.getNonUnionizedCollisionBoxes(state);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,17 +7,62 @@ import net.minecraft.item.ItemStack;
|
|||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.EnumHand;
|
import net.minecraft.util.EnumHand;
|
||||||
|
import net.minecraft.util.math.AxisAlignedBB;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
import refinedstorage.RefinedStorage;
|
import refinedstorage.RefinedStorage;
|
||||||
import refinedstorage.RefinedStorageGui;
|
import refinedstorage.RefinedStorageGui;
|
||||||
import refinedstorage.tile.externalstorage.TileExternalStorage;
|
import refinedstorage.tile.externalstorage.TileExternalStorage;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
public class BlockExternalStorage extends BlockCable {
|
public class BlockExternalStorage extends BlockCable {
|
||||||
|
public static final AxisAlignedBB HEAD_NORTH_AABB = createAABB(3, 3, 0, 13, 13, 2);
|
||||||
|
public static final AxisAlignedBB HEAD_EAST_AABB = createAABB(14, 3, 3, 16, 13, 13);
|
||||||
|
public static final AxisAlignedBB HEAD_SOUTH_AABB = createAABB(3, 3, 14, 13, 13, 16);
|
||||||
|
public static final AxisAlignedBB HEAD_WEST_AABB = createAABB(0, 3, 3, 2, 13, 13);
|
||||||
|
public static final AxisAlignedBB HEAD_UP_AABB = createAABB(3, 14, 3, 13, 16, 13);
|
||||||
|
public static final AxisAlignedBB HEAD_DOWN_AABB = createAABB(3, 0, 3, 13, 2, 13);
|
||||||
|
|
||||||
public BlockExternalStorage() {
|
public BlockExternalStorage() {
|
||||||
super("external_storage");
|
super("external_storage");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<AxisAlignedBB> getNonUnionizedCollisionBoxes(IBlockState state) {
|
||||||
|
List<AxisAlignedBB> boxes = new ArrayList<>();
|
||||||
|
|
||||||
|
switch (state.getValue(DIRECTION)) {
|
||||||
|
case NORTH:
|
||||||
|
boxes.add(BlockConstructor.HOLDER_NORTH_AABB);
|
||||||
|
boxes.add(HEAD_NORTH_AABB);
|
||||||
|
break;
|
||||||
|
case EAST:
|
||||||
|
boxes.add(BlockConstructor.HOLDER_EAST_AABB);
|
||||||
|
boxes.add(HEAD_EAST_AABB);
|
||||||
|
break;
|
||||||
|
case SOUTH:
|
||||||
|
boxes.add(BlockConstructor.HOLDER_SOUTH_AABB);
|
||||||
|
boxes.add(HEAD_SOUTH_AABB);
|
||||||
|
break;
|
||||||
|
case WEST:
|
||||||
|
boxes.add(BlockConstructor.HOLDER_WEST_AABB);
|
||||||
|
boxes.add(HEAD_WEST_AABB);
|
||||||
|
break;
|
||||||
|
case UP:
|
||||||
|
boxes.add(BlockConstructor.HOLDER_UP_AABB);
|
||||||
|
boxes.add(HEAD_UP_AABB);
|
||||||
|
break;
|
||||||
|
case DOWN:
|
||||||
|
boxes.add(BlockConstructor.HOLDER_DOWN_AABB);
|
||||||
|
boxes.add(HEAD_DOWN_AABB);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return boxes;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public TileEntity createTileEntity(World world, IBlockState state) {
|
public TileEntity createTileEntity(World world, IBlockState state) {
|
||||||
return new TileExternalStorage();
|
return new TileExternalStorage();
|
||||||
|
|||||||
Reference in New Issue
Block a user