aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/moe/nea/firmament/mixins/MixinPlayerScreenHandler.java
diff options
context:
space:
mode:
authorJacob <55346310+Kathund@users.noreply.github.com>2025-08-12 04:58:14 +0800
committerGitHub <noreply@github.com>2025-08-11 22:58:14 +0200
commit3fe5ec7233fcfaa6884c7676fd720f3a3600cd58 (patch)
tree28cc36f0ebcbf121f0f63c2bb746d1ace1358f0a /src/main/java/moe/nea/firmament/mixins/MixinPlayerScreenHandler.java
parent773a8bec96877d0210044b335a83ac12a460cad5 (diff)
downloadFirmament-3fe5ec7233fcfaa6884c7676fd720f3a3600cd58.tar.gz
Firmament-3fe5ec7233fcfaa6884c7676fd720f3a3600cd58.tar.bz2
Firmament-3fe5ec7233fcfaa6884c7676fd720f3a3600cd58.zip
feat: remove offhand (#125)
Diffstat (limited to 'src/main/java/moe/nea/firmament/mixins/MixinPlayerScreenHandler.java')
-rw-r--r--src/main/java/moe/nea/firmament/mixins/MixinPlayerScreenHandler.java31
1 files changed, 31 insertions, 0 deletions
diff --git a/src/main/java/moe/nea/firmament/mixins/MixinPlayerScreenHandler.java b/src/main/java/moe/nea/firmament/mixins/MixinPlayerScreenHandler.java
new file mode 100644
index 0000000..12455f4
--- /dev/null
+++ b/src/main/java/moe/nea/firmament/mixins/MixinPlayerScreenHandler.java
@@ -0,0 +1,31 @@
+package moe.nea.firmament.mixins;
+
+import moe.nea.firmament.features.fixes.Fixes;
+import net.minecraft.entity.player.PlayerEntity;
+import net.minecraft.entity.player.PlayerInventory;
+import net.minecraft.screen.PlayerScreenHandler;
+import org.spongepowered.asm.mixin.Mixin;
+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;
+
+@Mixin(PlayerScreenHandler.class)
+public class MixinPlayerScreenHandler {
+
+ @Unique
+ private static final int OFF_HAND_SLOT = 40;
+
+ @Inject(method = "<init>", at = @At("TAIL"))
+ private void moveOffHandSlot(PlayerInventory inventory, boolean onServer, PlayerEntity owner, CallbackInfo ci) {
+ if (Fixes.TConfig.INSTANCE.getHideOffHand()) {
+ PlayerScreenHandler self = (PlayerScreenHandler) (Object) this;
+ self.slots.stream()
+ .filter(slot -> slot.getIndex() == OFF_HAND_SLOT)
+ .forEach(slot -> {
+ slot.x = -1000;
+ slot.y = -1000;
+ });
+ }
+ }
+}