package com.hbm.tileentity.machine.oil; import com.hbm.interfaces.IFluidAcceptor; import com.hbm.inventory.UpgradeManager; import com.hbm.inventory.fluid.FluidType; import com.hbm.inventory.fluid.Fluids; import com.hbm.inventory.fluid.tank.FluidTank; import com.hbm.inventory.recipes.SolidificationRecipes; import com.hbm.items.machine.ItemMachineUpgrade.UpgradeType; import com.hbm.lib.Library; import com.hbm.tileentity.TileEntityMachineBase; import com.hbm.util.Tuple.Pair; import com.hbm.util.fauxpointtwelve.DirPos; import api.hbm.energy.IEnergyUser; import api.hbm.fluid.IFluidStandardReceiver; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; import net.minecraft.item.ItemStack; import net.minecraft.nbt.NBTTagCompound; import net.minecraft.util.AxisAlignedBB; public class TileEntityMachineSolidifier extends TileEntityMachineBase implements IEnergyUser, IFluidAcceptor, IFluidStandardReceiver { public long power; public static final long maxPower = 100000; public static final int usageBase = 500; public int usage; public int progress; public static final int processTimeBase = 200; public int processTime; public FluidTank tank; public TileEntityMachineSolidifier() { super(5); tank = new FluidTank(Fluids.NONE, 24000, 0); } @Override public String getName() { return "container.machineSolidifier"; } @Override public void updateEntity() { if(!worldObj.isRemote) { this.power = Library.chargeTEFromItems(slots, 1, power, maxPower); tank.setType(4, slots); tank.updateTank(this); this.updateConnections(); UpgradeManager.eval(slots, 2, 3); int speed = Math.min(UpgradeManager.getLevel(UpgradeType.SPEED), 3); int power = Math.min(UpgradeManager.getLevel(UpgradeType.POWER), 3); this.processTime = processTimeBase - (processTimeBase / 4) * speed; this.usage = usageBase - (usageBase / 4) * speed; if(this.canProcess()) this.process(); else this.progress = 0; NBTTagCompound data = new NBTTagCompound(); data.setLong("power", this.power); data.setInteger("progress", this.progress); data.setInteger("usage", this.usage); data.setInteger("processTime", this.processTime); this.networkPack(data, 50); } } private void updateConnections() { for(DirPos pos : getConPos()) { this.trySubscribe(worldObj, pos.getX(), pos.getY(), pos.getZ(), pos.getDir()); this.trySubscribe(tank.getTankType(), worldObj, pos.getX(), pos.getY(), pos.getZ(), pos.getDir()); } } private DirPos[] getConPos() { return new DirPos[] { new DirPos(xCoord, yCoord + 4, zCoord, Library.POS_Y), new DirPos(xCoord, yCoord - 1, zCoord, Library.NEG_Y), new DirPos(xCoord + 2, yCoord + 1, zCoord, Library.POS_X), new DirPos(xCoord - 2, yCoord + 1, zCoord, Library.NEG_X), new DirPos(xCoord, yCoord + 1, zCoord + 2, Library.POS_Z), new DirPos(xCoord, yCoord + 1, zCoord - 2, Library.NEG_Z) }; } @Override public boolean canExtractItem(int slot, ItemStack stack, int side) { return slot == 0; } @Override public int[] getAccessibleSlotsFromSide(int side) { return new int[] { 0 }; } public boolean canProcess() { if(this.power < usage) return false; Pair out = SolidificationRecipes.getOutput(tank.getTankType()); if(out == null) return false; int req = out.getKey(); ItemStack stack = out.getValue(); if(req > tank.getFill()) return false; if(slots[0] != null) { if(slots[0].getItem() != stack.getItem()) return false; if(slots[0].getItemDamage() != stack.getItemDamage()) return false; if(slots[0].stackSize + stack.stackSize > slots[0].getMaxStackSize()) return false; } return true; } public void process() { this.power -= usage; progress++; if(progress >= processTime) { Pair out = SolidificationRecipes.getOutput(tank.getTankType()); int req = out.getKey(); ItemStack stack = out.getValue(); tank.setFill(tank.getFill() - req); if(slots[0] == null) { slots[0] = stack.copy(); } else { slots[0].stackSize += stack.stackSize; } progress = 0; this.markDirty(); } } @Override public void networkUnpack(NBTTagCompound nbt) { this.power = nbt.getLong("power"); this.progress = nbt.getInteger("progress"); this.usage = nbt.getInteger("usage"); this.processTime = nbt.getInteger("processTime"); } @Override public void readFromNBT(NBTTagCompound nbt) { super.readFromNBT(nbt); tank.readFromNBT(nbt, "tank"); } @Override public void writeToNBT(NBTTagCompound nbt) { super.writeToNBT(nbt); tank.writeToNBT(nbt, "tank"); } @Override public void setPower(long power) { this.power = power; } @Override public long getPower() { return power; } @Override public long getMaxPower() { return maxPower; } @Override public void setFillForSync(int fill, int index) { tank.setFill(fill); } @Override public void setFluidFill(int fill, FluidType type) { if(type == tank.getTankType()) tank.setFill(fill); } @Override public void setTypeForSync(FluidType type, int index) { tank.setTankType(type); } @Override public int getFluidFill(FluidType type) { return tank.getTankType() == type ? tank.getFill() : 0; } @Override public int getMaxFluidFill(FluidType type) { return tank.getTankType() == type ? tank.getMaxFill() : 0; } AxisAlignedBB bb = null; @Override public AxisAlignedBB getRenderBoundingBox() { if(bb == null) { bb = AxisAlignedBB.getBoundingBox( xCoord - 1, yCoord, zCoord - 1, xCoord + 2, yCoord + 4, zCoord + 2 ); } return bb; } @Override @SideOnly(Side.CLIENT) public double getMaxRenderDistanceSquared() { return 65536.0D; } @Override public FluidTank[] getReceivingTanks() { return new FluidTank[] { tank }; } }