aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/detrav/gui/DetravScannerGUI.java
diff options
context:
space:
mode:
authorNotAPenguin <michiel.vandeginste@gmail.com>2024-09-02 23:17:17 +0200
committerGitHub <noreply@github.com>2024-09-02 23:17:17 +0200
commit1b820de08a05070909a267e17f033fcf58ac8710 (patch)
tree02831a025986a06b20f87e5bcc69d1e0c639a342 /src/main/java/detrav/gui/DetravScannerGUI.java
parentafd3fd92b6a6ab9ab0d0dc3214e6bc8ff7a86c9b (diff)
downloadGT5-Unofficial-1b820de08a05070909a267e17f033fcf58ac8710.tar.gz
GT5-Unofficial-1b820de08a05070909a267e17f033fcf58ac8710.tar.bz2
GT5-Unofficial-1b820de08a05070909a267e17f033fcf58ac8710.zip
The Great Renaming (#3014)
* move kekztech to a single root dir * move detrav to a single root dir * move gtnh-lanthanides to a single root dir * move tectech and delete some gross reflection in gt++ * remove more reflection inside gt5u * delete more reflection in gt++ * fix imports * move bartworks and bwcrossmod * fix proxies * move galactigreg and ggfab * move gtneioreplugin * try to fix gt++ bee loader * apply the rename rules to BW * apply rename rules to bwcrossmod * apply rename rules to detrav scanner mod * apply rename rules to galacticgreg * apply rename rules to ggfab * apply rename rules to goodgenerator * apply rename rules to gtnh-lanthanides * apply rename rules to gt++ * apply rename rules to kekztech * apply rename rules to kubatech * apply rename rules to tectech * apply rename rules to gt apply the rename rules to gt * fix tt import * fix mui hopefully * fix coremod except intergalactic * rename assline recipe class * fix a class name i stumbled on * rename StructureUtility to GTStructureUtility to prevent conflict with structurelib * temporary rename of GTTooltipDataCache to old name * fix gt client/server proxy names
Diffstat (limited to 'src/main/java/detrav/gui/DetravScannerGUI.java')
-rw-r--r--src/main/java/detrav/gui/DetravScannerGUI.java120
1 files changed, 120 insertions, 0 deletions
diff --git a/src/main/java/detrav/gui/DetravScannerGUI.java b/src/main/java/detrav/gui/DetravScannerGUI.java
new file mode 100644
index 0000000000..7e7b4964e3
--- /dev/null
+++ b/src/main/java/detrav/gui/DetravScannerGUI.java
@@ -0,0 +1,120 @@
+package detrav.gui;
+
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+
+import net.minecraft.client.gui.GuiScreen;
+import net.minecraft.util.ResourceLocation;
+import net.minecraft.util.StatCollector;
+
+import org.lwjgl.opengl.GL11;
+
+import detrav.gui.textures.DetravMapTexture;
+import gregtech.api.util.GTUtility;
+
+/**
+ * Created by wital_000 on 21.03.2016.
+ */
+public class DetravScannerGUI extends GuiScreen {
+
+ public static final int GUI_ID = 20;
+ private static DetravMapTexture map = null;
+ OresList oresList = null;
+
+ private final static int minHeight = 128;
+ private final static int minWidth = 128;
+ private int prevW;
+ private int prevH;
+
+ private static final ResourceLocation back = new ResourceLocation("gregtech:textures/gui/propick.png");
+
+ public DetravScannerGUI() {
+
+ }
+
+ public static void newMap(DetravMapTexture aMap) {
+ if (map != null) {
+ map.deleteGlTexture();
+ map = null;
+ }
+ map = aMap;
+ map.loadTexture(null);
+ }
+
+ @Override
+ public void drawScreen(int x, int y, float f) {
+ this.drawDefaultBackground();
+ if (map == null) return;
+ int currentWidth = Math.max(map.width, minWidth);
+ int currentHeight = Math.max(map.height, minHeight);
+ int aX = (this.width - currentWidth - 100) / 2;
+ int aY = (this.height - currentHeight) / 2;
+
+ if (oresList == null || (prevW != width || prevH != height)) {
+ oresList = new OresList(
+ this,
+ 100,
+ currentHeight,
+ aY,
+ aY + currentHeight,
+ aX + currentWidth,
+ 10,
+ map.packet.ores,
+ ((name, invert) -> { if (map != null) map.loadTexture(null, name, invert); }));
+ prevW = width;
+ prevH = height;
+ }
+
+ // draw back for ores
+ drawRect(aX, aY, aX + currentWidth + 100, aY + currentHeight, 0xFFC6C6C6);
+ map.glBindTexture();
+ map.draw(aX, aY);
+ oresList.drawScreen(x, y, f);
+ mc.getTextureManager()
+ .bindTexture(back);
+ GL11.glColor4f(0xFF, 0xFF, 0xFF, 0xFF);
+
+ // draw corners
+ drawTexturedModalRect(aX - 5, aY - 5, 0, 0, 5, 5);// leftTop
+ drawTexturedModalRect(aX + currentWidth + 100, aY - 5, 171, 0, 5, 5);// RightTop
+ drawTexturedModalRect(aX - 5, aY + currentHeight, 0, 161, 5, 5);// leftDown
+ drawTexturedModalRect(aX + currentWidth + 100, aY + currentHeight, 171, 161, 5, 5);// RightDown
+
+ // draw edges
+ for (int i = aX; i < aX + currentWidth + 100; i += 128)
+ drawTexturedModalRect(i, aY - 5, 5, 0, Math.min(128, aX + currentWidth + 100 - i), 5); // top
+ for (int i = aX; i < aX + currentWidth + 100; i += 128)
+ drawTexturedModalRect(i, aY + currentHeight, 5, 161, Math.min(128, aX + currentWidth + 100 - i), 5); // down
+ for (int i = aY; i < aY + currentHeight; i += 128)
+ drawTexturedModalRect(aX - 5, i, 0, 5, 5, Math.min(128, aY + currentHeight - i)); // left
+ for (int i = aY; i < aY + currentHeight; i += 128)
+ drawTexturedModalRect(aX + currentWidth + 100, i, 171, 5, 5, Math.min(128, aY + currentHeight - i)); // right
+
+ if (map.packet.ptype == 2) {
+ HashMap<Byte, Short>[][] fluidInfo = map.packet.map;
+ int tX = x - aX;
+ int tY = y - aY;
+ if (tX >= 0 && tY >= 0 && tX < fluidInfo.length && tY < fluidInfo[0].length) {
+ List<String> info = new ArrayList<>();
+ if (fluidInfo[tX][tY] != null) {
+ short fluidId = fluidInfo[tX][tY].get((byte) 1);
+ short fluidAmount = fluidInfo[tX][tY].get((byte) 2);
+ if (fluidId != 0 && fluidAmount > 0) {
+ info.add(
+ StatCollector.translateToLocal("gui.detrav.scanner.tooltip.fluid_name")
+ + map.packet.metaMap.get(fluidId));
+ info.add(
+ StatCollector.translateToLocal("gui.detrav.scanner.tooltip.fluid_amount")
+ + GTUtility.formatNumbers(fluidAmount)
+ + " L");
+ } else info.add(StatCollector.translateToLocal("gui.detrav.scanner.tooltip.no_fluid"));
+ } else {
+ info.add(StatCollector.translateToLocal("gui.detrav.scanner.tooltip.no_fluid"));
+ }
+ func_146283_a(info, x, y);
+ }
+ }
+ }
+
+}