Add planes to planeless tile objects
This commit is contained in:
@@ -38,6 +38,8 @@ public interface TileObject
|
|||||||
|
|
||||||
int getY();
|
int getY();
|
||||||
|
|
||||||
|
int getPlane();
|
||||||
|
|
||||||
int getId();
|
int getId();
|
||||||
|
|
||||||
WorldPoint getWorldLocation();
|
WorldPoint getWorldLocation();
|
||||||
|
|||||||
@@ -41,6 +41,23 @@ public abstract class RSDecorativeObjectMixin implements RSDecorativeObject
|
|||||||
@Shadow("clientInstance")
|
@Shadow("clientInstance")
|
||||||
private static RSClient client;
|
private static RSClient client;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
private int decorativeObjectPlane;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public int getPlane()
|
||||||
|
{
|
||||||
|
return decorativeObjectPlane;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public void setPlane(int plane)
|
||||||
|
{
|
||||||
|
this.decorativeObjectPlane = plane;
|
||||||
|
}
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
private Model getModel()
|
private Model getModel()
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -40,6 +40,23 @@ public abstract class RSGroundObjectMixin implements RSGroundObject
|
|||||||
@Shadow("clientInstance")
|
@Shadow("clientInstance")
|
||||||
private static RSClient client;
|
private static RSClient client;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
private int groundObjectPlane;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public int getPlane()
|
||||||
|
{
|
||||||
|
return groundObjectPlane;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public void setPlane(int plane)
|
||||||
|
{
|
||||||
|
this.groundObjectPlane = plane;
|
||||||
|
}
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
private Model getModel()
|
private Model getModel()
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -32,11 +32,27 @@ import net.runelite.rs.api.RSItemLayer;
|
|||||||
@Mixin(RSItemLayer.class)
|
@Mixin(RSItemLayer.class)
|
||||||
public abstract class RSItemLayerMixin implements RSItemLayer
|
public abstract class RSItemLayerMixin implements RSItemLayer
|
||||||
{
|
{
|
||||||
|
@Inject
|
||||||
|
private int itemLayerPlane;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public int getPlane()
|
||||||
|
{
|
||||||
|
return itemLayerPlane;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public void setPlane(int plane)
|
||||||
|
{
|
||||||
|
this.itemLayerPlane = plane;
|
||||||
|
}
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
@Override
|
@Override
|
||||||
public Area getClickbox()
|
public Area getClickbox()
|
||||||
{
|
{
|
||||||
throw new UnsupportedOperationException();
|
throw new UnsupportedOperationException();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -24,11 +24,16 @@
|
|||||||
*/
|
*/
|
||||||
package net.runelite.mixins;
|
package net.runelite.mixins;
|
||||||
|
|
||||||
|
import net.runelite.api.Renderable;
|
||||||
import net.runelite.api.mixins.Copy;
|
import net.runelite.api.mixins.Copy;
|
||||||
import net.runelite.api.mixins.Inject;
|
import net.runelite.api.mixins.Inject;
|
||||||
import net.runelite.api.mixins.Mixin;
|
import net.runelite.api.mixins.Mixin;
|
||||||
import net.runelite.api.mixins.Replace;
|
import net.runelite.api.mixins.Replace;
|
||||||
|
import net.runelite.rs.api.RSDecorativeObject;
|
||||||
|
import net.runelite.rs.api.RSGroundObject;
|
||||||
|
import net.runelite.rs.api.RSItemLayer;
|
||||||
import net.runelite.rs.api.RSRegion;
|
import net.runelite.rs.api.RSRegion;
|
||||||
|
import net.runelite.rs.api.RSWallObject;
|
||||||
|
|
||||||
@Mixin(RSRegion.class)
|
@Mixin(RSRegion.class)
|
||||||
public abstract class RSRegionMixin implements RSRegion
|
public abstract class RSRegionMixin implements RSRegion
|
||||||
@@ -52,4 +57,44 @@ public abstract class RSRegionMixin implements RSRegion
|
|||||||
isDrawingRegion = false;
|
isDrawingRegion = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Copy("addBoundaryDecoration")
|
||||||
|
abstract public void rs$addBoundaryDecoration(int plane, int x, int y, int hash, Renderable var5, Renderable var6, int var7, int var8, int var9, int var10, int var11, int var12);
|
||||||
|
|
||||||
|
@Replace("addBoundaryDecoration")
|
||||||
|
public void rl$addBoundaryDecoration(int plane, int x, int y, int hash, Renderable var5, Renderable var6, int var7, int var8, int var9, int var10, int var11, int var12)
|
||||||
|
{
|
||||||
|
rs$addBoundaryDecoration(plane, x, y, hash, var5, var6, var7, var8, var9, var10, var11, var12);
|
||||||
|
((RSDecorativeObject) getTiles()[plane][x][y].getDecorativeObject()).setPlane(plane);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Copy("addItemPile")
|
||||||
|
abstract public void rs$addItemPile(int plane, int x, int y, int hash, Renderable var5, int var6, Renderable var7, Renderable var8);
|
||||||
|
|
||||||
|
@Replace("addItemPile")
|
||||||
|
public void rl$addItemPile(int plane, int x, int y, int hash, Renderable var5, int var6, Renderable var7, Renderable var8)
|
||||||
|
{
|
||||||
|
rs$addItemPile(plane, x, y, hash, var5, var6, var7, var8);
|
||||||
|
((RSItemLayer) getTiles()[plane][x][y].getItemLayer()).setPlane(plane);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Copy("groundObjectSpawned")
|
||||||
|
abstract public void rs$groundObjectSpawned(int plane, int x, int y, int hash, Renderable var5, int var6, int var7);
|
||||||
|
|
||||||
|
@Replace("groundObjectSpawned")
|
||||||
|
public void rl$groundObjectSpawned(int plane, int x, int y, int hash, Renderable var5, int var6, int var7)
|
||||||
|
{
|
||||||
|
rs$groundObjectSpawned(plane, x, y, hash, var5, var6, var7);
|
||||||
|
((RSGroundObject) getTiles()[plane][x][y].getGroundObject()).setPlane(plane);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Copy("addBoundary")
|
||||||
|
abstract public void rs$addBoundary(int plane, int x, int y, int hash, Renderable var5, Renderable var6, int var7, int var8, int var9, int var10);
|
||||||
|
|
||||||
|
@Replace("addBoundary")
|
||||||
|
public void rl$addBoundary(int plane, int x, int y, int hash, Renderable var5, Renderable var6, int var7, int var8, int var9, int var10)
|
||||||
|
{
|
||||||
|
rs$addBoundary(plane, x, y, hash, var5, var6, var7, var8, var9, var10);
|
||||||
|
((RSWallObject) getTiles()[plane][x][y].getWallObject()).setPlane(plane);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,6 +40,23 @@ public abstract class RSWallObjectMixin implements RSWallObject
|
|||||||
@Shadow("clientInstance")
|
@Shadow("clientInstance")
|
||||||
private static RSClient client;
|
private static RSClient client;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
private int wallPlane;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public int getPlane()
|
||||||
|
{
|
||||||
|
return wallPlane;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public void setPlane(int plane)
|
||||||
|
{
|
||||||
|
this.wallPlane = plane;
|
||||||
|
}
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
private Model getModelA()
|
private Model getModelA()
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -71,7 +71,7 @@ public abstract class TileObjectMixin implements TileObject
|
|||||||
@Inject
|
@Inject
|
||||||
public WorldPoint getWorldLocation()
|
public WorldPoint getWorldLocation()
|
||||||
{
|
{
|
||||||
return WorldPoint.fromLocal(client, getX(), getY(), client.getPlane()); //TODO: use the correct plane
|
return WorldPoint.fromLocal(client, getX(), getY(), getPlane());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -45,4 +45,6 @@ public interface RSDecorativeObject extends DecorativeObject
|
|||||||
|
|
||||||
@Import("renderable1")
|
@Import("renderable1")
|
||||||
Renderable getRenderable();
|
Renderable getRenderable();
|
||||||
|
|
||||||
|
void setPlane(int plane);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -42,4 +42,6 @@ public interface RSGroundObject extends GroundObject
|
|||||||
|
|
||||||
@Import("renderable")
|
@Import("renderable")
|
||||||
Renderable getRenderable();
|
Renderable getRenderable();
|
||||||
|
|
||||||
|
void setPlane(int plane);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -56,4 +56,6 @@ public interface RSItemLayer extends ItemLayer
|
|||||||
@Import("top")
|
@Import("top")
|
||||||
@Override
|
@Override
|
||||||
RSRenderable getTop();
|
RSRenderable getTop();
|
||||||
|
|
||||||
|
void setPlane(int plane);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -59,4 +59,6 @@ public interface RSWallObject extends WallObject
|
|||||||
@Import("config")
|
@Import("config")
|
||||||
@Override
|
@Override
|
||||||
int getConfig();
|
int getConfig();
|
||||||
|
|
||||||
|
void setPlane(int plane);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user