aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/io/github/moulberry/notenoughupdates/BetterContainers.java
diff options
context:
space:
mode:
authorBuildTools <james.jenour@protonmail.com>2021-01-07 12:57:35 +0800
committerBuildTools <james.jenour@protonmail.com>2021-01-07 12:57:35 +0800
commitcfa0aa0c9a24aa739d3254b24ef4bf0bea7087a6 (patch)
tree37195b6df62d8281e236e0fb87e5d9edbd60f625 /src/main/java/io/github/moulberry/notenoughupdates/BetterContainers.java
parent9ae63509ab33c4d3f0ee19bc618ef4e4c654ef46 (diff)
downloadnotenoughupdates-cfa0aa0c9a24aa739d3254b24ef4bf0bea7087a6.tar.gz
notenoughupdates-cfa0aa0c9a24aa739d3254b24ef4bf0bea7087a6.tar.bz2
notenoughupdates-cfa0aa0c9a24aa739d3254b24ef4bf0bea7087a6.zip
PRE4
Diffstat (limited to 'src/main/java/io/github/moulberry/notenoughupdates/BetterContainers.java')
-rw-r--r--src/main/java/io/github/moulberry/notenoughupdates/BetterContainers.java458
1 files changed, 0 insertions, 458 deletions
diff --git a/src/main/java/io/github/moulberry/notenoughupdates/BetterContainers.java b/src/main/java/io/github/moulberry/notenoughupdates/BetterContainers.java
deleted file mode 100644
index 02ff2164..00000000
--- a/src/main/java/io/github/moulberry/notenoughupdates/BetterContainers.java
+++ /dev/null
@@ -1,458 +0,0 @@
-package io.github.moulberry.notenoughupdates;
-
-import com.google.gson.JsonObject;
-import io.github.moulberry.notenoughupdates.util.TexLoc;
-import io.github.moulberry.notenoughupdates.util.Utils;
-import net.minecraft.client.Minecraft;
-import net.minecraft.client.gui.ScaledResolution;
-import net.minecraft.client.gui.inventory.GuiChest;
-import net.minecraft.client.renderer.GlStateManager;
-import net.minecraft.client.renderer.texture.DynamicTexture;
-import net.minecraft.client.renderer.texture.TextureManager;
-import net.minecraft.init.Blocks;
-import net.minecraft.inventory.Container;
-import net.minecraft.inventory.ContainerChest;
-import net.minecraft.inventory.IInventory;
-import net.minecraft.item.Item;
-import net.minecraft.item.ItemStack;
-import net.minecraft.nbt.NBTTagList;
-import net.minecraft.util.EnumChatFormatting;
-import net.minecraft.util.ResourceLocation;
-import org.lwjgl.input.Keyboard;
-import org.lwjgl.opengl.GL11;
-import org.lwjgl.opengl.GL14;
-
-import javax.imageio.ImageIO;
-import java.awt.*;
-import java.awt.image.BufferedImage;
-import java.io.*;
-import java.nio.charset.StandardCharsets;
-import java.util.HashMap;
-import java.util.Random;
-
-public class BetterContainers {
-
- private static final ResourceLocation TOGGLE_OFF = new ResourceLocation("notenoughupdates:dynamic_54/toggle_off.png");
- private static final ResourceLocation TOGGLE_ON = new ResourceLocation("notenoughupdates:dynamic_54/toggle_on.png");
-
- private static final ResourceLocation DYNAMIC_54_BASE = new ResourceLocation("notenoughupdates:dynamic_54/style1/dynamic_54.png");
- private static final ResourceLocation DYNAMIC_54_SLOT = new ResourceLocation("notenoughupdates:dynamic_54/style1/dynamic_54_slot_ctm.png");
- private static final ResourceLocation DYNAMIC_54_BUTTON = new ResourceLocation("notenoughupdates:dynamic_54/style1/dynamic_54_button_ctm.png");
- private static final ResourceLocation rl = new ResourceLocation("notenoughupdates:dynamic_chest_inventory.png");
- private static boolean loaded = false;
- private static DynamicTexture texture = null;
- private static int textColour = 4210752;
-
- private static int lastClickedSlot = 0;
- private static int clickedSlot = 0;
- private static long clickedSlotMillis = 0;
- public static long lastRenderMillis = 0;
-
- public static HashMap<Integer, ItemStack> itemCache = new HashMap<>();
- public static boolean lastUsingCached = false;
- public static boolean usingCached = false;
-
- public static void clickSlot(int slot) {
- clickedSlotMillis = System.currentTimeMillis();
- clickedSlot = slot;
- }
-
- public static int getClickedSlot() {
- if(System.currentTimeMillis() - clickedSlotMillis < 500) {
- return clickedSlot;
- }
- return -1;
- }
-
- public static void bindHook(TextureManager textureManager, ResourceLocation location) {
- if(isChestOpen()) {
- Container container = ((GuiChest)Minecraft.getMinecraft().currentScreen).inventorySlots;
- if(container instanceof ContainerChest) {
- usingCached = true;
- IInventory lower = ((ContainerChest)container).getLowerChestInventory();
- int size = lower.getSizeInventory();
- for(int index=0; index<size; index++) {
- if(lower.getStackInSlot(index) != null) {
- for(int index2=0; index2<size; index2++) {
- itemCache.put(index2, lower.getStackInSlot(index2));
- }
- usingCached = false;
- break;
- }
- }
- }
-
- if((texture != null && loaded && lastClickedSlot != getClickedSlot()) ||
- lastUsingCached != getUsingCache() ||
- (texture == null && !loaded)) {
- lastUsingCached = getUsingCache();
- lastClickedSlot = getClickedSlot();
- generateTex(location);
- }
- if(texture != null && loaded) {
- if(!usingCached) lastRenderMillis = System.currentTimeMillis();
- lastRenderMillis = System.currentTimeMillis();
-
- GlStateManager.color(1, 1, 1, 1);
-
- textureManager.loadTexture(rl, texture);
- textureManager.bindTexture(rl);
- return;
- }
- }
- textureManager.bindTexture(location);
- }
-
- public static boolean getUsingCache() {
- return usingCached && System.currentTimeMillis() - lastRenderMillis < 300;
- }
-
- public static boolean isBlacklistedInventory() {
- if(!isChestOpen()) return false;
-
- GuiChest eventGui = (GuiChest) Minecraft.getMinecraft().currentScreen;
- ContainerChest cc = (ContainerChest) eventGui.inventorySlots;
- String containerName = cc.getLowerChestInventory().getDisplayName().getUnformattedText();
- return containerName.toLowerCase().trim().startsWith("navigate the maze");
- }
-
- public static boolean isOverriding() {
- return isChestOpen() && ((loaded && texture != null)) && !isBlacklistedInventory();
- }
-
- public static boolean isBlankStack(ItemStack stack) {
- return stack != null && stack.getItem() == Item.getItemFromBlock(Blocks.stained_glass_pane) &&
- stack.getDisplayName() != null && stack.getDisplayName().trim().isEmpty();
- }
-
- public static boolean shouldRenderStack(ItemStack stack) {
- return !isBlankStack(stack) && !isToggleOff(stack) && !isToggleOn(stack);
- }
-
- public static boolean isButtonStack(ItemStack stack) {
- return stack != null && stack.getItem() != Item.getItemFromBlock(Blocks.stained_glass_pane)
- && NotEnoughUpdates.INSTANCE.manager.getInternalNameForItem(stack) == null && !isToggleOn(stack) && !isToggleOff(stack);
- }
-
- public static int getTextColour() {
- return textColour;
- }
-
- public static boolean isToggleOn(ItemStack stack) {
- if(stack != null && stack.getTagCompound() != null && stack.getTagCompound().hasKey("display", 10) &&
- stack.getTagCompound().getCompoundTag("display").hasKey("Lore", 9)) {
- NBTTagList lore = stack.getTagCompound().getCompoundTag("display").getTagList("Lore", 8);
- if(lore.tagCount() == 1 && lore.getStringTagAt(0).equalsIgnoreCase(EnumChatFormatting.GRAY+"click to disable!")) {
- return true;
- }
- }
- return false;
- }
-
- public static boolean isToggleOff(ItemStack stack) {
- if(stack != null && stack.getTagCompound() != null && stack.getTagCompound().hasKey("display", 10) &&
- stack.getTagCompound().getCompoundTag("display").hasKey("Lore", 9)) {
- NBTTagList lore = stack.getTagCompound().getCompoundTag("display").getTagList("Lore", 8);
- if(lore.tagCount() == 1 && lore.getStringTagAt(0).equalsIgnoreCase(EnumChatFormatting.GRAY+"click to enable!")) {
- return true;
- }
- }
- return false;
- }
-
- private static void generateTex(ResourceLocation location) {
- if(!hasItem()) return;
- texture = null;
- loaded = true;
- Container container = ((GuiChest)Minecraft.getMinecraft().currentScreen).inventorySlots;
-
- if(hasNullPane() && container instanceof ContainerChest) {
- int backgroundStyle = NotEnoughUpdates.INSTANCE.manager.config.dynamicMenuBackgroundStyle.value.intValue();
- backgroundStyle = Math.max(1, Math.min(10, backgroundStyle));
- try(BufferedReader reader = new BufferedReader(new InputStreamReader(Minecraft.getMinecraft().getResourceManager().getResource(
- new ResourceLocation("notenoughupdates:dynamic_54/style"+ backgroundStyle+"/dynamic_config.json")).getInputStream(), StandardCharsets.UTF_8))) {
- JsonObject json = NotEnoughUpdates.INSTANCE.manager.gson.fromJson(reader, JsonObject.class);
- String textColourS = json.get("text-colour").getAsString();
- textColour = (int)Long.parseLong(textColourS, 16);
- } catch(Exception e) {
- textColour = 4210752;
- }
-
- try {
- BufferedImage bufferedImageOn = ImageIO.read(Minecraft.getMinecraft().getResourceManager().getResource(TOGGLE_ON).getInputStream());
- BufferedImage bufferedImageOff = ImageIO.read(Minecraft.getMinecraft().getResourceManager().getResource(TOGGLE_OFF).getInputStream());
-
- BufferedImage bufferedImageBase = ImageIO.read(Minecraft.getMinecraft().getResourceManager().getResource(DYNAMIC_54_BASE).getInputStream());
- try {
- bufferedImageBase = ImageIO.read(Minecraft.getMinecraft().getResourceManager().getResource(
- new ResourceLocation("notenoughupdates:dynamic_54/style"+ backgroundStyle+"/dynamic_54.png")).getInputStream());
- } catch(Exception e) {}
- BufferedImage bufferedImageSlot = ImageIO.read(Minecraft.getMinecraft().getResourceManager().getResource(DYNAMIC_54_SLOT).getInputStream());
- try {
- int buttonStyle = NotEnoughUpdates.INSTANCE.manager.config.dynamicMenuButtonStyle.value.intValue();
- buttonStyle = Math.max(1, Math.min(10, buttonStyle));
- bufferedImageSlot = ImageIO.read(Minecraft.getMinecraft().getResourceManager().getResource(
- new ResourceLocation("notenoughupdates:dynamic_54/style"+buttonStyle+"/dynamic_54_slot_ctm.png")).getInputStream());
- } catch(Exception e) {}
- BufferedImage bufferedImageButton = ImageIO.read(Minecraft.getMinecraft().getResourceManager().getResource(DYNAMIC_54_BUTTON).getInputStream());
- try {
- int buttonStyle = NotEnoughUpdates.INSTANCE.manager.config.dynamicMenuButtonStyle.value.intValue();
- buttonStyle = Math.max(1, Math.min(10, buttonStyle));
- bufferedImageButton = ImageIO.read(Minecraft.getMinecraft().getResourceManager().getResource(
- new ResourceLocation("notenoughupdates:dynamic_54/style"+buttonStyle+"/dynamic_54_button_ctm.png")).getInputStream());
- } catch(Exception e) {}
-
- int horzTexMult = bufferedImageBase.getWidth()/256;
- int vertTexMult = bufferedImageBase.getWidth()/256;
- BufferedImage bufferedImageNew = new BufferedImage(
- bufferedImageBase.getColorModel(),
- bufferedImageBase.copyData(null),
- bufferedImageBase.isAlphaPremultiplied(),
- null);
- IInventory lower = ((ContainerChest) container).getLowerChestInventory();
- int size = lower.getSizeInventory();
- boolean[][] slots = new boolean[9][size/9];
- boolean[][] buttons = new boolean[9][size/9];
- for (int index = 0; index < size; index++) {
- ItemStack stack = getStackCached(lower, index);
- buttons[index%9][index/9] = isButtonStack(stack);
-
- if(buttons[index%9][index/9] && lastClickedSlot == index) {
- buttons[index%9][index/9] = false;
- slots[index%9][index/9] = true;
- } else {
- slots[index%9][index/9] = !isBlankStack(stack) && !buttons[index%9][index/9];
- }
- }
- for (int index = 0; index < size; index++) {
- ItemStack stack = getStackCached(lower, index);
- int xi = index%9;
- int yi = index/9;
- if(slots[xi][yi] || buttons[xi][yi]) {
- int x = 7*horzTexMult + xi*18*horzTexMult;
- int y = 17*vertTexMult + yi*18*vertTexMult;
-
- boolean on = isToggleOn(stack);
- boolean off = isToggleOff(stack);
-
- if(on || off) {
- for(int x2=0; x2<18; x2++) {
- for(int y2=0; y2<18; y2++) {
- BufferedImage toggle = on ? bufferedImageOn : bufferedImageOff;
- Color c = new Color(toggle.getRGB(x2, y2), true);
- if(c.getAlpha() < 10) {
- continue;
- }
- bufferedImageNew.setRGB(x+x2, y+y2, c.getRGB());
- }
- }
- continue;
- }
-
- if(buttons[xi][yi]) {
- boolean up = yi > 0 && buttons[xi][yi-1];
- boolean right = xi < buttons.length-1 && buttons[xi+1][yi];
- boolean down = yi < buttons[xi].length-1 && buttons[xi][yi+1];
- boolean left = xi > 0 && buttons[xi-1][yi];
-
- boolean upleft = yi > 0 && xi > 0 && buttons[xi-1][yi-1];
- boolean upright = yi > 0 && xi < buttons.length-1 && buttons[xi+1][yi-1];
- boolean downright = xi < buttons.length-1 && yi < buttons[xi+1].length-1 && buttons[xi+1][yi+1];
- boolean downleft = xi > 0 && yi < buttons[xi-1].length-1 && buttons[xi-1][yi+1];
-
- int ctmIndex = getCTMIndex(up, right, down, left, upleft, upright, downright, downleft);
- int[] rgbs = bufferedImageButton.getRGB((ctmIndex%12)*19*horzTexMult, (ctmIndex/12)*19*vertTexMult,
- 18*horzTexMult, 18*vertTexMult, null, 0, 18*vertTexMult);
- bufferedImageNew.setRGB(x, y, 18*horzTexMult, 18*vertTexMult, rgbs, 0, 18*vertTexMult);
-
- } else {
- boolean up = yi > 0 && slots[xi][yi-1];
- boolean right = xi < slots.length-1 && slots[xi+1][yi];
- boolean down = yi < slots[xi].length-1 && slots[xi][yi+1];
- boolean left = xi > 0 && slots[xi-1][yi];
-
- boolean upleft = yi > 0 && xi > 0 && slots[xi-1][yi-1];
- boolean upright = yi > 0 && xi < slots.length-1 && slots[xi+1][yi-1];
- boolean downright = xi < slots.length-1 && yi < slots[xi+1].length-1 && slots[xi+1][yi+1];
- boolean downleft = xi > 0 && yi < slots[xi-1].length-1 && slots[xi-1][yi+1];
-
- int ctmIndex = getCTMIndex(up, right, down, left, upleft, upright, downright, downleft);
- int[] rgbs = bufferedImageSlot.getRGB((ctmIndex%12)*19*horzTexMult, (ctmIndex/12)*19*vertTexMult,
- 18*horzTexMult, 18*vertTexMult, null, 0, 18*vertTexMult);
- bufferedImageNew.setRGB(x, y, 18*horzTexMult, 18*vertTexMult, rgbs, 0, 18*vertTexMult);
- }
- }
- }
- texture = new DynamicTexture(bufferedImageNew);
- } catch(Exception e) {
- e.printStackTrace();
- }
- }
- }
-
- public static void reset() {
- texture = null;
- loaded = false;
- clickedSlot = -1;
- clickedSlotMillis = 0;
- textColour = 4210752;
- }
-
- private static boolean isChestOpen() {
- return Minecraft.getMinecraft().currentScreen instanceof GuiChest &&
- NotEnoughUpdates.INSTANCE.hasSkyblockScoreboard() &&
- (NotEnoughUpdates.INSTANCE.manager.config.dynamicMenuBackgroundStyle.value >= 1 &&
- NotEnoughUpdates.INSTANCE.manager.config.dynamicMenuButtonStyle.value >= 1);
- }
-
- private static boolean hasItem() {
- if(!isChestOpen()) return false;
- Container container = ((GuiChest)Minecraft.getMinecraft().currentScreen).inventorySlots;
- if(container instanceof ContainerChest) {
- IInventory lower = ((ContainerChest)container).getLowerChestInventory();
- int size = lower.getSizeInventory();
- for(int index=0; index<size; index++) {
- if(getStackCached(lower, index) != null) return true;
- }
- }
- return false;
- }
-
- private static ItemStack getStackCached(IInventory lower, int index) {
- if(getUsingCache()) {
- return itemCache.get(index);
- } else {
- return lower.getStackInSlot(index);
- }
- }
-
- private static boolean hasNullPane() {
- if(!isChestOpen()) return false;
- Container container = ((GuiChest)Minecraft.getMinecraft().currentScreen).inventorySlots;
- if(container instanceof ContainerChest) {
- IInventory lower = ((ContainerChest)container).getLowerChestInventory();
- int size = lower.getSizeInventory();
- for(int index=0; index<size; index++) {
- if(isBlankStack(getStackCached(lower, index))) return true;
- }
- }
- return false;
- }
-
- private static int getCTMIndex(boolean up, boolean right, boolean down, boolean left, boolean upleft, boolean upright, boolean downright, boolean downleft) {
- if(up && right && down && left) {
- if(upleft && upright && downright && downleft) {
- return 26;
- } else if(upleft && upright && downright && !downleft) {
- return 33;
- } else if(upleft && upright && !downright && downleft) {
- return 32;
- } else if(upleft && upright && !downright && !downleft) {
- return 11;
- } else if(upleft && !upright && downright && downleft) {
- return 44;
- } else if(upleft && !upright && downright && !downleft) {
- return 35;
- } else if(upleft && !upright && !downright && downleft) {
- return 10;
- } else if(upleft && !upright && !downright && !downleft) {
- return 20;
- } else if(!upleft && upright && downright && downleft) {
- return 45;
- } else if(!upleft && upright && downright && !downleft) {
- return 23;
- } else if(!upleft && upright && !downright && downleft) {
- return 34;
- } else if(!upleft && upright && !downright && !downleft) {
- return 8;
- } else if(!upleft && !upright && downright && downleft) {
- return 22;
- } else if(!upleft && !upright && downright && !downleft) {
- return 9;
- } else if(!upleft && !upright && !downright && downleft) {
- return 21;
- } else {
- return 46;
- }
- } else if(up && right && down && !left) {
- if(!upright && !downright) {
- return 6;
- } else if(!upright) {
- return 28;
- } else if(!downright) {
- return 30;
- } else {
- return 25;
- }
- } else if(up && right && !down && left) {
- if(!upleft && !upright) {
- return 18;
- } else if(!upleft) {
- return 40;
- } else if(!upright) {
- return 42;
- } else {
- return 38;
- }
- } else if(up && right && !down && !left) {
- if(!upright) {
- return 16;
- } else {
- return 37;
- }
- } else if(up && !right && down && left) {
- if(!upleft && !downleft) {
- return 19;
- } else if(!upleft) {
- return 43;
- } else if(!downleft) {
- return 41;
- } else {
- return 27;
- }
- } else if(up && !right && down && !left) {
- return 24;
- } else if(up && !right && !down && left) {
- if(!upleft) {
- return 17;
- } else {
- return 39;
- }
- } else if(up && !right && !down && !left) {
- return 36;
- } else if(!up && right && down && left) {
- if(!downleft && !downright) {
- return 7;
- } else if(!downleft) {
- return 31;
- } else if(!downright) {
- return 29;
- } else {
- return 14;
- }
- } else if(!up && right && down && !left) {
- if(!downright) {
- return 4;
- } else {
- return 13;
- }
- } else if(!up && right && !down && left) {
- return 2;
- } else if(!up && right && !down && !left) {
- return 1;
- } else if(!up && !right && down && left) {
- if(!downleft) {
- return 5;
- } else {
- return 15;
- }
- } else if(!up && !right && down && !left) {
- return 12;
- } else if(!up && !right && !down && left) {
- return 3;
- } else {
- return 0;
- }
- }
-
-}