package appeng.tile.grindstone; import io.netty.buffer.ByteBuf; import java.util.Arrays; import java.util.List; import net.minecraft.entity.Entity; import net.minecraft.tileentity.TileEntity; import net.minecraft.util.AxisAlignedBB; import net.minecraft.world.World; import net.minecraftforge.common.util.ForgeDirection; import appeng.api.implementations.tiles.ICrankable; import appeng.helpers.ICustomCollision; import appeng.tile.AEBaseTile; import appeng.tile.TileEvent; import appeng.tile.events.TileEventType; import appeng.util.Platform; public class TileCrank extends AEBaseTile implements ICustomCollision { final int ticksPerRotation = 18; // sided values.. public float visibleRotation = 0; public int charge = 0; public int hits = 0; public int rotation = 0; @TileEvent(TileEventType.TICK) public void Tick_TileCrank() { if ( rotation > 0 ) { visibleRotation -= 360 / (ticksPerRotation); charge++; if ( charge >= ticksPerRotation ) { charge -= ticksPerRotation; ICrankable g = getGrinder(); if ( g != null ) g.applyTurn(); } rotation--; } } @TileEvent(TileEventType.NETWORK_READ) public boolean readFromStream_TileCrank(ByteBuf data) throws java.io.IOException { rotation = data.readInt(); return false; } @TileEvent(TileEventType.NETWORK_WRITE) public void writeToStream_TileCrank(ByteBuf data) throws java.io.IOException { data.writeInt( rotation ); } public ICrankable getGrinder() { if ( Platform.isClient() ) return null; ForgeDirection grinder = getUp().getOpposite(); TileEntity te = worldObj.getTileEntity( xCoord + grinder.offsetX, yCoord + grinder.offsetY, zCoord + grinder.offsetZ ); if ( te instanceof ICrankable ) return (ICrankable) te; return null; } @Override public void setOrientation(ForgeDirection inForward, ForgeDirection inUp) { super.setOrientation( inForward, inUp ); getBlockType().onNeighborBlockChange( worldObj, xCoord, yCoord, zCoord, Platform.air ); } /** * return true if this should count towards stats. */ public boolean power() { if ( Platform.isClient() ) return false; if ( rotation < 3 ) { ICrankable g = getGrinder(); if ( g != null ) { if ( g.canTurn() ) { hits = 0; rotation += ticksPerRotation; this.markForUpdate(); return true; } else { hits++; if ( hits > 10 ) { worldObj.func_147480_a( xCoord, yCoord, zCoord, false ); // worldObj.destroyBlock( xCoord, yCoord, zCoord, false ); } } } } return false; } @Override public Iterable getSelectedBoundingBoxesFromPool(World w, int x, int y, int z, Entity e, boolean isVisual) { double xOff = -0.15 * getUp().offsetX; double yOff = -0.15 * getUp().offsetY; double zOff = -0.15 * getUp().offsetZ; return Arrays .asList( new AxisAlignedBB[] { AxisAlignedBB.getBoundingBox( xOff + 0.15, yOff + 0.15, zOff + 0.15, xOff + 0.85, yOff + 0.85, zOff + 0.85 ) } ); } @Override public void addCollidingBlockToList(World w, int x, int y, int z, AxisAlignedBB bb, List out, Entity e) { double xOff = -0.15 * getUp().offsetX; double yOff = -0.15 * getUp().offsetY; double zOff = -0.15 * getUp().offsetZ; out.add( AxisAlignedBB.getBoundingBox( xOff + (double) 0.15, yOff + (double) 0.15, zOff + (double) 0.15,// ahh xOff + (double) 0.85, yOff + (double) 0.85, zOff + (double) 0.85 ) ); } @Override public boolean requiresTESR() { return true; } }