2013-12-27 16:59:59 -06:00
|
|
|
package appeng.tile.grindstone;
|
|
|
|
|
2014-02-08 19:34:52 -06:00
|
|
|
import io.netty.buffer.ByteBuf;
|
|
|
|
|
2013-12-27 16:59:59 -06:00
|
|
|
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;
|
2014-02-08 19:34:52 -06:00
|
|
|
import net.minecraftforge.common.util.ForgeDirection;
|
2014-01-23 13:02:48 -06:00
|
|
|
import appeng.api.implementations.tiles.ICrankable;
|
2013-12-27 16:59:59 -06:00
|
|
|
import appeng.helpers.ICustomCollision;
|
|
|
|
import appeng.tile.AEBaseTile;
|
2014-08-28 02:39:52 -05:00
|
|
|
import appeng.tile.TileEvent;
|
2013-12-27 16:59:59 -06:00
|
|
|
import appeng.tile.events.TileEventType;
|
|
|
|
import appeng.util.Platform;
|
|
|
|
|
|
|
|
public class TileCrank extends AEBaseTile implements ICustomCollision
|
|
|
|
{
|
|
|
|
|
2014-09-21 00:35:08 +02:00
|
|
|
final int ticksPerRotation = 18;
|
2013-12-27 16:59:59 -06:00
|
|
|
|
|
|
|
// sided values..
|
|
|
|
public float visibleRotation = 0;
|
|
|
|
public int charge = 0;
|
|
|
|
|
|
|
|
public int hits = 0;
|
|
|
|
public int rotation = 0;
|
|
|
|
|
2014-08-28 02:39:52 -05:00
|
|
|
@TileEvent(TileEventType.TICK)
|
|
|
|
public void Tick_TileCrank()
|
|
|
|
{
|
|
|
|
if ( rotation > 0 )
|
|
|
|
{
|
2014-09-21 00:35:08 +02:00
|
|
|
visibleRotation -= 360 / (ticksPerRotation);
|
2014-08-28 02:39:52 -05:00
|
|
|
charge++;
|
2014-09-21 00:35:08 +02:00
|
|
|
if ( charge >= ticksPerRotation )
|
2013-12-27 16:59:59 -06:00
|
|
|
{
|
2014-09-21 00:35:08 +02:00
|
|
|
charge -= ticksPerRotation;
|
2014-08-28 02:39:52 -05:00
|
|
|
ICrankable g = getGrinder();
|
|
|
|
if ( g != null )
|
|
|
|
g.applyTurn();
|
2013-12-27 16:59:59 -06:00
|
|
|
}
|
|
|
|
|
2014-08-28 02:39:52 -05:00
|
|
|
rotation--;
|
|
|
|
}
|
|
|
|
}
|
2013-12-27 16:59:59 -06:00
|
|
|
|
2014-08-28 02:39:52 -05:00
|
|
|
@TileEvent(TileEventType.NETWORK_READ)
|
|
|
|
public boolean readFromStream_TileCrank(ByteBuf data) throws java.io.IOException
|
|
|
|
{
|
|
|
|
rotation = data.readInt();
|
|
|
|
return false;
|
|
|
|
}
|
2013-12-27 16:59:59 -06:00
|
|
|
|
2014-08-28 02:39:52 -05:00
|
|
|
@TileEvent(TileEventType.NETWORK_WRITE)
|
|
|
|
public void writeToStream_TileCrank(ByteBuf data) throws java.io.IOException
|
|
|
|
{
|
|
|
|
data.writeInt( rotation );
|
2013-12-27 16:59:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
public ICrankable getGrinder()
|
|
|
|
{
|
|
|
|
if ( Platform.isClient() )
|
|
|
|
return null;
|
|
|
|
|
|
|
|
ForgeDirection grinder = getUp().getOpposite();
|
2014-02-08 19:34:52 -06:00
|
|
|
TileEntity te = worldObj.getTileEntity( xCoord + grinder.offsetX, yCoord + grinder.offsetY, zCoord + grinder.offsetZ );
|
2013-12-27 16:59:59 -06:00
|
|
|
if ( te instanceof ICrankable )
|
|
|
|
return (ICrankable) te;
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void setOrientation(ForgeDirection inForward, ForgeDirection inUp)
|
|
|
|
{
|
|
|
|
super.setOrientation( inForward, inUp );
|
2014-02-08 19:34:52 -06:00
|
|
|
getBlockType().onNeighborBlockChange( worldObj, xCoord, yCoord, zCoord, Platform.air );
|
2013-12-27 16:59:59 -06:00
|
|
|
}
|
|
|
|
|
2014-08-31 03:06:06 -05:00
|
|
|
/**
|
|
|
|
* return true if this should count towards stats.
|
|
|
|
*/
|
|
|
|
public boolean power()
|
2013-12-27 16:59:59 -06:00
|
|
|
{
|
|
|
|
if ( Platform.isClient() )
|
2014-08-31 03:06:06 -05:00
|
|
|
return false;
|
2013-12-27 16:59:59 -06:00
|
|
|
|
|
|
|
if ( rotation < 3 )
|
|
|
|
{
|
|
|
|
ICrankable g = getGrinder();
|
|
|
|
if ( g != null )
|
|
|
|
{
|
|
|
|
if ( g.canTurn() )
|
|
|
|
{
|
|
|
|
hits = 0;
|
2014-09-21 00:35:08 +02:00
|
|
|
rotation += ticksPerRotation;
|
2013-12-27 16:59:59 -06:00
|
|
|
this.markForUpdate();
|
2014-08-31 03:06:06 -05:00
|
|
|
return true;
|
2013-12-27 16:59:59 -06:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
hits++;
|
|
|
|
if ( hits > 10 )
|
2014-02-08 19:34:52 -06:00
|
|
|
{
|
|
|
|
worldObj.func_147480_a( xCoord, yCoord, zCoord, false );
|
|
|
|
// worldObj.destroyBlock( xCoord, yCoord, zCoord, false );
|
|
|
|
}
|
2013-12-27 16:59:59 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-08-31 03:06:06 -05:00
|
|
|
|
|
|
|
return false;
|
2013-12-27 16:59:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-09-21 00:35:59 +02:00
|
|
|
public Iterable<AxisAlignedBB> getSelectedBoundingBoxesFromPool(World w, int x, int y, int z, Entity e, boolean isVisual)
|
2013-12-27 16:59:59 -06:00
|
|
|
{
|
|
|
|
double xOff = -0.15 * getUp().offsetX;
|
|
|
|
double yOff = -0.15 * getUp().offsetY;
|
|
|
|
double zOff = -0.15 * getUp().offsetZ;
|
2014-02-05 22:36:10 -06:00
|
|
|
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 ) } );
|
2013-12-27 16:59:59 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
@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;
|
2014-06-04 22:59:56 -05:00
|
|
|
out.add( AxisAlignedBB.getBoundingBox( xOff + (double) 0.15, yOff + (double) 0.15, zOff + (double) 0.15,// ahh
|
2013-12-27 16:59:59 -06:00
|
|
|
xOff + (double) 0.85, yOff + (double) 0.85, zOff + (double) 0.85 ) );
|
|
|
|
}
|
2014-02-05 22:36:10 -06:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean requiresTESR()
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
2013-12-27 16:59:59 -06:00
|
|
|
}
|