2015-05-30 17:47:57 +02:00
|
|
|
package ellpeck.actuallyadditions.tile;
|
|
|
|
|
|
|
|
import cpw.mods.fml.relauncher.Side;
|
|
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
|
|
|
import ellpeck.actuallyadditions.config.values.ConfigIntValues;
|
2015-07-02 04:21:21 +02:00
|
|
|
import ellpeck.actuallyadditions.network.sync.IPacketSyncerToClient;
|
|
|
|
import ellpeck.actuallyadditions.network.sync.PacketSyncerToClient;
|
2015-07-07 11:51:05 +02:00
|
|
|
import ellpeck.actuallyadditions.util.WorldPos;
|
2015-05-30 17:47:57 +02:00
|
|
|
import ellpeck.actuallyadditions.util.WorldUtil;
|
|
|
|
import net.minecraft.block.Block;
|
|
|
|
import net.minecraft.init.Blocks;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
import net.minecraftforge.common.util.ForgeDirection;
|
|
|
|
import net.minecraftforge.fluids.*;
|
|
|
|
|
2015-07-02 04:21:21 +02:00
|
|
|
public class TileEntityFluidCollector extends TileEntityInventoryBase implements IFluidHandler, IPacketSyncerToClient{
|
2015-05-30 17:47:57 +02:00
|
|
|
|
|
|
|
public FluidTank tank = new FluidTank(8*FluidContainerRegistry.BUCKET_VOLUME);
|
2015-07-02 04:21:21 +02:00
|
|
|
private int lastTankAmount;
|
2015-05-30 17:47:57 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public int fill(ForgeDirection from, FluidStack resource, boolean doFill){
|
|
|
|
if(this.isPlacer){
|
|
|
|
return this.tank.fill(resource, doFill);
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public FluidStack drain(ForgeDirection from, FluidStack resource, boolean doDrain){
|
|
|
|
if(!this.isPlacer){
|
|
|
|
return this.tank.drain(resource.amount, doDrain);
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public FluidStack drain(ForgeDirection from, int maxDrain, boolean doDrain){
|
|
|
|
if(!this.isPlacer){
|
|
|
|
return this.tank.drain(maxDrain, doDrain);
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean canFill(ForgeDirection from, Fluid fluid){
|
2015-06-12 19:12:06 +02:00
|
|
|
return this.isPlacer;
|
2015-05-30 17:47:57 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean canDrain(ForgeDirection from, Fluid fluid){
|
2015-06-12 19:12:06 +02:00
|
|
|
return !this.isPlacer;
|
2015-05-30 17:47:57 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public FluidTankInfo[] getTankInfo(ForgeDirection from){
|
|
|
|
return new FluidTankInfo[]{this.tank.getInfo()};
|
|
|
|
}
|
|
|
|
|
2015-07-02 04:21:21 +02:00
|
|
|
@Override
|
|
|
|
public int[] getValues(){
|
|
|
|
return new int[]{this.tank.getFluidAmount(), this.tank.getFluid() == null ? -1 : this.tank.getFluid().getFluidID()};
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void setValues(int[] values){
|
|
|
|
if(values[1] != -1){
|
|
|
|
Fluid fluid = FluidRegistry.getFluid(values[1]);
|
|
|
|
this.tank.setFluid(new FluidStack(fluid, values[0]));
|
|
|
|
}
|
|
|
|
else this.tank.setFluid(null);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void sendUpdate(){
|
|
|
|
PacketSyncerToClient.sendPacket(this);
|
|
|
|
}
|
|
|
|
|
2015-05-30 17:47:57 +02:00
|
|
|
public static class TileEntityFluidPlacer extends TileEntityFluidCollector{
|
|
|
|
|
|
|
|
public TileEntityFluidPlacer(){
|
|
|
|
super(2, "fluidPlacer");
|
|
|
|
this.isPlacer = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isPlacer;
|
|
|
|
|
|
|
|
private final int timeNeeded = ConfigIntValues.BREAKER_TIME_NEEDED.getValue();
|
|
|
|
private int currentTime;
|
|
|
|
|
|
|
|
public TileEntityFluidCollector(int slots, String name){
|
|
|
|
super(slots, name);
|
|
|
|
}
|
|
|
|
|
|
|
|
public TileEntityFluidCollector(){
|
|
|
|
super(2, "fluidCollector");
|
|
|
|
this.isPlacer = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
@SuppressWarnings("unchecked")
|
|
|
|
public void updateEntity(){
|
|
|
|
if(!worldObj.isRemote){
|
|
|
|
if(!worldObj.isBlockIndirectlyGettingPowered(xCoord, yCoord, zCoord)){
|
|
|
|
if(this.currentTime > 0){
|
|
|
|
this.currentTime--;
|
|
|
|
if(this.currentTime <= 0){
|
|
|
|
ForgeDirection sideToManipulate = ForgeDirection.getOrientation(worldObj.getBlockMetadata(xCoord, yCoord, zCoord));
|
|
|
|
|
2015-07-07 11:51:05 +02:00
|
|
|
WorldPos coordsBlock = WorldUtil.getCoordsFromSide(sideToManipulate, xCoord, yCoord, zCoord);
|
2015-05-30 17:47:57 +02:00
|
|
|
if(coordsBlock != null){
|
2015-07-07 11:51:05 +02:00
|
|
|
Block blockToBreak = worldObj.getBlock(coordsBlock.getX(), coordsBlock.getY(), coordsBlock.getZ());
|
|
|
|
if(!this.isPlacer && blockToBreak != null && worldObj.getBlockMetadata(coordsBlock.getX(), coordsBlock.getY(), coordsBlock.getZ()) == 0){
|
2015-05-30 17:47:57 +02:00
|
|
|
if(blockToBreak instanceof IFluidBlock && ((IFluidBlock)blockToBreak).getFluid() != null){
|
|
|
|
if(this.tank.fill(new FluidStack(((IFluidBlock)blockToBreak).getFluid(), FluidContainerRegistry.BUCKET_VOLUME), false) >= FluidContainerRegistry.BUCKET_VOLUME){
|
|
|
|
this.tank.fill(new FluidStack(((IFluidBlock)blockToBreak).getFluid(), FluidContainerRegistry.BUCKET_VOLUME), true);
|
|
|
|
WorldUtil.breakBlockAtSide(sideToManipulate, worldObj, xCoord, yCoord, zCoord);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(blockToBreak == Blocks.lava || blockToBreak == Blocks.flowing_lava){
|
|
|
|
if(this.tank.fill(new FluidStack(FluidRegistry.LAVA, FluidContainerRegistry.BUCKET_VOLUME), false) >= FluidContainerRegistry.BUCKET_VOLUME){
|
|
|
|
this.tank.fill(new FluidStack(FluidRegistry.LAVA, FluidContainerRegistry.BUCKET_VOLUME), true);
|
|
|
|
WorldUtil.breakBlockAtSide(sideToManipulate, worldObj, xCoord, yCoord, zCoord);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(blockToBreak == Blocks.water || blockToBreak == Blocks.flowing_water){
|
|
|
|
if(this.tank.fill(new FluidStack(FluidRegistry.WATER, FluidContainerRegistry.BUCKET_VOLUME), false) >= FluidContainerRegistry.BUCKET_VOLUME){
|
|
|
|
this.tank.fill(new FluidStack(FluidRegistry.WATER, FluidContainerRegistry.BUCKET_VOLUME), true);
|
|
|
|
WorldUtil.breakBlockAtSide(sideToManipulate, worldObj, xCoord, yCoord, zCoord);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-07-07 11:51:05 +02:00
|
|
|
else if(this.isPlacer && worldObj.getBlock(coordsBlock.getX(), coordsBlock.getY(), coordsBlock.getZ()).isReplaceable(worldObj, coordsBlock.getX(), coordsBlock.getY(), coordsBlock.getZ())){
|
2015-05-30 17:47:57 +02:00
|
|
|
if(this.tank.getFluidAmount() >= FluidContainerRegistry.BUCKET_VOLUME){
|
|
|
|
if(this.tank.getFluid().getFluid().getBlock() != null){
|
|
|
|
Block block = worldObj.getBlock(xCoord+sideToManipulate.offsetX, yCoord+sideToManipulate.offsetY, zCoord+sideToManipulate.offsetZ);
|
|
|
|
if(!(block instanceof IFluidBlock) && block != Blocks.lava && block != Blocks.water && block != Blocks.flowing_lava && block != Blocks.flowing_water){
|
|
|
|
WorldUtil.placeBlockAtSide(sideToManipulate, worldObj, xCoord, yCoord, zCoord, new ItemStack(this.tank.getFluid().getFluid().getBlock()));
|
|
|
|
this.tank.drain(FluidContainerRegistry.BUCKET_VOLUME, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else this.currentTime = this.timeNeeded;
|
|
|
|
}
|
|
|
|
|
2015-07-01 15:14:39 +02:00
|
|
|
if(!this.isPlacer) WorldUtil.fillBucket(tank, slots, 0, 1);
|
|
|
|
else WorldUtil.emptyBucket(tank, slots, 0, 1);
|
2015-05-30 17:47:57 +02:00
|
|
|
|
2015-07-02 01:26:37 +02:00
|
|
|
if(!this.isPlacer && this.tank.getFluidAmount() > 0){
|
2015-07-02 01:14:22 +02:00
|
|
|
WorldUtil.pushFluid(worldObj, xCoord, yCoord, zCoord, ForgeDirection.DOWN, this.tank);
|
2015-07-02 01:26:37 +02:00
|
|
|
if(!worldObj.isBlockIndirectlyGettingPowered(xCoord, yCoord, zCoord)){
|
|
|
|
WorldUtil.pushFluid(worldObj, xCoord, yCoord, zCoord, ForgeDirection.NORTH, this.tank);
|
|
|
|
WorldUtil.pushFluid(worldObj, xCoord, yCoord, zCoord, ForgeDirection.EAST, this.tank);
|
|
|
|
WorldUtil.pushFluid(worldObj, xCoord, yCoord, zCoord, ForgeDirection.SOUTH, this.tank);
|
|
|
|
WorldUtil.pushFluid(worldObj, xCoord, yCoord, zCoord, ForgeDirection.WEST, this.tank);
|
|
|
|
}
|
2015-05-30 17:47:57 +02:00
|
|
|
}
|
|
|
|
|
2015-07-02 04:21:21 +02:00
|
|
|
if(lastTankAmount != this.tank.getFluidAmount()){
|
|
|
|
lastTankAmount = this.tank.getFluidAmount();
|
|
|
|
this.sendUpdate();
|
2015-05-30 17:47:57 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@SideOnly(Side.CLIENT)
|
|
|
|
public int getTankScaled(int i){
|
|
|
|
return this.tank.getFluidAmount() * i / this.tank.getCapacity();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void writeToNBT(NBTTagCompound compound){
|
|
|
|
super.writeToNBT(compound);
|
|
|
|
compound.setInteger("CurrentTime", this.currentTime);
|
|
|
|
this.tank.writeToNBT(compound);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void readFromNBT(NBTTagCompound compound){
|
|
|
|
super.readFromNBT(compound);
|
|
|
|
this.currentTime = compound.getInteger("CurrentTime");
|
|
|
|
this.tank.readFromNBT(compound);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isItemValidForSlot(int i, ItemStack stack){
|
|
|
|
if(i == 0){
|
|
|
|
if(this.isPlacer) return FluidContainerRegistry.isFilledContainer(stack);
|
|
|
|
else return stack.isItemEqual(FluidContainerRegistry.EMPTY_BUCKET);
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean canInsertItem(int slot, ItemStack stack, int side){
|
|
|
|
return this.isItemValidForSlot(slot, stack);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean canExtractItem(int slot, ItemStack stack, int side){
|
|
|
|
return slot == 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|