aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/shedaniel/rei/mixin/MixinContainerGui.java
diff options
context:
space:
mode:
authorUnknown <shekwancheung0528@gmail.com>2019-01-12 15:23:14 +0800
committerUnknown <shekwancheung0528@gmail.com>2019-01-12 15:23:14 +0800
commitdf941b4b679fea60840862298710916720f112b6 (patch)
tree16edb6c434960347294a939eaf19d5a85bfdf5cb /src/main/java/me/shedaniel/rei/mixin/MixinContainerGui.java
parent1ac6e0efb3ef837634e23b897ec9dcd826357462 (diff)
downloadRoughlyEnoughItems-2.0.0.32.tar.gz
RoughlyEnoughItems-2.0.0.32.tar.bz2
RoughlyEnoughItems-2.0.0.32.zip
Fixed lots of guisv2.0.0.32
Diffstat (limited to 'src/main/java/me/shedaniel/rei/mixin/MixinContainerGui.java')
-rw-r--r--src/main/java/me/shedaniel/rei/mixin/MixinContainerGui.java44
1 files changed, 22 insertions, 22 deletions
diff --git a/src/main/java/me/shedaniel/rei/mixin/MixinContainerGui.java b/src/main/java/me/shedaniel/rei/mixin/MixinContainerGui.java
index 3c8d65ccf..64d5eae97 100644
--- a/src/main/java/me/shedaniel/rei/mixin/MixinContainerGui.java
+++ b/src/main/java/me/shedaniel/rei/mixin/MixinContainerGui.java
@@ -1,13 +1,18 @@
package me.shedaniel.rei.mixin;
+import me.shedaniel.rei.RoughlyEnoughItemsCore;
+import me.shedaniel.rei.client.ClientHelper;
import me.shedaniel.rei.client.GuiHelper;
import me.shedaniel.rei.gui.ContainerGuiOverlay;
import me.shedaniel.rei.listeners.IMixinContainerGui;
+import me.shedaniel.rei.listeners.IMixinTabGetter;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.gui.ContainerGui;
import net.minecraft.client.gui.Gui;
import net.minecraft.client.gui.GuiEventListener;
+import net.minecraft.client.gui.ingame.CreativePlayerInventoryGui;
import net.minecraft.container.Slot;
+import net.minecraft.item.ItemGroup;
import net.minecraft.item.ItemStack;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.Shadow;
@@ -27,14 +32,12 @@ public class MixinContainerGui extends Gui implements IMixinContainerGui {
protected int containerWidth;
@Shadow
protected int containerHeight;
-
+ @Shadow
+ protected Slot focusedSlot;
private ContainerGui lastGui;
-
@Shadow
private ItemStack field_2782;
- @Shadow protected Slot focusedSlot;
-
@Override
public int getContainerLeft() {
return left;
@@ -68,6 +71,11 @@ public class MixinContainerGui extends Gui implements IMixinContainerGui {
@Inject(method = "draw(IIF)V", at = @At("RETURN"))
public void draw(int int_1, int int_2, float float_1, CallbackInfo info) {
+ if (MinecraftClient.getInstance().currentGui instanceof CreativePlayerInventoryGui) {
+ IMixinTabGetter tabGetter = (IMixinTabGetter) MinecraftClient.getInstance().currentGui;
+ if (tabGetter.getSelectedTab() != ItemGroup.INVENTORY.getId())
+ return;
+ }
if (MinecraftClient.getInstance().currentGui instanceof ContainerGui)
this.lastGui = (ContainerGui) MinecraftClient.getInstance().currentGui;
GuiHelper.getOverlay(lastGui).render(int_1, int_2, float_1);
@@ -83,24 +91,6 @@ public class MixinContainerGui extends Gui implements IMixinContainerGui {
return lastGui;
}
- // TODO into an inject
- @Override
- public boolean mouseScrolled(double double_1) {
- for(GuiEventListener entry : this.getEntries())
- if (entry.mouseScrolled(double_1))
- return true;
- return false;
- }
-
- // TODO into an inject
- @Override
- public boolean charTyped(char char_1, int int_1) {
- for(GuiEventListener entry : this.getEntries())
- if (entry.charTyped(char_1, int_1))
- return true;
- return false;
- }
-
@Inject(method = "keyPressed(III)Z", at = @At("HEAD"), cancellable = true)
public void keyPressed(int int_1, int int_2, int int_3, CallbackInfoReturnable<Boolean> ci) {
for(GuiEventListener entry : this.getEntries())
@@ -115,4 +105,14 @@ public class MixinContainerGui extends Gui implements IMixinContainerGui {
return focusedSlot;
}
+ @Override
+ public boolean mouseScrolled(double double_1) {
+ ContainerGuiOverlay overlay = GuiHelper.getOverlay(lastGui);
+ if (GuiHelper.isOverlayVisible() && overlay.getRectangle().contains(ClientHelper.getMouseLocation()))
+ for(GuiEventListener entry : this.getEntries())
+ if (entry.mouseScrolled(double_1))
+ return true;
+ return super.mouseScrolled(double_1);
+ }
+
}