2013-08-26 18:49:32 -04:00
|
|
|
package mekanism.client.gui;
|
2013-04-28 15:23:08 -04:00
|
|
|
|
2013-08-26 18:57:08 -04:00
|
|
|
import mekanism.client.render.MekanismRenderer;
|
2013-11-26 22:44:14 -05:00
|
|
|
import mekanism.common.TankUpdateProtocol;
|
2013-08-26 18:49:32 -04:00
|
|
|
import mekanism.common.inventory.container.ContainerDynamicTank;
|
|
|
|
import mekanism.common.tileentity.TileEntityDynamicTank;
|
2013-08-26 18:57:08 -04:00
|
|
|
import mekanism.common.util.MekanismUtils;
|
|
|
|
import mekanism.common.util.MekanismUtils.ResourceType;
|
2013-04-28 15:23:08 -04:00
|
|
|
import net.minecraft.entity.player.InventoryPlayer;
|
2013-07-20 12:10:14 -04:00
|
|
|
import net.minecraftforge.fluids.FluidStack;
|
2013-04-28 15:23:08 -04:00
|
|
|
|
|
|
|
import org.lwjgl.opengl.GL11;
|
|
|
|
|
|
|
|
import cpw.mods.fml.relauncher.Side;
|
|
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
|
|
|
|
|
|
|
@SideOnly(Side.CLIENT)
|
2013-11-26 20:11:26 -05:00
|
|
|
public class GuiDynamicTank extends GuiMekanism
|
2013-04-28 15:23:08 -04:00
|
|
|
{
|
|
|
|
public TileEntityDynamicTank tileEntity;
|
|
|
|
|
|
|
|
private int guiWidth;
|
|
|
|
private int guiHeight;
|
|
|
|
|
|
|
|
public GuiDynamicTank(InventoryPlayer inventory, TileEntityDynamicTank tentity)
|
|
|
|
{
|
|
|
|
super(new ContainerDynamicTank(inventory, tentity));
|
|
|
|
tileEntity = tentity;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void drawGuiContainerForegroundLayer(int mouseX, int mouseY)
|
|
|
|
{
|
|
|
|
int xAxis = (mouseX - (width - xSize) / 2);
|
|
|
|
int yAxis = (mouseY - (height - ySize) / 2);
|
|
|
|
|
2013-11-30 00:28:02 -05:00
|
|
|
fontRenderer.drawString(tileEntity.getInvName(), 45, 6, 0x404040);
|
|
|
|
fontRenderer.drawString(MekanismUtils.localize("container.inventory"), 8, (ySize - 94) + 2, 0x404040);
|
|
|
|
fontRenderer.drawString(MekanismUtils.localize("gui.volume") + ": " + tileEntity.clientCapacity/TankUpdateProtocol.FLUID_PER_TANK, 53, 26, 0x00CD00);
|
|
|
|
fontRenderer.drawString(tileEntity.structure.fluidStored != null ? tileEntity.structure.fluidStored.getFluid().getName() + ":" : MekanismUtils.localize("gui.noFluid"), 53, 44, 0x00CD00);
|
2013-06-29 23:06:24 -04:00
|
|
|
|
2013-07-20 12:10:14 -04:00
|
|
|
if(tileEntity.structure.fluidStored != null)
|
2013-06-29 23:06:24 -04:00
|
|
|
{
|
2013-07-20 12:10:14 -04:00
|
|
|
fontRenderer.drawString(tileEntity.structure.fluidStored.amount + "mB", 53, 53, 0x00CD00);
|
2013-06-29 23:06:24 -04:00
|
|
|
}
|
2013-04-28 15:23:08 -04:00
|
|
|
|
|
|
|
if(xAxis >= 7 && xAxis <= 39 && yAxis >= 14 && yAxis <= 72)
|
|
|
|
{
|
2013-11-30 00:28:02 -05:00
|
|
|
drawCreativeTabHoveringText(tileEntity.structure.fluidStored != null ? tileEntity.structure.fluidStored.getFluid().getLocalizedName() + ": " + tileEntity.structure.fluidStored.amount + "mB" : MekanismUtils.localize("gui.empty"), xAxis, yAxis);
|
2013-04-28 15:23:08 -04:00
|
|
|
}
|
2013-11-26 20:11:26 -05:00
|
|
|
|
|
|
|
super.drawGuiContainerForegroundLayer(mouseX, mouseY);
|
2013-04-28 15:23:08 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2013-11-26 20:11:26 -05:00
|
|
|
protected void drawGuiContainerBackgroundLayer(float partialTick, int mouseX, int mouseY)
|
2013-04-28 15:23:08 -04:00
|
|
|
{
|
2013-11-26 20:11:26 -05:00
|
|
|
super.drawGuiContainerBackgroundLayer(partialTick, mouseX, mouseY);
|
|
|
|
|
2013-09-28 02:59:47 +01:00
|
|
|
mc.renderEngine.bindTexture(MekanismUtils.getResource(ResourceType.GUI, "GuiDynamicTank.png"));
|
2013-04-28 15:23:08 -04:00
|
|
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
|
|
|
guiWidth = (width - xSize) / 2;
|
|
|
|
guiHeight = (height - ySize) / 2;
|
|
|
|
drawTexturedModalRect(guiWidth, guiHeight, 0, 0, xSize, ySize);
|
|
|
|
|
2013-07-20 12:10:14 -04:00
|
|
|
if(tileEntity.getScaledFluidLevel(58) > 0)
|
2013-04-28 15:23:08 -04:00
|
|
|
{
|
2013-11-26 20:11:26 -05:00
|
|
|
displayGauge(7, 14, tileEntity.getScaledFluidLevel(58), tileEntity.structure.fluidStored, 0);
|
|
|
|
displayGauge(23, 14, tileEntity.getScaledFluidLevel(58), tileEntity.structure.fluidStored, 1);
|
2013-04-28 15:23:08 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Credit to BuildCraft for both the gauge texture and parts of the code.
|
|
|
|
*/
|
2013-11-26 20:11:26 -05:00
|
|
|
public void displayGauge(int xPos, int yPos, int scale, FluidStack fluid, int side /*0-left, 1-right*/)
|
2013-04-28 15:23:08 -04:00
|
|
|
{
|
2013-07-20 12:10:14 -04:00
|
|
|
if(fluid == null)
|
2013-04-28 15:23:08 -04:00
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
int start = 0;
|
|
|
|
|
|
|
|
while(true)
|
|
|
|
{
|
|
|
|
int renderRemaining = 0;
|
|
|
|
|
|
|
|
if(scale > 16)
|
|
|
|
{
|
|
|
|
renderRemaining = 16;
|
|
|
|
scale -= 16;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
renderRemaining = scale;
|
|
|
|
scale = 0;
|
|
|
|
}
|
|
|
|
|
2013-11-24 12:12:42 -06:00
|
|
|
mc.renderEngine.bindTexture(MekanismRenderer.getBlocksTexture());
|
2013-11-26 20:11:26 -05:00
|
|
|
drawTexturedModelRectFromIcon(guiWidth + xPos, guiHeight + yPos + 58 - renderRemaining - start, fluid.getFluid().getIcon(), 16, 16 - (16 - renderRemaining));
|
2013-04-28 15:23:08 -04:00
|
|
|
start+=16;
|
|
|
|
|
|
|
|
if(renderRemaining == 0 || scale == 0)
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-09-28 02:59:47 +01:00
|
|
|
mc.renderEngine.bindTexture(MekanismUtils.getResource(ResourceType.GUI, "GuiDynamicTank.png"));
|
2013-11-26 20:11:26 -05:00
|
|
|
drawTexturedModalRect(guiWidth + xPos, guiHeight + yPos, 176, side == 0 ? 0 : 54, 16, 54);
|
2013-04-28 15:23:08 -04:00
|
|
|
}
|
|
|
|
}
|