2014-01-20 10:41:37 -06:00
|
|
|
package appeng.client.gui.implementations;
|
|
|
|
|
|
|
|
import java.io.IOException;
|
|
|
|
|
|
|
|
import net.minecraft.client.gui.GuiButton;
|
|
|
|
import net.minecraft.entity.player.InventoryPlayer;
|
|
|
|
import net.minecraft.inventory.IInventory;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
|
|
|
|
import org.lwjgl.input.Mouse;
|
|
|
|
|
|
|
|
import appeng.api.config.ActionItems;
|
2014-04-06 18:05:09 -05:00
|
|
|
import appeng.api.config.CopyMode;
|
2014-01-20 10:41:37 -06:00
|
|
|
import appeng.api.config.FuzzyMode;
|
|
|
|
import appeng.api.config.Settings;
|
|
|
|
import appeng.api.config.Upgrades;
|
2014-01-23 13:02:48 -06:00
|
|
|
import appeng.api.implementations.items.IUpgradeModule;
|
2014-01-20 10:41:37 -06:00
|
|
|
import appeng.client.gui.widgets.GuiImgButton;
|
2014-04-06 18:05:09 -05:00
|
|
|
import appeng.client.gui.widgets.GuiToggleButton;
|
2014-01-20 10:41:37 -06:00
|
|
|
import appeng.container.implementations.ContainerCellWorkbench;
|
|
|
|
import appeng.core.localization.GuiText;
|
2014-02-08 19:34:52 -06:00
|
|
|
import appeng.core.sync.network.NetworkHandler;
|
2014-01-20 10:41:37 -06:00
|
|
|
import appeng.core.sync.packets.PacketValueConfig;
|
|
|
|
import appeng.tile.misc.TileCellWorkbench;
|
|
|
|
import appeng.util.Platform;
|
|
|
|
|
|
|
|
public class GuiCellWorkbench extends GuiUpgradeable
|
|
|
|
{
|
|
|
|
|
|
|
|
ContainerCellWorkbench ccwb;
|
|
|
|
TileCellWorkbench tcw;
|
|
|
|
|
|
|
|
GuiImgButton clear;
|
|
|
|
GuiImgButton partition;
|
2014-04-06 18:05:09 -05:00
|
|
|
GuiToggleButton copyMode;
|
2014-01-20 10:41:37 -06:00
|
|
|
|
|
|
|
public GuiCellWorkbench(InventoryPlayer inventoryPlayer, TileCellWorkbench te) {
|
|
|
|
super( new ContainerCellWorkbench( inventoryPlayer, te ) );
|
|
|
|
ccwb = (ContainerCellWorkbench) inventorySlots;
|
|
|
|
ySize = 251;
|
|
|
|
tcw = te;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected boolean drawUpgrades()
|
|
|
|
{
|
|
|
|
return ccwb.availableUpgrades() > 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void initGui()
|
|
|
|
{
|
|
|
|
super.initGui();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void drawBG(int offsetX, int offsetY, int mouseX, int mouseY)
|
|
|
|
{
|
|
|
|
handleButtonVisiblity();
|
|
|
|
|
|
|
|
bindTexture( getBackground() );
|
|
|
|
this.drawTexturedModalRect( offsetX, offsetY, 0, 0, 211 - 34, ySize );
|
|
|
|
if ( drawUpgrades() )
|
|
|
|
{
|
|
|
|
if ( ccwb.availableUpgrades() <= 8 )
|
|
|
|
{
|
|
|
|
this.drawTexturedModalRect( offsetX + 177, offsetY, 177, 0, 35, 7 + ccwb.availableUpgrades() * 18 );
|
|
|
|
this.drawTexturedModalRect( offsetX + 177, offsetY + (7 + (ccwb.availableUpgrades()) * 18), 177, 151, 35, 7 );
|
|
|
|
}
|
|
|
|
else if ( ccwb.availableUpgrades() <= 16 )
|
|
|
|
{
|
|
|
|
this.drawTexturedModalRect( offsetX + 177, offsetY, 177, 0, 35, 7 + 8 * 18 );
|
|
|
|
this.drawTexturedModalRect( offsetX + 177, offsetY + (7 + (8) * 18), 177, 151, 35, 7 );
|
|
|
|
|
|
|
|
int dx = ccwb.availableUpgrades() - 8;
|
|
|
|
this.drawTexturedModalRect( offsetX + 177 + 27, offsetY, 186, 0, 35 - 8, 7 + dx * 18 );
|
|
|
|
if ( dx == 8 )
|
|
|
|
this.drawTexturedModalRect( offsetX + 177 + 27, offsetY + (7 + (dx) * 18), 186, 151, 35 - 8, 7 );
|
|
|
|
else
|
|
|
|
this.drawTexturedModalRect( offsetX + 177 + 27 + 4, offsetY + (7 + (dx) * 18), 186 + 4, 151, 35 - 8, 7 );
|
|
|
|
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.drawTexturedModalRect( offsetX + 177, offsetY, 177, 0, 35, 7 + 8 * 18 );
|
|
|
|
this.drawTexturedModalRect( offsetX + 177, offsetY + (7 + (8) * 18), 177, 151, 35, 7 );
|
|
|
|
|
|
|
|
this.drawTexturedModalRect( offsetX + 177 + 27, offsetY, 186, 0, 35 - 8, 7 + 8 * 18 );
|
|
|
|
this.drawTexturedModalRect( offsetX + 177 + 27, offsetY + (7 + (8) * 18), 186, 151, 35 - 8, 7 );
|
|
|
|
|
|
|
|
int dx = ccwb.availableUpgrades() - 16;
|
|
|
|
this.drawTexturedModalRect( offsetX + 177 + 27 + 18, offsetY, 186, 0, 35 - 8, 7 + dx * 18 );
|
|
|
|
if ( dx == 8 )
|
|
|
|
this.drawTexturedModalRect( offsetX + 177 + 27 + 18, offsetY + (7 + (dx) * 18), 186, 151, 35 - 8, 7 );
|
|
|
|
else
|
|
|
|
this.drawTexturedModalRect( offsetX + 177 + 27 + 18 + 4, offsetY + (7 + (dx) * 18), 186 + 4, 151, 35 - 8, 7 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ( hasToolbox() )
|
|
|
|
this.drawTexturedModalRect( offsetX + 178, offsetY + ySize - 90, 178, 161, 68, 68 );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void actionPerformed(GuiButton btn)
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
2014-04-06 18:05:09 -05:00
|
|
|
if ( btn == copyMode )
|
|
|
|
{
|
|
|
|
NetworkHandler.instance.sendToServer( new PacketValueConfig( "CellWorkbench.Action", "CopyMode" ) );
|
|
|
|
}
|
|
|
|
else if ( btn == partition )
|
2014-01-20 10:41:37 -06:00
|
|
|
{
|
2014-02-08 19:34:52 -06:00
|
|
|
NetworkHandler.instance.sendToServer( new PacketValueConfig( "CellWorkbench.Action", "Partition" ) );
|
2014-01-20 10:41:37 -06:00
|
|
|
}
|
|
|
|
else if ( btn == clear )
|
|
|
|
{
|
2014-02-08 19:34:52 -06:00
|
|
|
NetworkHandler.instance.sendToServer( new PacketValueConfig( "CellWorkbench.Action", "Clear" ) );
|
2014-01-20 10:41:37 -06:00
|
|
|
}
|
|
|
|
else if ( btn == fuzzyMode )
|
|
|
|
{
|
|
|
|
boolean backwards = Mouse.isButtonDown( 1 );
|
|
|
|
|
|
|
|
FuzzyMode fz = (FuzzyMode) fuzzyMode.getCurrentValue();
|
|
|
|
fz = Platform.rotateEnum( fz, backwards, Settings.FUZZY_MODE.getPossibleValues() );
|
|
|
|
|
2014-02-08 19:34:52 -06:00
|
|
|
NetworkHandler.instance.sendToServer( new PacketValueConfig( "CellWorkbench.Fuzzy", fz.name() ) );
|
2014-01-20 10:41:37 -06:00
|
|
|
}
|
|
|
|
else
|
|
|
|
super.actionPerformed( btn );
|
|
|
|
}
|
|
|
|
catch (IOException err)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
protected void addButtons()
|
|
|
|
{
|
|
|
|
clear = new GuiImgButton( this.guiLeft - 18, guiTop + 8, Settings.ACTIONS, ActionItems.CLOSE );
|
|
|
|
partition = new GuiImgButton( this.guiLeft - 18, guiTop + 28, Settings.ACTIONS, ActionItems.WRENCH );
|
2014-04-06 18:05:09 -05:00
|
|
|
copyMode = new GuiToggleButton( this.guiLeft - 18, guiTop + 48, 11 * 16 + 5, 12 * 16 + 5, GuiText.CopyMode.getLocal(), GuiText.CopyModeDesc.getLocal() );
|
|
|
|
fuzzyMode = new GuiImgButton( this.guiLeft - 18, guiTop + 68, Settings.FUZZY_MODE, FuzzyMode.IGNORE_ALL );
|
2014-01-20 10:41:37 -06:00
|
|
|
|
|
|
|
buttonList.add( fuzzyMode );
|
|
|
|
buttonList.add( partition );
|
|
|
|
buttonList.add( clear );
|
2014-04-06 18:05:09 -05:00
|
|
|
buttonList.add( copyMode );
|
2014-01-20 10:41:37 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
protected void handleButtonVisiblity()
|
|
|
|
{
|
2014-04-06 18:05:09 -05:00
|
|
|
copyMode.setState( ccwb.copyMode == CopyMode.CLEAR_ON_REMOVE );
|
|
|
|
|
2014-01-20 10:41:37 -06:00
|
|
|
boolean hasFuzzy = false;
|
|
|
|
IInventory inv = ccwb.getCellUpgradeInventory();
|
|
|
|
for (int x = 0; x < inv.getSizeInventory(); x++)
|
|
|
|
{
|
|
|
|
ItemStack is = inv.getStackInSlot( x );
|
|
|
|
if ( is != null && is.getItem() instanceof IUpgradeModule )
|
|
|
|
{
|
|
|
|
if ( ((IUpgradeModule) is.getItem()).getType( is ) == Upgrades.FUZZY )
|
|
|
|
hasFuzzy = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fuzzyMode.setVisibility( hasFuzzy );
|
|
|
|
}
|
|
|
|
|
|
|
|
protected String getBackground()
|
|
|
|
{
|
|
|
|
return "guis/cellworkbench.png";
|
|
|
|
}
|
|
|
|
|
|
|
|
protected GuiText getName()
|
|
|
|
{
|
|
|
|
return GuiText.CellWorkbench;
|
|
|
|
}
|
|
|
|
}
|