Merge pull request #2276 from WooxSolo/graphics-object-hooks
Add graphics objects
This commit is contained in:
@@ -234,6 +234,8 @@ public interface Client extends GameEngine
|
|||||||
|
|
||||||
List<Projectile> getProjectiles();
|
List<Projectile> getProjectiles();
|
||||||
|
|
||||||
|
List<GraphicsObject> getGraphicsObjects();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Play a sound effect at the player's current location. This is how UI,
|
* Play a sound effect at the player's current location. This is how UI,
|
||||||
* and player-generated (e.g. mining, woodcutting) sound effects are
|
* and player-generated (e.g. mining, woodcutting) sound effects are
|
||||||
|
|||||||
@@ -0,0 +1,40 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2018, Woox <https://github.com/wooxsolo>
|
||||||
|
* 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.api;
|
||||||
|
|
||||||
|
import net.runelite.api.coords.LocalPoint;
|
||||||
|
|
||||||
|
public interface GraphicsObject extends Renderable
|
||||||
|
{
|
||||||
|
int getId();
|
||||||
|
|
||||||
|
LocalPoint getLocation();
|
||||||
|
|
||||||
|
int getStartCycle();
|
||||||
|
|
||||||
|
int getLevel();
|
||||||
|
|
||||||
|
int getHeight();
|
||||||
|
}
|
||||||
@@ -0,0 +1,34 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2018, Woox <https://github.com/wooxsolo>
|
||||||
|
* 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.api.events;
|
||||||
|
|
||||||
|
import lombok.Value;
|
||||||
|
import net.runelite.api.GraphicsObject;
|
||||||
|
|
||||||
|
@Value
|
||||||
|
public class GraphicsObjectCreated
|
||||||
|
{
|
||||||
|
private final GraphicsObject graphicsObject;
|
||||||
|
}
|
||||||
@@ -39,6 +39,7 @@ import java.awt.image.BufferedImage;
|
|||||||
import net.runelite.api.Actor;
|
import net.runelite.api.Actor;
|
||||||
import net.runelite.api.ChatMessageType;
|
import net.runelite.api.ChatMessageType;
|
||||||
import net.runelite.api.Client;
|
import net.runelite.api.Client;
|
||||||
|
import net.runelite.api.GraphicsObject;
|
||||||
import net.runelite.api.Hitsplat;
|
import net.runelite.api.Hitsplat;
|
||||||
import net.runelite.api.ItemComposition;
|
import net.runelite.api.ItemComposition;
|
||||||
import net.runelite.api.KeyFocusListener;
|
import net.runelite.api.KeyFocusListener;
|
||||||
@@ -56,6 +57,7 @@ import net.runelite.api.events.ActorDeath;
|
|||||||
import net.runelite.api.events.ChatMessage;
|
import net.runelite.api.events.ChatMessage;
|
||||||
import net.runelite.api.events.FocusChanged;
|
import net.runelite.api.events.FocusChanged;
|
||||||
import net.runelite.api.events.GameTick;
|
import net.runelite.api.events.GameTick;
|
||||||
|
import net.runelite.api.events.GraphicsObjectCreated;
|
||||||
import net.runelite.api.events.HitsplatApplied;
|
import net.runelite.api.events.HitsplatApplied;
|
||||||
import net.runelite.api.events.MenuOpened;
|
import net.runelite.api.events.MenuOpened;
|
||||||
import net.runelite.api.events.MenuOptionClicked;
|
import net.runelite.api.events.MenuOptionClicked;
|
||||||
@@ -488,4 +490,10 @@ public class Hooks
|
|||||||
event.setHitsplat(hitsplat);
|
event.setHitsplat(hitsplat);
|
||||||
eventBus.post(event);
|
eventBus.post(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void onGraphicsObjectCreated(GraphicsObject go, int var1, int var2, int var3, int var4, int var5, int var6, int var7)
|
||||||
|
{
|
||||||
|
GraphicsObjectCreated event = new GraphicsObjectCreated(go);
|
||||||
|
eventBus.post(event);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -39,6 +39,7 @@ import net.runelite.api.Actor;
|
|||||||
import net.runelite.api.Client;
|
import net.runelite.api.Client;
|
||||||
import net.runelite.api.DecorativeObject;
|
import net.runelite.api.DecorativeObject;
|
||||||
import net.runelite.api.GameObject;
|
import net.runelite.api.GameObject;
|
||||||
|
import net.runelite.api.GraphicsObject;
|
||||||
import net.runelite.api.GroundObject;
|
import net.runelite.api.GroundObject;
|
||||||
import net.runelite.api.Item;
|
import net.runelite.api.Item;
|
||||||
import net.runelite.api.ItemLayer;
|
import net.runelite.api.ItemLayer;
|
||||||
@@ -47,6 +48,7 @@ import net.runelite.api.NPCComposition;
|
|||||||
import net.runelite.api.Node;
|
import net.runelite.api.Node;
|
||||||
import net.runelite.api.Perspective;
|
import net.runelite.api.Perspective;
|
||||||
import net.runelite.api.Player;
|
import net.runelite.api.Player;
|
||||||
|
import net.runelite.api.Point;
|
||||||
import net.runelite.api.Projectile;
|
import net.runelite.api.Projectile;
|
||||||
import net.runelite.api.Region;
|
import net.runelite.api.Region;
|
||||||
import net.runelite.api.Tile;
|
import net.runelite.api.Tile;
|
||||||
@@ -124,6 +126,11 @@ public class DevToolsOverlay extends Overlay
|
|||||||
renderProjectiles(graphics);
|
renderProjectiles(graphics);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (plugin.isToggleGraphicsObjects())
|
||||||
|
{
|
||||||
|
renderGraphicsObjects(graphics);
|
||||||
|
}
|
||||||
|
|
||||||
renderWidgets(graphics);
|
renderWidgets(graphics);
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
@@ -385,6 +392,30 @@ public class DevToolsOverlay extends Overlay
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void renderGraphicsObjects(Graphics2D graphics)
|
||||||
|
{
|
||||||
|
List<GraphicsObject> graphicsObjects = client.getGraphicsObjects();
|
||||||
|
|
||||||
|
for (GraphicsObject graphicsObject : graphicsObjects)
|
||||||
|
{
|
||||||
|
LocalPoint lp = graphicsObject.getLocation();
|
||||||
|
Polygon poly = Perspective.getCanvasTilePoly(client, lp);
|
||||||
|
|
||||||
|
if (poly != null)
|
||||||
|
{
|
||||||
|
OverlayUtil.renderPolygon(graphics, poly, Color.MAGENTA);
|
||||||
|
}
|
||||||
|
|
||||||
|
String infoString = "(ID: " + graphicsObject.getId() + ")";
|
||||||
|
Point textLocation = Perspective.getCanvasTextLocation(
|
||||||
|
client, graphics, lp, infoString, 0);
|
||||||
|
if (textLocation != null)
|
||||||
|
{
|
||||||
|
OverlayUtil.renderTextLocation(graphics, textLocation, infoString, Color.WHITE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void renderWidgets(Graphics2D graphics)
|
public void renderWidgets(Graphics2D graphics)
|
||||||
{
|
{
|
||||||
Widget widget = plugin.currentWidget;
|
Widget widget = plugin.currentWidget;
|
||||||
|
|||||||
@@ -196,6 +196,14 @@ public class DevToolsPanel extends PluginPanel
|
|||||||
});
|
});
|
||||||
container.add(lineOfSightBtn);
|
container.add(lineOfSightBtn);
|
||||||
|
|
||||||
|
final JButton graphicsObjectsBtn = new JButton("Graphics objects");
|
||||||
|
graphicsObjectsBtn.addActionListener(e ->
|
||||||
|
{
|
||||||
|
highlightButton(graphicsObjectsBtn);
|
||||||
|
plugin.toggleGraphicsObjects();
|
||||||
|
});
|
||||||
|
container.add(graphicsObjectsBtn);
|
||||||
|
|
||||||
return container;
|
return container;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -94,6 +94,7 @@ public class DevToolsPlugin extends Plugin
|
|||||||
private boolean toggleMapSquares;
|
private boolean toggleMapSquares;
|
||||||
private boolean toggleValidMovement;
|
private boolean toggleValidMovement;
|
||||||
private boolean toggleLineOfSight;
|
private boolean toggleLineOfSight;
|
||||||
|
private boolean toggleGraphicsObjects;
|
||||||
|
|
||||||
Widget currentWidget;
|
Widget currentWidget;
|
||||||
int itemIndex = -1;
|
int itemIndex = -1;
|
||||||
@@ -301,6 +302,11 @@ public class DevToolsPlugin extends Plugin
|
|||||||
toggleLineOfSight = !toggleLineOfSight;
|
toggleLineOfSight = !toggleLineOfSight;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void toggleGraphicsObjects()
|
||||||
|
{
|
||||||
|
toggleGraphicsObjects = !toggleGraphicsObjects;
|
||||||
|
}
|
||||||
|
|
||||||
boolean isTogglePlayers()
|
boolean isTogglePlayers()
|
||||||
{
|
{
|
||||||
return togglePlayers;
|
return togglePlayers;
|
||||||
@@ -370,4 +376,9 @@ public class DevToolsPlugin extends Plugin
|
|||||||
{
|
{
|
||||||
return toggleLineOfSight;
|
return toggleLineOfSight;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boolean isToggleGraphicsObjects()
|
||||||
|
{
|
||||||
|
return toggleGraphicsObjects;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -0,0 +1,41 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2018, Woox <https://github.com/wooxsolo>
|
||||||
|
* 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.mixins;
|
||||||
|
|
||||||
|
import net.runelite.api.coords.LocalPoint;
|
||||||
|
import net.runelite.api.mixins.Inject;
|
||||||
|
import net.runelite.api.mixins.Mixin;
|
||||||
|
import net.runelite.rs.api.RSGraphicsObject;
|
||||||
|
|
||||||
|
@Mixin(RSGraphicsObject.class)
|
||||||
|
public abstract class GraphicsObjectMixin implements RSGraphicsObject
|
||||||
|
{
|
||||||
|
@Override
|
||||||
|
@Inject
|
||||||
|
public LocalPoint getLocation()
|
||||||
|
{
|
||||||
|
return new LocalPoint(this.getX(), this.getY());
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -32,6 +32,7 @@ import net.runelite.api.ChatMessageType;
|
|||||||
import net.runelite.api.ClanMember;
|
import net.runelite.api.ClanMember;
|
||||||
import net.runelite.api.GameState;
|
import net.runelite.api.GameState;
|
||||||
import net.runelite.api.GrandExchangeOffer;
|
import net.runelite.api.GrandExchangeOffer;
|
||||||
|
import net.runelite.api.GraphicsObject;
|
||||||
import net.runelite.api.HintArrowType;
|
import net.runelite.api.HintArrowType;
|
||||||
import net.runelite.api.IndexedSprite;
|
import net.runelite.api.IndexedSprite;
|
||||||
import net.runelite.api.InventoryID;
|
import net.runelite.api.InventoryID;
|
||||||
@@ -480,6 +481,22 @@ public abstract class RSClientMixin implements RSClient
|
|||||||
return projectiles;
|
return projectiles;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public List<GraphicsObject> getGraphicsObjects()
|
||||||
|
{
|
||||||
|
List<GraphicsObject> graphicsObjects = new ArrayList<GraphicsObject>();
|
||||||
|
RSDeque graphicsObjectDeque = this.getGraphicsObjectDeque();
|
||||||
|
Node head = graphicsObjectDeque.getHead();
|
||||||
|
|
||||||
|
for (Node node = head.getNext(); node != head; node = node.getNext())
|
||||||
|
{
|
||||||
|
graphicsObjects.add((GraphicsObject)node);
|
||||||
|
}
|
||||||
|
|
||||||
|
return graphicsObjects;
|
||||||
|
}
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
@Override
|
@Override
|
||||||
public void setModIcons(IndexedSprite[] modIcons)
|
public void setModIcons(IndexedSprite[] modIcons)
|
||||||
|
|||||||
@@ -195,6 +195,9 @@ public interface RSClient extends RSGameEngine, Client
|
|||||||
@Import("projectiles")
|
@Import("projectiles")
|
||||||
RSDeque getProjectilesDeque();
|
RSDeque getProjectilesDeque();
|
||||||
|
|
||||||
|
@Import("graphicsObjectDeque")
|
||||||
|
RSDeque getGraphicsObjectDeque();
|
||||||
|
|
||||||
@Import("username")
|
@Import("username")
|
||||||
@Override
|
@Override
|
||||||
String getUsername();
|
String getUsername();
|
||||||
|
|||||||
@@ -0,0 +1,53 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2018, Woox <https://github.com/wooxsolo>
|
||||||
|
* 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.rs.api;
|
||||||
|
|
||||||
|
import net.runelite.api.GraphicsObject;
|
||||||
|
import net.runelite.mapping.Import;
|
||||||
|
|
||||||
|
public interface RSGraphicsObject extends GraphicsObject, RSRenderable
|
||||||
|
{
|
||||||
|
@Import("id")
|
||||||
|
@Override
|
||||||
|
int getId();
|
||||||
|
|
||||||
|
@Import("x")
|
||||||
|
int getX();
|
||||||
|
|
||||||
|
@Import("y")
|
||||||
|
int getY();
|
||||||
|
|
||||||
|
@Import("startCycle")
|
||||||
|
@Override
|
||||||
|
int getStartCycle();
|
||||||
|
|
||||||
|
@Import("level")
|
||||||
|
@Override
|
||||||
|
int getLevel();
|
||||||
|
|
||||||
|
@Import("height")
|
||||||
|
@Override
|
||||||
|
int getHeight();
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user