From 8f5d3cb93690fa15cae0999eb17994213d920288 Mon Sep 17 00:00:00 2001 From: Alkalus Date: Tue, 11 Jul 2017 10:09:00 +1000 Subject: $ Fixed Industrial Sieve Tooltip. $ Implemented Texture Array Expansion. > This fixes the issue of hatches not using the correct textures. --- src/Java/gregtech/api/enums/TAE.java | 54 ++++++++++++++++++++++++++++++++++++ 1 file changed, 54 insertions(+) create mode 100644 src/Java/gregtech/api/enums/TAE.java (limited to 'src/Java/gregtech/api/enums/TAE.java') diff --git a/src/Java/gregtech/api/enums/TAE.java b/src/Java/gregtech/api/enums/TAE.java new file mode 100644 index 0000000000..40811a141c --- /dev/null +++ b/src/Java/gregtech/api/enums/TAE.java @@ -0,0 +1,54 @@ +package gregtech.api.enums; + +import gregtech.api.interfaces.ITexture; +import gregtech.api.objects.GT_CopiedBlockTexture; +import gregtech.api.objects.GT_RenderedTexture; + +public class TAE { + + //TAE stands for Texture Array Expansion. + + public static int gtTexturesArrayStartOrigin; + public static int gtPPLastUsedIndex = 512; + public static boolean hasArrayBeenExpanded = false; + + public static boolean hookGtTextures() { + ITexture[] textureArrayDump = Textures.BlockIcons.CASING_BLOCKS; + GT_RenderedTexture[] newTextureArray = new GT_RenderedTexture[1024]; + gtTexturesArrayStartOrigin = textureArrayDump.length; + System.arraycopy(textureArrayDump, 0, newTextureArray, 0, textureArrayDump.length); + Textures.BlockIcons.CASING_BLOCKS = newTextureArray; + if (Textures.BlockIcons.CASING_BLOCKS.length == 1024){ + hasArrayBeenExpanded = true; + } + else { + hasArrayBeenExpanded = false; + } + return hasArrayBeenExpanded; + } + + public static boolean registerTextures(GT_RenderedTexture textureToRegister) { + Textures.BlockIcons.CASING_BLOCKS[gtPPLastUsedIndex++] = textureToRegister; + //Just so I know registration is done. + return true; + } + + public static boolean registerTextures(GT_CopiedBlockTexture gt_CopiedBlockTexture) { + Textures.BlockIcons.CASING_BLOCKS[gtPPLastUsedIndex++] = gt_CopiedBlockTexture; + //Just so I know registration is done. + return true; + } + + public static ITexture getTexture(int index){ + if (!hasArrayBeenExpanded){ + return null; + } + else { + return Textures.BlockIcons.CASING_BLOCKS[(512+index)]; + } + } + + public static int GTPP_INDEX(int ID){ + return (512+ID); + } +} -- cgit