aboutsummaryrefslogtreecommitdiff
path: root/src/Java/miscutil/core/handler
diff options
context:
space:
mode:
authorDraknyte1 <Draknyte1@hotmail.com>2016-07-04 15:21:58 +1000
committerDraknyte1 <Draknyte1@hotmail.com>2016-07-04 15:21:58 +1000
commitb1c319fa2d6fbf34d0db684f4fc3d7dc51b43a54 (patch)
treeb1061e2d9c569424d508ffcd26d33c13a565fa9a /src/Java/miscutil/core/handler
parent7b5dbdc81b2f8f393dafc3268efe5eb5cd084c39 (diff)
downloadGT5-Unofficial-b1c319fa2d6fbf34d0db684f4fc3d7dc51b43a54.tar.gz
GT5-Unofficial-b1c319fa2d6fbf34d0db684f4fc3d7dc51b43a54.tar.bz2
GT5-Unofficial-b1c319fa2d6fbf34d0db684f4fc3d7dc51b43a54.zip
+ Added in base and Abstract classes to begin usage of RainsinToastCore.
+ Started work on a new GUI handler based off others, featuring dynamic ID ranges. (Internal code changes) - Removed a very old GUI handler class, left the current one until the new one is done.
Diffstat (limited to 'src/Java/miscutil/core/handler')
-rw-r--r--src/Java/miscutil/core/handler/GuiHandler.java55
1 files changed, 45 insertions, 10 deletions
diff --git a/src/Java/miscutil/core/handler/GuiHandler.java b/src/Java/miscutil/core/handler/GuiHandler.java
index d604f1b147..92cb2a2812 100644
--- a/src/Java/miscutil/core/handler/GuiHandler.java
+++ b/src/Java/miscutil/core/handler/GuiHandler.java
@@ -1,14 +1,19 @@
package miscutil.core.handler;
+import miscutil.MiscUtils;
import miscutil.core.container.Container_Charger;
import miscutil.core.container.Container_NHG;
+import miscutil.core.gui.beta.Gui_ID_Registry;
+import miscutil.core.gui.beta.MU_GuiId;
import miscutil.core.gui.machine.GUI_Charger;
import miscutil.core.gui.machine.GUI_NHG;
+import miscutil.core.interfaces.IGuiManager;
import miscutil.core.tileentities.machines.TileEntityCharger;
import miscutil.core.tileentities.machines.TileEntityNHG;
import miscutil.core.util.Utils;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.tileentity.TileEntity;
+import net.minecraft.util.ChunkCoordinates;
import net.minecraft.world.World;
import cpw.mods.fml.common.network.IGuiHandler;
@@ -17,8 +22,6 @@ public class GuiHandler implements IGuiHandler {
private static final int GUI1 = 0; //Nuclear Helium Gen.
private static final int GUI2 = 1; //Energy Charger
-
-
@Override //ContainerModTileEntity
public Object getServerGuiElement(int ID, EntityPlayer player, World world, int x, int y, int z) {
TileEntity te = world.getTileEntity(x, y, z);
@@ -42,16 +45,48 @@ public class GuiHandler implements IGuiHandler {
Utils.LOG_WARNING("getClientGuiElement Called by: "+player+", in world: "+player.dimension+" at x:"+x+", y:"+y+", z:"+z+".");
TileEntity te = world.getTileEntity(x, y, z);
if (te != null){
- if (ID == GUI1){
- Utils.LOG_WARNING("Opening Gui with Id: "+ID+" NHG");
- return new GUI_NHG((TileEntityNHG) te, player);
- }
- else if (ID == GUI2){
- Utils.LOG_WARNING("Opening Gui with Id: "+ID+" Charger");
- return new GUI_Charger((TileEntityCharger) te, player);
- }
+ if (ID == GUI1){
+ Utils.LOG_WARNING("Opening Gui with Id: "+ID+" NHG");
+ return new GUI_NHG((TileEntityNHG) te, player);
+ }
+ else if (ID == GUI2){
+ Utils.LOG_WARNING("Opening Gui with Id: "+ID+" Charger");
+ return new GUI_Charger((TileEntityCharger) te, player);
+ }
}
return null;
}
+
+
+
+ //New Methods
+ public static void openGui(EntityPlayer entityplayer, IGuiManager guiHandler)
+ {
+ openGui(entityplayer, guiHandler, (short)0);
+ }
+
+ public static void openGui(EntityPlayer entityplayer, IGuiManager guiHandler, short data)
+ {
+ int guiData = encodeGuiData(guiHandler, data);
+ ChunkCoordinates coordinates = guiHandler.getCoordinates();
+ entityplayer.openGui(MiscUtils.instance, guiData, entityplayer.worldObj, coordinates.posX, coordinates.posY, coordinates.posZ);
+ }
+
+ private static int encodeGuiData(IGuiManager guiHandler, short data)
+ {
+ MU_GuiId guiId = Gui_ID_Registry.getGuiIdForGuiHandler(guiHandler);
+ return data << 16 | guiId.getId();
+ }
+
+ private static MU_GuiId decodeGuiID(int guiData)
+ {
+ int guiId = guiData & 0xFF;
+ return Gui_ID_Registry.getGuiId(guiId);
+ }
+
+ private static short decodeGuiData(int guiId)
+ {
+ return (short)(guiId >> 16);
+ }
} \ No newline at end of file