From aee1bd60143c9f9ada2d4f6ca4de3f7c5c2d768e Mon Sep 17 00:00:00 2001 From: mezz Date: Tue, 12 Jan 2016 20:01:27 -0800 Subject: [PATCH] Add GuiScreenEvent.BackgroundDrawnEvent --- .../minecraft/client/gui/GuiScreen.java.patch | 8 ++++ .../client/event/GuiScreenEvent.java | 40 +++++++++++++++++++ 2 files changed, 48 insertions(+) diff --git a/patches/minecraft/net/minecraft/client/gui/GuiScreen.java.patch b/patches/minecraft/net/minecraft/client/gui/GuiScreen.java.patch index 85fa8750e..1a343c6f6 100644 --- a/patches/minecraft/net/minecraft/client/gui/GuiScreen.java.patch +++ b/patches/minecraft/net/minecraft/client/gui/GuiScreen.java.patch @@ -97,3 +97,11 @@ } } } +@@ -570,6 +591,7 @@ + public void func_146276_q_() + { + this.func_146270_b(0); ++ net.minecraftforge.common.MinecraftForge.EVENT_BUS.post(new net.minecraftforge.client.event.GuiScreenEvent.BackgroundDrawnEvent(this)); + } + + public void func_146270_b(int p_146270_1_) diff --git a/src/main/java/net/minecraftforge/client/event/GuiScreenEvent.java b/src/main/java/net/minecraftforge/client/event/GuiScreenEvent.java index 7ed451c77..b38feff7d 100644 --- a/src/main/java/net/minecraftforge/client/event/GuiScreenEvent.java +++ b/src/main/java/net/minecraftforge/client/event/GuiScreenEvent.java @@ -3,8 +3,12 @@ package net.minecraftforge.client.event; import java.util.ArrayList; import java.util.List; +import org.lwjgl.input.Mouse; + import net.minecraft.client.gui.GuiButton; import net.minecraft.client.gui.GuiScreen; +import net.minecraft.client.gui.ScaledResolution; + import net.minecraftforge.fml.common.eventhandler.Cancelable; import net.minecraftforge.fml.common.eventhandler.Event; import net.minecraftforge.fml.relauncher.Side; @@ -119,6 +123,42 @@ public class GuiScreenEvent extends Event } } } + + /** + * This event fires at the end of {@code GuiScreen.drawDefaultBackground()} and before the rest of the Gui draws. + * This allows drawing next to Guis, above the background but below any tooltips. + */ + public static class BackgroundDrawnEvent extends GuiScreenEvent + { + private final int mouseX; + private final int mouseY; + + public BackgroundDrawnEvent(GuiScreen gui) + { + super(gui); + final ScaledResolution scaledresolution = new ScaledResolution(gui.mc); + final int scaledWidth = scaledresolution.getScaledWidth(); + final int scaledHeight = scaledresolution.getScaledHeight(); + this.mouseX = Mouse.getX() * scaledWidth / gui.mc.displayWidth; + this.mouseY = scaledHeight - Mouse.getY() * scaledHeight / gui.mc.displayHeight - 1; + } + + /** + * The x coordinate of the mouse pointer on the screen. + */ + public int getMouseX() + { + return mouseX; + } + + /** + * The y coordinate of the mouse pointer on the screen. + */ + public int getMouseY() + { + return mouseY; + } + } public static class ActionPerformedEvent extends GuiScreenEvent {