aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThatGravyBoat <thatgravyboat@gmail.com>2021-07-15 18:28:38 -0230
committerThatGravyBoat <thatgravyboat@gmail.com>2021-07-15 18:28:38 -0230
commitd447859cc3b850551191cabf832d3ab305758a9e (patch)
tree47c785977c9d144765d6e4459f1ffdc4601fda67
parentdb6b8d152adf270035a274046afc6220a85eadb2 (diff)
downloadSkyblockHud-Death-Defied-d447859cc3b850551191cabf832d3ab305758a9e.tar.gz
SkyblockHud-Death-Defied-d447859cc3b850551191cabf832d3ab305758a9e.tar.bz2
SkyblockHud-Death-Defied-d447859cc3b850551191cabf832d3ab305758a9e.zip
Fixed issue with hudcaching and sbh not being able to remove hud elements
-rw-r--r--src/main/java/com/thatgravyboat/skyblockhud/handlers/MapHandler.java4
-rw-r--r--src/main/java/com/thatgravyboat/skyblockhud/mixins/MixinGuiIngameForge.java43
2 files changed, 25 insertions, 22 deletions
diff --git a/src/main/java/com/thatgravyboat/skyblockhud/handlers/MapHandler.java b/src/main/java/com/thatgravyboat/skyblockhud/handlers/MapHandler.java
index bf38d49..e7143a9 100644
--- a/src/main/java/com/thatgravyboat/skyblockhud/handlers/MapHandler.java
+++ b/src/main/java/com/thatgravyboat/skyblockhud/handlers/MapHandler.java
@@ -1,7 +1,5 @@
package com.thatgravyboat.skyblockhud.handlers;
-import static com.thatgravyboat.skyblockhud.GuiTextures.mapOverlay;
-
import com.thatgravyboat.skyblockhud.SkyblockHud;
import com.thatgravyboat.skyblockhud.Utils;
import com.thatgravyboat.skyblockhud.config.KeyBindings;
@@ -26,6 +24,8 @@ import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
import net.minecraftforge.fml.common.gameevent.TickEvent;
import org.lwjgl.opengl.GL11;
+import static com.thatgravyboat.skyblockhud.GuiTextures.mapOverlay;
+
public class MapHandler {
public enum MapIconTypes {
diff --git a/src/main/java/com/thatgravyboat/skyblockhud/mixins/MixinGuiIngameForge.java b/src/main/java/com/thatgravyboat/skyblockhud/mixins/MixinGuiIngameForge.java
index 5d64950..746d917 100644
--- a/src/main/java/com/thatgravyboat/skyblockhud/mixins/MixinGuiIngameForge.java
+++ b/src/main/java/com/thatgravyboat/skyblockhud/mixins/MixinGuiIngameForge.java
@@ -1,7 +1,5 @@
package com.thatgravyboat.skyblockhud.mixins;
-import static net.minecraftforge.client.event.RenderGameOverlayEvent.ElementType.*;
-
import com.thatgravyboat.skyblockhud.SkyblockHud;
import com.thatgravyboat.skyblockhud.Utils;
import com.thatgravyboat.skyblockhud.overlay.MiningHud;
@@ -11,10 +9,13 @@ import net.minecraftforge.client.event.RenderGameOverlayEvent;
import net.minecraftforge.common.MinecraftForge;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.Shadow;
+import org.spongepowered.asm.mixin.Unique;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
+import static net.minecraftforge.client.event.RenderGameOverlayEvent.ElementType.*;
+
@Mixin(GuiIngameForge.class)
public class MixinGuiIngameForge {
@@ -25,8 +26,8 @@ public class MixinGuiIngameForge {
public void onRenderArmor(int width, int height, CallbackInfo ci) {
if (SkyblockHud.config.renderer.hideArmor && SkyblockHud.hasSkyblockScoreboard()) {
ci.cancel();
- if (pre(ARMOR)) return;
- post(ARMOR);
+ if (prePost(ARMOR, eventParent)) return;
+ postPost(ARMOR, eventParent);
}
}
@@ -34,8 +35,8 @@ public class MixinGuiIngameForge {
public void onRenderHealth(int width, int height, CallbackInfo ci) {
if (SkyblockHud.config.renderer.hideHearts && SkyblockHud.hasSkyblockScoreboard()) {
ci.cancel();
- if (pre(HEALTH)) return;
- post(HEALTH);
+ if (prePost(HEALTH, eventParent)) return;
+ postPost(HEALTH, eventParent);
}
}
@@ -43,8 +44,8 @@ public class MixinGuiIngameForge {
public void onRenderAir(int width, int height, CallbackInfo ci) {
if (SkyblockHud.config.renderer.hideAir && SkyblockHud.hasSkyblockScoreboard()) {
ci.cancel();
- if (pre(AIR)) return;
- post(AIR);
+ if (prePost(AIR, eventParent)) return;
+ postPost(AIR, eventParent);
}
}
@@ -52,8 +53,8 @@ public class MixinGuiIngameForge {
public void onRenderHealthMount(int width, int height, CallbackInfo ci) {
if (SkyblockHud.config.renderer.hideAnimalHearts && SkyblockHud.hasSkyblockScoreboard()) {
ci.cancel();
- if (pre(HEALTHMOUNT)) return;
- post(HEALTHMOUNT);
+ if (prePost(HEALTHMOUNT, eventParent)) return;
+ postPost(HEALTHMOUNT, eventParent);
}
}
@@ -61,13 +62,13 @@ public class MixinGuiIngameForge {
public void onRenderExperience(int width, int height, CallbackInfo ci) {
if (SkyblockHud.config.renderer.hideXpBar && SkyblockHud.hasSkyblockScoreboard()) {
ci.cancel();
- if (pre(EXPERIENCE)) return;
- post(EXPERIENCE);
+ if (prePost(EXPERIENCE, eventParent)) return;
+ postPost(EXPERIENCE, eventParent);
} else if (!SkyblockHud.config.renderer.hideXpBar && (SkyblockHud.config.mining.showDrillBar || SkyblockHud.config.mining.showHeatBar) && SkyblockHud.hasSkyblockScoreboard()) {
if (MiningHud.getHeat() > 0 || Utils.isDrill(Minecraft.getMinecraft().thePlayer.getHeldItem())) {
ci.cancel();
- if (pre(EXPERIENCE)) return;
- post(EXPERIENCE);
+ if (prePost(EXPERIENCE, eventParent)) return;
+ postPost(EXPERIENCE, eventParent);
}
}
}
@@ -76,8 +77,8 @@ public class MixinGuiIngameForge {
public void onRenderJumpBar(int width, int height, CallbackInfo ci) {
if (SkyblockHud.config.renderer.hideXpBar && SkyblockHud.hasSkyblockScoreboard()) {
ci.cancel();
- if (pre(JUMPBAR)) return;
- post(JUMPBAR);
+ if (prePost(JUMPBAR, eventParent)) return;
+ postPost(JUMPBAR, eventParent);
}
}
@@ -85,16 +86,18 @@ public class MixinGuiIngameForge {
public void onRenderFood(int width, int height, CallbackInfo ci) {
if (SkyblockHud.config.renderer.hideFood && SkyblockHud.hasSkyblockScoreboard()) {
ci.cancel();
- if (pre(FOOD)) return;
- post(FOOD);
+ if (prePost(FOOD, eventParent)) return;
+ postPost(FOOD, eventParent);
}
}
- private boolean pre(RenderGameOverlayEvent.ElementType type) {
+ @Unique
+ private static boolean prePost(RenderGameOverlayEvent.ElementType type, RenderGameOverlayEvent eventParent) {
return MinecraftForge.EVENT_BUS.post(new RenderGameOverlayEvent.Pre(eventParent, type));
}
- private void post(RenderGameOverlayEvent.ElementType type) {
+ @Unique
+ private static void postPost(RenderGameOverlayEvent.ElementType type, RenderGameOverlayEvent eventParent) {
MinecraftForge.EVENT_BUS.post(new RenderGameOverlayEvent.Post(eventParent, type));
}
}