Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- package com.maideniles.calumsmod.blocks.tracks;
- import com.google.common.collect.Lists;
- import com.google.common.collect.Sets;
- import com.maideniles.calumsmod.CalumsMod;
- import com.maideniles.calumsmod.init.ModBlocks;
- import com.maideniles.calumsmod.init.ModItems;
- import com.maideniles.calumsmod.util.IHasModel;
- import java.util.EnumSet;
- import java.util.List;
- import java.util.Random;
- import java.util.Set;
- import javax.annotation.Nullable;
- import net.minecraft.block.Block;
- import net.minecraft.block.BlockObserver;
- import net.minecraft.block.BlockRedstoneDiode;
- import net.minecraft.block.BlockRedstoneRepeater;
- import net.minecraft.block.material.Material;
- import net.minecraft.block.properties.IProperty;
- import net.minecraft.block.properties.PropertyEnum;
- import net.minecraft.block.properties.PropertyInteger;
- import net.minecraft.block.state.BlockFaceShape;
- import net.minecraft.block.state.BlockStateContainer;
- import net.minecraft.block.state.IBlockState;
- import net.minecraft.init.Blocks;
- import net.minecraft.init.Items;
- import net.minecraft.item.Item;
- import net.minecraft.item.ItemBlock;
- import net.minecraft.item.ItemStack;
- import net.minecraft.util.BlockRenderLayer;
- import net.minecraft.util.EnumFacing;
- import net.minecraft.util.EnumParticleTypes;
- import net.minecraft.util.IStringSerializable;
- import net.minecraft.util.Mirror;
- import net.minecraft.util.Rotation;
- import net.minecraft.util.math.AxisAlignedBB;
- import net.minecraft.util.math.BlockPos;
- import net.minecraft.util.math.MathHelper;
- import net.minecraft.world.IBlockAccess;
- import net.minecraft.world.World;
- import net.minecraftforge.fml.relauncher.Side;
- import net.minecraftforge.fml.relauncher.SideOnly;
- public class BlockTrackWire extends Block implements IHasModel
- {
- public static final PropertyEnum<BlockTrackWire.EnumAttachPosition> NORTH = PropertyEnum.<BlockTrackWire.EnumAttachPosition>create("north", BlockTrackWire.EnumAttachPosition.class);
- public static final PropertyEnum<BlockTrackWire.EnumAttachPosition> EAST = PropertyEnum.<BlockTrackWire.EnumAttachPosition>create("east", BlockTrackWire.EnumAttachPosition.class);
- public static final PropertyEnum<BlockTrackWire.EnumAttachPosition> SOUTH = PropertyEnum.<BlockTrackWire.EnumAttachPosition>create("south", BlockTrackWire.EnumAttachPosition.class);
- public static final PropertyEnum<BlockTrackWire.EnumAttachPosition> WEST = PropertyEnum.<BlockTrackWire.EnumAttachPosition>create("west", BlockTrackWire.EnumAttachPosition.class);
- public static final PropertyInteger POWER = PropertyInteger.create("power", 0, 15);
- protected static final AxisAlignedBB[] TRACK_WIRE_AABB = new AxisAlignedBB[] {new AxisAlignedBB(0.1875D, 0.0D, 0.1875D, 0.8125D, 0.0625D, 0.8125D), new AxisAlignedBB(0.1875D, 0.0D, 0.1875D, 0.8125D, 0.0625D, 1.0D), new AxisAlignedBB(0.0D, 0.0D, 0.1875D, 0.8125D, 0.0625D, 0.8125D), new AxisAlignedBB(0.0D, 0.0D, 0.1875D, 0.8125D, 0.0625D, 1.0D), new AxisAlignedBB(0.1875D, 0.0D, 0.0D, 0.8125D, 0.0625D, 0.8125D), new AxisAlignedBB(0.1875D, 0.0D, 0.0D, 0.8125D, 0.0625D, 1.0D), new AxisAlignedBB(0.0D, 0.0D, 0.0D, 0.8125D, 0.0625D, 0.8125D), new AxisAlignedBB(0.0D, 0.0D, 0.0D, 0.8125D, 0.0625D, 1.0D), new AxisAlignedBB(0.1875D, 0.0D, 0.1875D, 1.0D, 0.0625D, 0.8125D), new AxisAlignedBB(0.1875D, 0.0D, 0.1875D, 1.0D, 0.0625D, 1.0D), new AxisAlignedBB(0.0D, 0.0D, 0.1875D, 1.0D, 0.0625D, 0.8125D), new AxisAlignedBB(0.0D, 0.0D, 0.1875D, 1.0D, 0.0625D, 1.0D), new AxisAlignedBB(0.1875D, 0.0D, 0.0D, 1.0D, 0.0625D, 0.8125D), new AxisAlignedBB(0.1875D, 0.0D, 0.0D, 1.0D, 0.0625D, 1.0D), new AxisAlignedBB(0.0D, 0.0D, 0.0D, 1.0D, 0.0625D, 0.8125D), new AxisAlignedBB(0.0D, 0.0D, 0.0D, 1.0D, 0.0625D, 1.0D)};
- private boolean canProvidePower = true;
- /** List of blocks to update with redstone. */
- private final Set<BlockPos> blocksNeedingUpdate = Sets.<BlockPos>newHashSet();
- public BlockTrackWire(String name, Material materialIn)
- {
- super(Material.CIRCUITS);
- setUnlocalizedName(name);
- setRegistryName(name);
- this.setDefaultState(this.blockState.getBaseState().withProperty(NORTH, BlockTrackWire.EnumAttachPosition.NONE).withProperty(EAST, BlockTrackWire.EnumAttachPosition.NONE).withProperty(SOUTH, BlockTrackWire.EnumAttachPosition.NONE).withProperty(WEST, BlockTrackWire.EnumAttachPosition.NONE).withProperty(POWER, Integer.valueOf(0)));
- this.setCreativeTab(CalumsMod.calumsmodblocks);
- ModBlocks.BLOCKS.add(this);
- ModItems.ITEMS.add(new ItemBlock(this).setRegistryName(this.getRegistryName()));
- }
- public AxisAlignedBB getBoundingBox(IBlockState state, IBlockAccess source, BlockPos pos)
- {
- return TRACK_WIRE_AABB[getAABBIndex(state.getActualState(source, pos))];
- }
- private static int getAABBIndex(IBlockState state)
- {
- int i = 0;
- boolean flag = state.getValue(NORTH) != BlockTrackWire.EnumAttachPosition.NONE;
- boolean flag1 = state.getValue(EAST) != BlockTrackWire.EnumAttachPosition.NONE;
- boolean flag2 = state.getValue(SOUTH) != BlockTrackWire.EnumAttachPosition.NONE;
- boolean flag3 = state.getValue(WEST) != BlockTrackWire.EnumAttachPosition.NONE;
- if (flag || flag2 && !flag && !flag1 && !flag3)
- {
- i |= 1 << EnumFacing.NORTH.getHorizontalIndex();
- }
- if (flag1 || flag3 && !flag && !flag1 && !flag2)
- {
- i |= 1 << EnumFacing.EAST.getHorizontalIndex();
- }
- if (flag2 || flag && !flag1 && !flag2 && !flag3)
- {
- i |= 1 << EnumFacing.SOUTH.getHorizontalIndex();
- }
- if (flag3 || flag1 && !flag && !flag2 && !flag3)
- {
- i |= 1 << EnumFacing.WEST.getHorizontalIndex();
- }
- return i;
- }
- /**
- * Get the actual Block state of this Block at the given position. This applies properties not visible in the
- * metadata, such as fence connections.
- */
- public IBlockState getActualState(IBlockState state, IBlockAccess worldIn, BlockPos pos)
- {
- state = state.withProperty(WEST, this.getAttachPosition(worldIn, pos, EnumFacing.WEST));
- state = state.withProperty(EAST, this.getAttachPosition(worldIn, pos, EnumFacing.EAST));
- state = state.withProperty(NORTH, this.getAttachPosition(worldIn, pos, EnumFacing.NORTH));
- state = state.withProperty(SOUTH, this.getAttachPosition(worldIn, pos, EnumFacing.SOUTH));
- return state;
- }
- private BlockTrackWire.EnumAttachPosition getAttachPosition(IBlockAccess worldIn, BlockPos pos, EnumFacing direction)
- {
- BlockPos blockpos = pos.offset(direction);
- IBlockState iblockstate = worldIn.getBlockState(pos.offset(direction));
- if (!canConnectTo(worldIn.getBlockState(blockpos), direction, worldIn, blockpos) && (iblockstate.isNormalCube() || !canConnectUpwardsTo(worldIn, blockpos.down())))
- {
- IBlockState iblockstate1 = worldIn.getBlockState(pos.up());
- if (!iblockstate1.isNormalCube())
- {
- boolean flag = worldIn.getBlockState(blockpos).isSideSolid(worldIn, blockpos, EnumFacing.UP) || worldIn.getBlockState(blockpos).getBlock() == Blocks.GLOWSTONE;
- if (flag && canConnectUpwardsTo(worldIn, blockpos.up()))
- {
- if (iblockstate.isBlockNormalCube())
- {
- return BlockTrackWire.EnumAttachPosition.UP;
- }
- return BlockTrackWire.EnumAttachPosition.SIDE;
- }
- }
- return BlockTrackWire.EnumAttachPosition.NONE;
- }
- else
- {
- return BlockTrackWire.EnumAttachPosition.SIDE;
- }
- }
- @Nullable
- public AxisAlignedBB getCollisionBoundingBox(IBlockState blockState, IBlockAccess worldIn, BlockPos pos)
- {
- return NULL_AABB;
- }
- /**
- * Used to determine ambient occlusion and culling when rebuilding chunks for render
- */
- public boolean isOpaqueCube(IBlockState state)
- {
- return false;
- }
- public boolean isFullCube(IBlockState state)
- {
- return false;
- }
- /**
- * Checks if this block can be placed exactly at the given position.
- */
- public boolean canPlaceBlockAt(World worldIn, BlockPos pos)
- {
- IBlockState downState = worldIn.getBlockState(pos.down());
- return downState.isTopSolid() || downState.getBlockFaceShape(worldIn, pos.down(), EnumFacing.UP) == BlockFaceShape.SOLID || worldIn.getBlockState(pos.down()).getBlock() == Blocks.GLOWSTONE;
- }
- private IBlockState updateSurroundingRedstone(World worldIn, BlockPos pos, IBlockState state)
- {
- state = this.calculateCurrentChanges(worldIn, pos, pos, state);
- List<BlockPos> list = Lists.newArrayList(this.blocksNeedingUpdate);
- this.blocksNeedingUpdate.clear();
- for (BlockPos blockpos : list)
- {
- worldIn.notifyNeighborsOfStateChange(blockpos, this, false);
- }
- return state;
- }
- private IBlockState calculateCurrentChanges(World worldIn, BlockPos pos1, BlockPos pos2, IBlockState state)
- {
- IBlockState iblockstate = state;
- int i = ((Integer)state.getValue(POWER)).intValue();
- int j = 0;
- j = this.getMaxCurrentStrength(worldIn, pos2, j);
- this.canProvidePower = false;
- int k = worldIn.isBlockIndirectlyGettingPowered(pos1);
- this.canProvidePower = true;
- if (k > 0 && k > j - 1)
- {
- j = k;
- }
- int l = 0;
- for (EnumFacing enumfacing : EnumFacing.Plane.HORIZONTAL)
- {
- BlockPos blockpos = pos1.offset(enumfacing);
- boolean flag = blockpos.getX() != pos2.getX() || blockpos.getZ() != pos2.getZ();
- if (flag)
- {
- l = this.getMaxCurrentStrength(worldIn, blockpos, l);
- }
- if (worldIn.getBlockState(blockpos).isNormalCube() && !worldIn.getBlockState(pos1.up()).isNormalCube())
- {
- if (flag && pos1.getY() >= pos2.getY())
- {
- l = this.getMaxCurrentStrength(worldIn, blockpos.up(), l);
- }
- }
- else if (!worldIn.getBlockState(blockpos).isNormalCube() && flag && pos1.getY() <= pos2.getY())
- {
- l = this.getMaxCurrentStrength(worldIn, blockpos.down(), l);
- }
- }
- if (l > j)
- {
- j = l - 1;
- }
- else if (j > 0)
- {
- --j;
- }
- else
- {
- j = 0;
- }
- if (k > j - 1)
- {
- j = k;
- }
- if (i != j)
- {
- state = state.withProperty(POWER, Integer.valueOf(j));
- if (worldIn.getBlockState(pos1) == iblockstate)
- {
- worldIn.setBlockState(pos1, state, 2);
- }
- this.blocksNeedingUpdate.add(pos1);
- for (EnumFacing enumfacing1 : EnumFacing.values())
- {
- this.blocksNeedingUpdate.add(pos1.offset(enumfacing1));
- }
- }
- return state;
- }
- /**
- * Calls World.notifyNeighborsOfStateChange() for all neighboring blocks, but only if the given block is a redstone
- * wire.
- */
- private void notifyWireNeighborsOfStateChange(World worldIn, BlockPos pos)
- {
- if (worldIn.getBlockState(pos).getBlock() == this)
- {
- worldIn.notifyNeighborsOfStateChange(pos, this, false);
- for (EnumFacing enumfacing : EnumFacing.values())
- {
- worldIn.notifyNeighborsOfStateChange(pos.offset(enumfacing), this, false);
- }
- }
- }
- /**
- * Called after the block is set in the Chunk data, but before the Tile Entity is set
- */
- public void onBlockAdded(World worldIn, BlockPos pos, IBlockState state)
- {
- if (!worldIn.isRemote)
- {
- this.updateSurroundingRedstone(worldIn, pos, state);
- for (EnumFacing enumfacing : EnumFacing.Plane.VERTICAL)
- {
- worldIn.notifyNeighborsOfStateChange(pos.offset(enumfacing), this, false);
- }
- for (EnumFacing enumfacing1 : EnumFacing.Plane.HORIZONTAL)
- {
- this.notifyWireNeighborsOfStateChange(worldIn, pos.offset(enumfacing1));
- }
- for (EnumFacing enumfacing2 : EnumFacing.Plane.HORIZONTAL)
- {
- BlockPos blockpos = pos.offset(enumfacing2);
- if (worldIn.getBlockState(blockpos).isNormalCube())
- {
- this.notifyWireNeighborsOfStateChange(worldIn, blockpos.up());
- }
- else
- {
- this.notifyWireNeighborsOfStateChange(worldIn, blockpos.down());
- }
- }
- }
- }
- /**
- * Called serverside after this block is replaced with another in Chunk, but before the Tile Entity is updated
- */
- public void breakBlock(World worldIn, BlockPos pos, IBlockState state)
- {
- super.breakBlock(worldIn, pos, state);
- if (!worldIn.isRemote)
- {
- for (EnumFacing enumfacing : EnumFacing.values())
- {
- worldIn.notifyNeighborsOfStateChange(pos.offset(enumfacing), this, false);
- }
- this.updateSurroundingRedstone(worldIn, pos, state);
- for (EnumFacing enumfacing1 : EnumFacing.Plane.HORIZONTAL)
- {
- this.notifyWireNeighborsOfStateChange(worldIn, pos.offset(enumfacing1));
- }
- for (EnumFacing enumfacing2 : EnumFacing.Plane.HORIZONTAL)
- {
- BlockPos blockpos = pos.offset(enumfacing2);
- if (worldIn.getBlockState(blockpos).isNormalCube())
- {
- this.notifyWireNeighborsOfStateChange(worldIn, blockpos.up());
- }
- else
- {
- this.notifyWireNeighborsOfStateChange(worldIn, blockpos.down());
- }
- }
- }
- }
- private int getMaxCurrentStrength(World worldIn, BlockPos pos, int strength)
- {
- if (worldIn.getBlockState(pos).getBlock() != this)
- {
- return strength;
- }
- else
- {
- int i = ((Integer)worldIn.getBlockState(pos).getValue(POWER)).intValue();
- return i > strength ? i : strength;
- }
- }
- /**
- * Called when a neighboring block was changed and marks that this state should perform any checks during a neighbor
- * change. Cases may include when redstone power is updated, cactus blocks popping off due to a neighboring solid
- * block, etc.
- */
- public void neighborChanged(IBlockState state, World worldIn, BlockPos pos, Block blockIn, BlockPos fromPos)
- {
- if (!worldIn.isRemote)
- {
- if (this.canPlaceBlockAt(worldIn, pos))
- {
- this.updateSurroundingRedstone(worldIn, pos, state);
- }
- else
- {
- this.dropBlockAsItem(worldIn, pos, state, 0);
- worldIn.setBlockToAir(pos);
- }
- }
- }
- /**
- * Get the Item that this Block should drop when harvested.
- */
- public Item getItemDropped(IBlockState state, Random rand, int fortune)
- {
- return Items.REDSTONE;
- }
- public int getStrongPower(IBlockState blockState, IBlockAccess blockAccess, BlockPos pos, EnumFacing side)
- {
- return !this.canProvidePower ? 0 : blockState.getWeakPower(blockAccess, pos, side);
- }
- public int getWeakPower(IBlockState blockState, IBlockAccess blockAccess, BlockPos pos, EnumFacing side)
- {
- if (!this.canProvidePower)
- {
- return 0;
- }
- else
- {
- int i = ((Integer)blockState.getValue(POWER)).intValue();
- if (i == 0)
- {
- return 0;
- }
- else if (side == EnumFacing.UP)
- {
- return i;
- }
- else
- {
- EnumSet<EnumFacing> enumset = EnumSet.<EnumFacing>noneOf(EnumFacing.class);
- for (EnumFacing enumfacing : EnumFacing.Plane.HORIZONTAL)
- {
- if (this.isPowerSourceAt(blockAccess, pos, enumfacing))
- {
- enumset.add(enumfacing);
- }
- }
- if (side.getAxis().isHorizontal() && enumset.isEmpty())
- {
- return i;
- }
- else if (enumset.contains(side) && !enumset.contains(side.rotateYCCW()) && !enumset.contains(side.rotateY()))
- {
- return i;
- }
- else
- {
- return 0;
- }
- }
- }
- }
- private boolean isPowerSourceAt(IBlockAccess worldIn, BlockPos pos, EnumFacing side)
- {
- BlockPos blockpos = pos.offset(side);
- IBlockState iblockstate = worldIn.getBlockState(blockpos);
- boolean flag = iblockstate.isNormalCube();
- boolean flag1 = worldIn.getBlockState(pos.up()).isNormalCube();
- if (!flag1 && flag && canConnectUpwardsTo(worldIn, blockpos.up()))
- {
- return true;
- }
- else if (canConnectTo(iblockstate, side, worldIn, pos))
- {
- return true;
- }
- else if (iblockstate.getBlock() == Blocks.POWERED_REPEATER && iblockstate.getValue(BlockRedstoneDiode.FACING) == side)
- {
- return true;
- }
- else
- {
- return !flag && canConnectUpwardsTo(worldIn, blockpos.down());
- }
- }
- protected static boolean canConnectUpwardsTo(IBlockAccess worldIn, BlockPos pos)
- {
- return canConnectTo(worldIn.getBlockState(pos), null, worldIn, pos);
- }
- protected static boolean canConnectTo(IBlockState blockState, @Nullable EnumFacing side, IBlockAccess world, BlockPos pos)
- {
- Block block = blockState.getBlock();
- if (block == ModBlocks.TRACK_WIRE)
- {
- return true;
- }
- else if (Blocks.UNPOWERED_REPEATER.isSameDiode(blockState))
- {
- EnumFacing enumfacing = (EnumFacing)blockState.getValue(BlockRedstoneRepeater.FACING);
- return enumfacing == side || enumfacing.getOpposite() == side;
- }
- else if (Blocks.OBSERVER == blockState.getBlock())
- {
- return side == blockState.getValue(BlockObserver.FACING);
- }
- else
- {
- return blockState.getBlock().canConnectRedstone(blockState, world, pos, side);
- }
- }
- /**
- * Can this block provide power. Only wire currently seems to have this change based on its state.
- */
- public boolean canProvidePower(IBlockState state)
- {
- return this.canProvidePower;
- }
- @SideOnly(Side.CLIENT)
- public static int colorMultiplier(int p_176337_0_)
- {
- float f = (float)p_176337_0_ / 15.0F;
- float f1 = f * 0.6F + 0.4F;
- if (p_176337_0_ == 0)
- {
- f1 = 0.3F;
- }
- float f2 = f * f * 0.7F - 0.5F;
- float f3 = f * f * 0.6F - 0.7F;
- if (f2 < 0.0F)
- {
- f2 = 0.0F;
- }
- if (f3 < 0.0F)
- {
- f3 = 0.0F;
- }
- int i = MathHelper.clamp((int)(f1 * 255.0F), 0, 255);
- int j = MathHelper.clamp((int)(f2 * 255.0F), 0, 255);
- int k = MathHelper.clamp((int)(f3 * 255.0F), 0, 255);
- return -16777216 | i << 16 | j << 8 | k;
- }
- @SideOnly(Side.CLIENT)
- public void randomDisplayTick(IBlockState stateIn, World worldIn, BlockPos pos, Random rand)
- {
- int i = ((Integer)stateIn.getValue(POWER)).intValue();
- if (i != 0)
- {
- double d0 = (double)pos.getX() + 0.5D + ((double)rand.nextFloat() - 0.5D) * 0.2D;
- double d1 = (double)((float)pos.getY() + 0.0625F);
- double d2 = (double)pos.getZ() + 0.5D + ((double)rand.nextFloat() - 0.5D) * 0.2D;
- float f = (float)i / 15.0F;
- float f1 = f * 0.6F + 0.4F;
- float f2 = Math.max(0.0F, f * f * 0.7F - 0.5F);
- float f3 = Math.max(0.0F, f * f * 0.6F - 0.7F);
- worldIn.spawnParticle(EnumParticleTypes.REDSTONE, d0, d1, d2, (double)f1, (double)f2, (double)f3);
- }
- }
- public ItemStack getItem(World worldIn, BlockPos pos, IBlockState state)
- {
- return new ItemStack(Items.REDSTONE);
- }
- /**
- * Convert the given metadata into a BlockState for this Block
- */
- public IBlockState getStateFromMeta(int meta)
- {
- return this.getDefaultState().withProperty(POWER, Integer.valueOf(meta));
- }
- @SideOnly(Side.CLIENT)
- public BlockRenderLayer getBlockLayer()
- {
- return BlockRenderLayer.CUTOUT;
- }
- /**
- * Convert the BlockState into the correct metadata value
- */
- public int getMetaFromState(IBlockState state)
- {
- return ((Integer)state.getValue(POWER)).intValue();
- }
- /**
- * Returns the blockstate with the given rotation from the passed blockstate. If inapplicable, returns the passed
- * blockstate.
- */
- public IBlockState withRotation(IBlockState state, Rotation rot)
- {
- switch (rot)
- {
- case CLOCKWISE_180:
- return state.withProperty(NORTH, state.getValue(SOUTH)).withProperty(EAST, state.getValue(WEST)).withProperty(SOUTH, state.getValue(NORTH)).withProperty(WEST, state.getValue(EAST));
- case COUNTERCLOCKWISE_90:
- return state.withProperty(NORTH, state.getValue(EAST)).withProperty(EAST, state.getValue(SOUTH)).withProperty(SOUTH, state.getValue(WEST)).withProperty(WEST, state.getValue(NORTH));
- case CLOCKWISE_90:
- return state.withProperty(NORTH, state.getValue(WEST)).withProperty(EAST, state.getValue(NORTH)).withProperty(SOUTH, state.getValue(EAST)).withProperty(WEST, state.getValue(SOUTH));
- default:
- return state;
- }
- }
- /**
- * Returns the blockstate with the given mirror of the passed blockstate. If inapplicable, returns the passed
- * blockstate.
- */
- public IBlockState withMirror(IBlockState state, Mirror mirrorIn)
- {
- switch (mirrorIn)
- {
- case LEFT_RIGHT:
- return state.withProperty(NORTH, state.getValue(SOUTH)).withProperty(SOUTH, state.getValue(NORTH));
- case FRONT_BACK:
- return state.withProperty(EAST, state.getValue(WEST)).withProperty(WEST, state.getValue(EAST));
- default:
- return super.withMirror(state, mirrorIn);
- }
- }
- protected BlockStateContainer createBlockState()
- {
- return new BlockStateContainer(this, new IProperty[] {NORTH, EAST, SOUTH, WEST, POWER});
- }
- /**
- * Get the geometry of the queried face at the given position and state. This is used to decide whether things like
- * buttons are allowed to be placed on the face, or how glass panes connect to the face, among other things.
- * <p>
- * Common values are {@code SOLID}, which is the default, and {@code UNDEFINED}, which represents something that
- * does not fit the other descriptions and will generally cause other things not to connect to the face.
- *
- * @return an approximation of the form of the given face
- */
- public BlockFaceShape getBlockFaceShape(IBlockAccess worldIn, IBlockState state, BlockPos pos, EnumFacing face)
- {
- return BlockFaceShape.UNDEFINED;
- }
- static enum EnumAttachPosition implements IStringSerializable
- {
- UP("up"),
- SIDE("side"),
- NONE("none");
- private final String name;
- private EnumAttachPosition(String name)
- {
- this.name = name;
- }
- public String toString()
- {
- return this.getName();
- }
- public String getName()
- {
- return this.name;
- }
- }
- @Override
- public void registerModels() {
- CalumsMod.proxy.registerItemRenderer(Item.getItemFromBlock(this), 0, "inventory");
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement