1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
|
package gtPlusPlus.core.handler;
import cpw.mods.fml.common.network.IGuiHandler;
import cpw.mods.fml.common.network.NetworkRegistry;
import gtPlusPlus.GTplusplus;
import gtPlusPlus.core.container.*;
import gtPlusPlus.core.gui.beta.Gui_ID_Registry;
import gtPlusPlus.core.gui.beta.MU_GuiId;
import gtPlusPlus.core.gui.item.GuiBaseBackpack;
import gtPlusPlus.core.gui.machine.*;
import gtPlusPlus.core.interfaces.IGuiManager;
import gtPlusPlus.core.inventories.BaseInventoryBackpack;
import gtPlusPlus.core.tileentities.base.TileEntityBase;
import gtPlusPlus.core.tileentities.general.TileEntityFishTrap;
import gtPlusPlus.core.tileentities.machines.TileEntityModularityTable;
import gtPlusPlus.core.tileentities.machines.TileEntityProjectTable;
import gtPlusPlus.core.tileentities.machines.TileEntityTradeTable;
import gtPlusPlus.core.tileentities.machines.TileEntityWorkbench;
import gtPlusPlus.core.tileentities.machines.TileEntityWorkbenchAdvanced;
import gtPlusPlus.core.util.Utils;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.ChunkCoordinates;
import net.minecraft.world.World;
public class GuiHandler implements IGuiHandler {
public static final int GUI1 = 0; //Project Table
public static final int GUI2 = 1; //Helium Generator
public static final int GUI3 = 2; //BackpackHandler
public static final int GUI4 = 3; //Workbench
public static final int GUI5 = 4; //Workbench Adv
public static final int GUI6 = 5; //Fish trap
public static final int GUI7 = 6; //Trade table
public static final int GUI8 = 7; //
public static void init(){
Utils.LOG_INFO("Registering GUIs.");
NetworkRegistry.INSTANCE.registerGuiHandler(GTplusplus.instance, new GuiHandler());
//Register GuiHandler
//NetworkRegistry.INSTANCE.registerGuiHandler(GTplusplus.instance, new GuiHandler());
}
@Override //ContainerModTileEntity
public Object getServerGuiElement(final int ID, final EntityPlayer player, final World world, final int x, final int y, final int z) {
final TileEntity te = world.getTileEntity(x, y, z);
if (te != null){
if (ID == GUI1){
return new Container_ProjectTable(player.inventory, (TileEntityProjectTable)te);
}
else if (ID == GUI2){
return new Container_ModularityTable(player.inventory, (TileEntityModularityTable) te);
}
}
if (ID == GUI3)
{
// Use the player's held item to create the inventory
return new Container_BackpackBase(player, player.inventory, new BaseInventoryBackpack(player.getHeldItem()));
}
if (te != null){
if (ID == GUI4){
return new Container_Workbench(player.inventory, (TileEntityWorkbench)te);
}
else if (ID == GUI5){
Utils.LOG_INFO("sad");
return new Container_WorkbenchAdvanced(player.inventory, (TileEntityWorkbenchAdvanced)te);
}
else if (ID == GUI6){
return new Container_FishTrap(player.inventory, (TileEntityFishTrap)te);
}
else if (ID == GUI7){
return new Container_TradeTable(player.inventory, (TileEntityTradeTable)te);
}
}
return null;
}
@Override //GuiModTileEntity
public Object getClientGuiElement(final int ID, final EntityPlayer player, final World world, final int x, final int y, final int z) {
Utils.LOG_WARNING("getClientGuiElement Called by: "+player+", in world: "+player.dimension+" at x:"+x+", y:"+y+", z:"+z+".");
final TileEntity te = world.getTileEntity(x, y, z);
if (te != null){
if (ID == GUI1){
return new GUI_ProjectTable(player.inventory, (TileEntityProjectTable)te);
}
else if (ID == GUI2){
return new GUI_ModularityTable(player.inventory, (TileEntityModularityTable) te);
}
}
if (ID == GUI3)
{
// We have to cast the new container as our custom class
// and pass in currently held item for the inventory
return new GuiBaseBackpack(new Container_BackpackBase(player, player.inventory, new BaseInventoryBackpack(player.getHeldItem())));
}
if (te != null){
if (ID == GUI4){
return new GUI_Workbench(player.inventory, (TileEntityWorkbench)te);
}
else if (ID == GUI5){
Utils.LOG_INFO("sad");
return new GUI_WorkbenchAdvanced(player.inventory, (TileEntityWorkbenchAdvanced)te);
}
else if (ID == GUI6){
return new GUI_FishTrap(player.inventory, (TileEntityFishTrap)te);
}
else if (ID == GUI7){
return new GUI_TradeTable(player.inventory, (TileEntityTradeTable)te, ((TileEntityBase) te).getOwner());
}
}
return null;
}
//New Methods
public static void openGui(final EntityPlayer entityplayer, final IGuiManager guiHandler)
{
openGui(entityplayer, guiHandler, (short)0);
}
public static void openGui(final EntityPlayer entityplayer, final IGuiManager guiHandler, final short data)
{
final int guiData = encodeGuiData(guiHandler, data);
final ChunkCoordinates coordinates = guiHandler.getCoordinates();
entityplayer.openGui(GTplusplus.instance, guiData, entityplayer.worldObj, coordinates.posX, coordinates.posY, coordinates.posZ);
}
private static int encodeGuiData(final IGuiManager guiHandler, final short data)
{
final MU_GuiId guiId = Gui_ID_Registry.getGuiIdForGuiHandler(guiHandler);
return (data << 16) | guiId.getId();
}
private static MU_GuiId decodeGuiID(final int guiData)
{
final int guiId = guiData & 0xFF;
return Gui_ID_Registry.getGuiId(guiId);
}
private static short decodeGuiData(final int guiId)
{
return (short)(guiId >> 16);
}
}
|