GT5-Unofficial/src/main/java/gregtech/api/gui/GT_GUIContainer_BasicMachine.java

109 lines
4.9 KiB
Java
Raw Normal View History

2015-04-23 16:14:22 +00:00
package gregtech.api.gui;
2015-10-22 02:15:09 +00:00
import gregtech.api.interfaces.tileentity.IGregTechTileEntity;
import net.minecraft.entity.player.InventoryPlayer;
2015-08-15 23:10:06 +00:00
import java.util.ArrayList;
import java.util.List;
2015-10-22 02:15:09 +00:00
import static gregtech.api.enums.GT_Values.RES_PATH_GUI;
2015-04-23 16:14:22 +00:00
/**
* NEVER INCLUDE THIS FILE IN YOUR MOD!!!
2015-10-22 02:15:09 +00:00
* <p/>
2015-04-23 16:14:22 +00:00
* The GUI-Container I use for all my Basic Machines
2015-10-22 02:15:09 +00:00
* <p/>
2015-04-23 16:14:22 +00:00
* As the NEI-RecipeTransferRect Handler can't handle one GUI-Class for all GUIs I needed to produce some dummy-classes which extend this class
*/
public class GT_GUIContainer_BasicMachine extends GT_GUIContainerMetaTile_Machine {
2015-10-22 02:15:09 +00:00
public final String mName, mNEI;
public final byte mProgressBarDirection, mProgressBarAmount;
2015-04-23 16:14:22 +00:00
public GT_GUIContainer_BasicMachine(InventoryPlayer aInventoryPlayer, IGregTechTileEntity aTileEntity, String aName, String aTextureFile, String aNEI) {
2015-10-22 02:15:09 +00:00
this(aInventoryPlayer, aTileEntity, aName, aTextureFile, aNEI, (byte) 0, (byte) 1);
2015-04-23 16:14:22 +00:00
}
2015-10-22 02:15:09 +00:00
2015-04-23 16:14:22 +00:00
public GT_GUIContainer_BasicMachine(InventoryPlayer aInventoryPlayer, IGregTechTileEntity aTileEntity, String aName, String aTextureFile, String aNEI, byte aProgressBarDirection, byte aProgressBarAmount) {
super(new GT_Container_BasicMachine(aInventoryPlayer, aTileEntity), RES_PATH_GUI + "basicmachines/" + aTextureFile);
mProgressBarDirection = aProgressBarDirection;
2015-10-22 02:15:09 +00:00
mProgressBarAmount = (byte) Math.max(1, aProgressBarAmount);
2015-04-23 16:14:22 +00:00
mName = aName;
mNEI = aNEI;
}
2015-10-22 02:15:09 +00:00
2015-04-23 16:14:22 +00:00
@Override
protected void drawGuiContainerForegroundLayer(int par1, int par2) {
2015-10-22 02:15:09 +00:00
fontRendererObj.drawString(mName, 8, 4, 4210752);
2015-08-15 23:10:06 +00:00
drawTooltip(par1, par2);
}
2015-10-22 02:15:09 +00:00
private void drawTooltip(int x2, int y2) {
int xStart = (width - xSize) / 2;
int yStart = (height - ySize) / 2;
int x = x2 - xStart;
int y = y2 - yStart + 5;
List<String> list = new ArrayList<String>();
if (y >= 67 && y <= 84) {
if (x >= 7 && x <= 24) {
list.add("Fluid Auto-Output");
}
if (x >= 25 && x <= 42) {
list.add("Item Auto-Output");
}
}
if (!list.isEmpty())
drawHoveringText(list, x, y, fontRendererObj);
2015-04-23 16:14:22 +00:00
}
2015-10-22 02:15:09 +00:00
2015-04-23 16:14:22 +00:00
@Override
protected void drawGuiContainerBackgroundLayer(float par1, int par2, int par3) {
2015-10-22 02:15:09 +00:00
super.drawGuiContainerBackgroundLayer(par1, par2, par3);
2015-04-23 16:14:22 +00:00
int x = (width - xSize) / 2;
int y = (height - ySize) / 2;
drawTexturedModalRect(x, y, 0, 0, xSize, ySize);
if (mContainer != null) {
2015-10-22 02:15:09 +00:00
if (((GT_Container_BasicMachine) mContainer).mFluidTransfer)
drawTexturedModalRect(x + 7, y + 62, 176, 18, 18, 18);
if (((GT_Container_BasicMachine) mContainer).mItemTransfer)
drawTexturedModalRect(x + 25, y + 62, 176, 36, 18, 18);
if (((GT_Container_BasicMachine) mContainer).mStuttering)
drawTexturedModalRect(x + 79, y + 44, 176, 54, 18, 18);
if (mContainer.mMaxProgressTime > 0) {
int tSize = (mProgressBarDirection < 2 ? 20 : 18), tProgress = Math.max(1, Math.min(tSize * mProgressBarAmount, (mContainer.mProgressTime > 0 ? 1 : 0) + (mContainer.mProgressTime * tSize * mProgressBarAmount) / mContainer.mMaxProgressTime)) % (tSize + 1);
switch (mProgressBarDirection) { // yes, my OCD was mad at me before I did the Tabs.
case 0:
drawTexturedModalRect(x + 78, y + 24, 176, 0, tProgress, 18);
break;
case 1:
drawTexturedModalRect(x + 78 + 20 - tProgress, y + 24, 176 + 20 - tProgress, 0, tProgress, 18);
break;
case 2:
drawTexturedModalRect(x + 78, y + 24, 176, 0, 20, tProgress);
break;
case 3:
drawTexturedModalRect(x + 78, y + 24 + 18 - tProgress, 176, 18 - tProgress, 20, tProgress);
break;
case 4:
tProgress = 20 - tProgress;
drawTexturedModalRect(x + 78, y + 24, 176, 0, tProgress, 18);
break;
case 5:
tProgress = 20 - tProgress;
drawTexturedModalRect(x + 78 + 20 - tProgress, y + 24, 176 + 20 - tProgress, 0, tProgress, 18);
break;
case 6:
tProgress = 18 - tProgress;
drawTexturedModalRect(x + 78, y + 24, 176, 0, 20, tProgress);
break;
case 7:
tProgress = 18 - tProgress;
drawTexturedModalRect(x + 78, y + 24 + 18 - tProgress, 176, 18 - tProgress, 20, tProgress);
break;
}
}
2015-04-23 16:14:22 +00:00
}
}
}