2013-08-26 18:49:32 -04:00
|
|
|
package mekanism.client.gui;
|
2012-12-20 16:53:39 -05:00
|
|
|
|
2013-02-26 20:21:30 -05:00
|
|
|
import java.util.ArrayList;
|
|
|
|
|
2013-11-30 00:28:02 -05:00
|
|
|
import mekanism.common.Object3D;
|
2012-12-20 16:53:39 -05:00
|
|
|
import mekanism.common.PacketHandler;
|
2013-06-13 17:37:30 -04:00
|
|
|
import mekanism.common.PacketHandler.Transmission;
|
2013-08-26 18:49:32 -04:00
|
|
|
import mekanism.common.inventory.container.ContainerMetallurgicInfuser;
|
2013-06-13 17:37:30 -04:00
|
|
|
import mekanism.common.network.PacketTileEntity;
|
2013-08-26 18:49:32 -04:00
|
|
|
import mekanism.common.tileentity.TileEntityMetallurgicInfuser;
|
2013-08-26 18:57:08 -04:00
|
|
|
import mekanism.common.util.MekanismUtils;
|
|
|
|
import mekanism.common.util.MekanismUtils.ResourceType;
|
2012-12-20 16:53:39 -05:00
|
|
|
import net.minecraft.entity.player.InventoryPlayer;
|
2013-08-26 18:49:32 -04:00
|
|
|
|
2012-12-20 16:53:39 -05:00
|
|
|
import org.lwjgl.opengl.GL11;
|
|
|
|
|
2013-04-13 10:33:37 -04:00
|
|
|
import cpw.mods.fml.relauncher.Side;
|
|
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
|
|
|
|
|
|
|
@SideOnly(Side.CLIENT)
|
2013-08-26 18:28:55 -04:00
|
|
|
public class GuiMetallurgicInfuser extends GuiMekanism
|
2012-12-20 16:53:39 -05:00
|
|
|
{
|
|
|
|
public TileEntityMetallurgicInfuser tileEntity;
|
|
|
|
|
|
|
|
public GuiMetallurgicInfuser(InventoryPlayer inventory, TileEntityMetallurgicInfuser tentity)
|
|
|
|
{
|
2013-11-29 19:11:07 -05:00
|
|
|
super(tentity, new ContainerMetallurgicInfuser(inventory, tentity));
|
2012-12-20 16:53:39 -05:00
|
|
|
tileEntity = tentity;
|
2013-08-25 20:54:34 -04:00
|
|
|
|
2013-08-26 18:28:55 -04:00
|
|
|
guiElements.add(new GuiRedstoneControl(this, tileEntity, MekanismUtils.getResource(ResourceType.GUI, "GuiMetallurgicInfuser.png")));
|
|
|
|
guiElements.add(new GuiUpgradeManagement(this, tileEntity, MekanismUtils.getResource(ResourceType.GUI, "GuiMetallurgicInfuser.png")));
|
2013-10-30 15:22:43 -04:00
|
|
|
guiElements.add(new GuiConfigurationTab(this, tileEntity, MekanismUtils.getResource(ResourceType.GUI, "GuiMetallurgicInfuser.png")));
|
2012-12-20 16:53:39 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2013-05-19 18:43:01 -04:00
|
|
|
protected void drawGuiContainerForegroundLayer(int mouseX, int mouseY)
|
2013-11-26 20:11:26 -05:00
|
|
|
{
|
2013-05-19 18:43:01 -04:00
|
|
|
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 - 96) + 2, 0x404040);
|
2013-05-19 18:43:01 -04:00
|
|
|
|
|
|
|
if(xAxis >= 165 && xAxis <= 169 && yAxis >= 17 && yAxis <= 69)
|
|
|
|
{
|
2013-11-22 20:58:49 -05:00
|
|
|
drawCreativeTabHoveringText(MekanismUtils.getEnergyDisplay(tileEntity.getEnergy()), xAxis, yAxis);
|
2013-05-19 18:43:01 -04:00
|
|
|
}
|
2013-11-26 20:11:26 -05:00
|
|
|
|
|
|
|
super.drawGuiContainerForegroundLayer(mouseX, mouseY);
|
2012-12-20 16:53:39 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2013-08-26 18:28:55 -04:00
|
|
|
protected void drawGuiContainerBackgroundLayer(float partialTick, int mouseX, int mouseY)
|
2012-12-20 16:53:39 -05:00
|
|
|
{
|
2013-08-26 18:28:55 -04:00
|
|
|
super.drawGuiContainerBackgroundLayer(partialTick, mouseX, mouseY);
|
|
|
|
|
2013-09-28 02:59:47 +01:00
|
|
|
mc.renderEngine.bindTexture(MekanismUtils.getResource(ResourceType.GUI, "GuiMetallurgicInfuser.png"));
|
2012-12-20 16:53:39 -05:00
|
|
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
2013-08-02 03:16:38 -04:00
|
|
|
int guiWidth = (width - xSize) / 2;
|
|
|
|
int guiHeight = (height - ySize) / 2;
|
2012-12-20 16:53:39 -05:00
|
|
|
drawTexturedModalRect(guiWidth, guiHeight, 0, 0, xSize, ySize);
|
|
|
|
|
2013-08-26 18:28:55 -04:00
|
|
|
int xAxis = mouseX - guiWidth;
|
|
|
|
int yAxis = mouseY - guiHeight;
|
2013-08-02 03:16:38 -04:00
|
|
|
|
2012-12-20 16:53:39 -05:00
|
|
|
int displayInt;
|
|
|
|
|
|
|
|
displayInt = tileEntity.getScaledProgress(32);
|
2013-08-25 20:54:34 -04:00
|
|
|
drawTexturedModalRect(guiWidth + 72, guiHeight + 47, 176, 52, displayInt + 1, 8);
|
2012-12-20 16:53:39 -05:00
|
|
|
|
|
|
|
displayInt = tileEntity.getScaledEnergyLevel(52);
|
2013-08-25 20:54:34 -04:00
|
|
|
drawTexturedModalRect(guiWidth + 165, guiHeight + 17 + 52 - displayInt, 176, 52 - displayInt, 4, displayInt);
|
2013-06-01 21:33:19 -04:00
|
|
|
|
|
|
|
if(tileEntity.type != null)
|
|
|
|
{
|
|
|
|
displayInt = tileEntity.getScaledInfuseLevel(52);
|
2013-09-28 02:59:47 +01:00
|
|
|
mc.renderEngine.bindTexture(tileEntity.type.texture);
|
2013-06-01 21:33:19 -04:00
|
|
|
drawTexturedModalRect(guiWidth + 7, guiHeight + 17 + 52 - displayInt, tileEntity.type.texX, tileEntity.type.texY + 52 - displayInt, 4, displayInt);
|
|
|
|
}
|
2013-08-02 03:16:38 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void mouseClicked(int x, int y, int button)
|
|
|
|
{
|
|
|
|
super.mouseClicked(x, y, button);
|
|
|
|
|
|
|
|
if(button == 0)
|
|
|
|
{
|
|
|
|
int xAxis = (x - (width - xSize) / 2);
|
|
|
|
int yAxis = (y - (height - ySize) / 2);
|
|
|
|
|
|
|
|
if(xAxis > 148 && xAxis < 168 && yAxis > 73 && yAxis < 82)
|
|
|
|
{
|
|
|
|
ArrayList data = new ArrayList();
|
|
|
|
data.add(0);
|
|
|
|
|
|
|
|
PacketHandler.sendPacket(Transmission.SERVER, new PacketTileEntity().setParams(Object3D.get(tileEntity), data));
|
|
|
|
mc.sndManager.playSoundFX("random.click", 1.0F, 1.0F);
|
|
|
|
}
|
|
|
|
}
|
2012-12-20 16:53:39 -05:00
|
|
|
}
|
|
|
|
}
|