2012-11-05 20:29:04 +01:00
|
|
|
package mekanism.client;
|
2012-10-02 20:39:40 +02:00
|
|
|
|
2012-12-20 22:53:39 +01:00
|
|
|
import mekanism.common.ContainerEnergyCube;
|
2013-07-20 18:10:14 +02:00
|
|
|
import mekanism.common.MekanismUtils;
|
|
|
|
import mekanism.common.MekanismUtils.ResourceType;
|
2013-07-31 22:44:53 +02:00
|
|
|
import mekanism.common.TileEntityEnergyCube;
|
2012-12-20 22:53:39 +01:00
|
|
|
import net.minecraft.client.gui.inventory.GuiContainer;
|
|
|
|
import net.minecraft.entity.player.InventoryPlayer;
|
|
|
|
import net.minecraft.util.StatCollector;
|
|
|
|
|
2012-10-02 20:39:40 +02:00
|
|
|
import org.lwjgl.opengl.GL11;
|
|
|
|
|
2013-03-18 17:23:57 +01:00
|
|
|
import universalelectricity.core.electricity.ElectricityDisplay;
|
|
|
|
import universalelectricity.core.electricity.ElectricityDisplay.ElectricUnit;
|
2013-07-31 22:44:53 +02:00
|
|
|
import cpw.mods.fml.relauncher.Side;
|
|
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
2012-11-25 16:45:00 +01:00
|
|
|
|
2013-04-13 16:33:37 +02:00
|
|
|
@SideOnly(Side.CLIENT)
|
2012-11-28 16:33:34 +01:00
|
|
|
public class GuiEnergyCube extends GuiContainer
|
2012-10-02 20:39:40 +02:00
|
|
|
{
|
2013-08-02 09:16:38 +02:00
|
|
|
public TileEntityEnergyCube tileEntity;
|
2012-10-02 20:39:40 +02:00
|
|
|
|
2013-08-02 09:16:38 +02:00
|
|
|
public GuiRedstoneControl redstoneControl;
|
2012-10-02 20:39:40 +02:00
|
|
|
|
2012-11-28 16:33:34 +01:00
|
|
|
public GuiEnergyCube(InventoryPlayer inventory, TileEntityEnergyCube tentity)
|
2012-10-02 20:39:40 +02:00
|
|
|
{
|
2012-11-28 16:33:34 +01:00
|
|
|
super(new ContainerEnergyCube(inventory, tentity));
|
2012-10-03 21:12:17 +02:00
|
|
|
tileEntity = tentity;
|
2013-08-02 09:16:38 +02:00
|
|
|
redstoneControl = new GuiRedstoneControl(this, tileEntity, MekanismUtils.getResource(ResourceType.GUI, "GuiEnergyCube.png"));
|
2012-10-02 20:39:40 +02:00
|
|
|
}
|
|
|
|
|
2012-11-06 16:44:14 +01:00
|
|
|
@Override
|
2013-08-02 09:16:38 +02:00
|
|
|
protected void drawGuiContainerForegroundLayer(int mouseX, int mouseY)
|
2012-10-02 20:39:40 +02:00
|
|
|
{
|
2013-08-02 09:16:38 +02:00
|
|
|
int xAxis = (mouseX - (width - xSize) / 2);
|
|
|
|
int yAxis = (mouseY - (height - ySize) / 2);
|
|
|
|
|
|
|
|
String capacityInfo = ElectricityDisplay.getDisplayShort(tileEntity.getEnergyStored(), ElectricUnit.JOULES) + "/" + ElectricityDisplay.getDisplayShort(tileEntity.getMaxEnergyStored(), ElectricUnit.JOULES);
|
2012-12-03 16:10:48 +01:00
|
|
|
String outputInfo = "Voltage: " + tileEntity.getVoltage() + "v";
|
2013-08-02 09:16:38 +02:00
|
|
|
|
2012-11-28 16:33:34 +01:00
|
|
|
fontRenderer.drawString(tileEntity.tier.name + " Energy Cube", 43, 6, 0x404040);
|
2012-12-03 16:10:48 +01:00
|
|
|
fontRenderer.drawString(capacityInfo, 45, 40, 0x00CD00);
|
|
|
|
fontRenderer.drawString(outputInfo, 45, 49, 0x00CD00);
|
2013-08-06 00:58:24 +02:00
|
|
|
fontRenderer.drawString(StatCollector.translateToLocal("container.inventory"), 8, ySize - 96 + 2, 0x404040);
|
2013-08-02 09:16:38 +02:00
|
|
|
|
|
|
|
redstoneControl.renderForeground(xAxis, yAxis);
|
2012-10-02 20:39:40 +02:00
|
|
|
}
|
|
|
|
|
2012-11-06 16:44:14 +01:00
|
|
|
@Override
|
2013-08-02 09:16:38 +02:00
|
|
|
protected void drawGuiContainerBackgroundLayer(float par1, int mouseX, int mouseY)
|
2012-10-02 20:39:40 +02:00
|
|
|
{
|
2013-07-20 18:10:14 +02:00
|
|
|
mc.renderEngine.func_110577_a(MekanismUtils.getResource(ResourceType.GUI, "GuiEnergyCube.png"));
|
2012-10-02 20:39:40 +02:00
|
|
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
2013-08-02 09:16:38 +02:00
|
|
|
int guiWidth = (width - xSize) / 2;
|
|
|
|
int guiHeight = (height - ySize) / 2;
|
2012-10-02 20:39:40 +02:00
|
|
|
drawTexturedModalRect(guiWidth, guiHeight, 0, 0, xSize, ySize);
|
2013-08-02 09:16:38 +02:00
|
|
|
|
|
|
|
int xAxis = (mouseX - (width - xSize) / 2);
|
|
|
|
int yAxis = (mouseY - (height - ySize) / 2);
|
|
|
|
|
2013-08-06 00:58:24 +02:00
|
|
|
int scale = (int)((tileEntity.electricityStored / tileEntity.tier.MAX_ELECTRICITY) * 72);
|
|
|
|
drawTexturedModalRect(guiWidth + 65, guiHeight + 17, 176, 0, scale, 10);
|
2013-08-02 09:16:38 +02:00
|
|
|
|
|
|
|
redstoneControl.renderBackground(xAxis, yAxis, guiWidth, guiHeight);
|
2012-10-02 20:39:40 +02:00
|
|
|
}
|
2013-08-02 09:16:38 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void mouseClicked(int mouseX, int mouseY, int button)
|
|
|
|
{
|
|
|
|
super.mouseClicked(mouseX, mouseY, button);
|
|
|
|
|
|
|
|
if(button == 0)
|
|
|
|
{
|
|
|
|
int xAxis = (mouseX - (width - xSize) / 2);
|
|
|
|
int yAxis = (mouseY - (height - ySize) / 2);
|
|
|
|
|
|
|
|
redstoneControl.mouseClicked(xAxis, yAxis);
|
|
|
|
}
|
|
|
|
}
|
2012-10-02 20:39:40 +02:00
|
|
|
}
|