GT5-Unofficial/src/main/java/gregtech/common/gui/GT_Container_Boiler.java

92 lines
3.5 KiB
Java
Raw Normal View History

2015-06-23 22:29:05 +00:00
package gregtech.common.gui;
import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
import gregtech.api.gui.GT_ContainerMetaTile_Machine;
import gregtech.api.interfaces.tileentity.IGregTechTileEntity;
import gregtech.common.tileentities.boilers.GT_MetaTileEntity_Boiler;
import java.util.Iterator;
import java.util.List;
import net.minecraft.entity.player.InventoryPlayer;
import net.minecraft.inventory.ICrafting;
import net.minecraft.inventory.Slot;
import net.minecraftforge.fluids.FluidStack;
public class GT_Container_Boiler
extends GT_ContainerMetaTile_Machine
{
public GT_Container_Boiler(InventoryPlayer aInventoryPlayer, IGregTechTileEntity aTileEntity, int aSteamCapacity)
{
super(aInventoryPlayer, aTileEntity);
this.mSteamCapacity = aSteamCapacity;
}
public void addSlots(InventoryPlayer aInventoryPlayer)
{
addSlotToContainer(new Slot(this.mTileEntity, 2, 116, 62));
addSlotToContainer(new Slot(this.mTileEntity, 0, 44, 26));
addSlotToContainer(new Slot(this.mTileEntity, 1, 44, 62));
addSlotToContainer(new Slot(this.mTileEntity, 3, 116, 26));
}
public int getSlotCount()
{
return 4;
}
public int getShiftClickSlotCount()
{
return 1;
}
public int mWaterAmount = 0;
public int mSteamAmount = 0;
public int mProcessingEnergy = 0;
public int mTemperature = 2;
private final int mSteamCapacity;
public void detectAndSendChanges()
{
super.detectAndSendChanges();
if ((this.mTileEntity.isClientSide()) || (this.mTileEntity.getMetaTileEntity() == null)) {
return;
}
this.mTemperature = ((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mTemperature;
this.mProcessingEnergy = ((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mProcessingEnergy;
this.mSteamAmount = (((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mSteam == null ? 0 : ((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mSteam.amount);
this.mWaterAmount = (((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mFluid == null ? 0 : ((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).mFluid.amount);
this.mTemperature = Math.min(54, Math.max(0, this.mTemperature * 54 / (((GT_MetaTileEntity_Boiler)this.mTileEntity.getMetaTileEntity()).maxProgresstime() - 10)));
this.mSteamAmount = Math.min(54, Math.max(0, this.mSteamAmount * 54 / (this.mSteamCapacity - 100)));
this.mWaterAmount = Math.min(54, Math.max(0, this.mWaterAmount * 54 / 15900));
this.mProcessingEnergy = Math.min(14, Math.max(this.mProcessingEnergy > 0 ? 1 : 0, this.mProcessingEnergy * 14 / 1000));
Iterator var2 = this.crafters.iterator();
while (var2.hasNext())
{
ICrafting var1 = (ICrafting)var2.next();
var1.sendProgressBarUpdate(this, 100, this.mTemperature);
var1.sendProgressBarUpdate(this, 101, this.mProcessingEnergy);
var1.sendProgressBarUpdate(this, 102, this.mSteamAmount);
var1.sendProgressBarUpdate(this, 103, this.mWaterAmount);
}
}
@SideOnly(Side.CLIENT)
public void updateProgressBar(int par1, int par2)
{
super.updateProgressBar(par1, par2);
switch (par1)
{
case 100:
this.mTemperature = par2; break;
case 101:
this.mProcessingEnergy = par2; break;
case 102:
this.mSteamAmount = par2; break;
case 103:
this.mWaterAmount = par2;
}
}
}