From 3c81f9c3804a1f2880dff836d137ae49d9c23ea6 Mon Sep 17 00:00:00 2001 From: zeruth Date: Wed, 6 May 2020 07:51:56 -0400 Subject: [PATCH] runelite: add DrawFinished event --- .../net/runelite/client/callback/Hooks.java | 13 +++++++ .../runelite/client/events/DrawFinished.java | 35 +++++++++++++++++++ .../client/ui/overlay/OverlayLayer.java | 5 +++ 3 files changed, 53 insertions(+) create mode 100644 runelite-client/src/main/java/net/runelite/client/events/DrawFinished.java diff --git a/runelite-client/src/main/java/net/runelite/client/callback/Hooks.java b/runelite-client/src/main/java/net/runelite/client/callback/Hooks.java index 2864c859f2..da0fd9f46f 100644 --- a/runelite-client/src/main/java/net/runelite/client/callback/Hooks.java +++ b/runelite-client/src/main/java/net/runelite/client/callback/Hooks.java @@ -64,6 +64,7 @@ import net.runelite.client.Notifier; import net.runelite.client.RuneLite; import net.runelite.client.chat.ChatMessageManager; import net.runelite.client.eventbus.EventBus; +import net.runelite.client.events.DrawFinished; import net.runelite.client.input.KeyManager; import net.runelite.client.input.MouseManager; import net.runelite.client.task.Scheduler; @@ -393,6 +394,18 @@ public class Hooks implements Callbacks finalImage = image; } + DrawFinished event = new DrawFinished(copy(finalImage)); + eventBus.post(DrawFinished.class, event); + + try + { + renderer.render((Graphics2D)finalImage.getGraphics(), OverlayLayer.AFTER_MIRROR); + } + catch (Exception ex) + { + log.warn("Error during post-mirror rendering", ex); + } + // Draw the image onto the game canvas graphics.drawImage(finalImage, 0, 0, client.getCanvas()); diff --git a/runelite-client/src/main/java/net/runelite/client/events/DrawFinished.java b/runelite-client/src/main/java/net/runelite/client/events/DrawFinished.java new file mode 100644 index 0000000000..227110e8ba --- /dev/null +++ b/runelite-client/src/main/java/net/runelite/client/events/DrawFinished.java @@ -0,0 +1,35 @@ +/* + * Copyright (c) 2018, Adam + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the above copyright notice, this + * list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright notice, + * this list of conditions and the following disclaimer in the documentation + * and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND + * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED + * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE + * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR + * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; + * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND + * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS + * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ +package net.runelite.client.events; + +import lombok.Value; +import net.runelite.api.events.Event; +import java.awt.Image; + +@Value +public class DrawFinished implements Event +{ + public Image image; +} \ No newline at end of file diff --git a/runelite-client/src/main/java/net/runelite/client/ui/overlay/OverlayLayer.java b/runelite-client/src/main/java/net/runelite/client/ui/overlay/OverlayLayer.java index ac75932ad6..ca91721b4f 100644 --- a/runelite-client/src/main/java/net/runelite/client/ui/overlay/OverlayLayer.java +++ b/runelite-client/src/main/java/net/runelite/client/ui/overlay/OverlayLayer.java @@ -50,4 +50,9 @@ public enum OverlayLayer * Render over the map, even when it's fullscreen */ ABOVE_MAP, + + /** + * Render overlay after mirror is produced + */ + AFTER_MIRROR, }