Add Angle and Direction
Extend GameObject.getOrientation() to account for object flags, and return an Angle
This commit is contained in:
@@ -25,6 +25,7 @@
|
||||
package net.runelite.api;
|
||||
|
||||
import java.awt.Polygon;
|
||||
import net.runelite.api.coords.Angle;
|
||||
|
||||
/**
|
||||
*
|
||||
@@ -32,8 +33,6 @@ import java.awt.Polygon;
|
||||
*/
|
||||
public interface GameObject extends TileObject
|
||||
{
|
||||
int getFlags();
|
||||
|
||||
/**
|
||||
* Returns the min x,y for this game object
|
||||
*
|
||||
@@ -50,4 +49,6 @@ public interface GameObject extends TileObject
|
||||
Point getRegionMaxLocation();
|
||||
|
||||
Polygon getConvexHull();
|
||||
|
||||
Angle getOrientation();
|
||||
}
|
||||
|
||||
@@ -0,0 +1,69 @@
|
||||
/*
|
||||
* Copyright (c) 2018, Adam <Adam@sigterm.info>
|
||||
* 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.coords;
|
||||
|
||||
import lombok.Value;
|
||||
import static net.runelite.api.coords.Direction.EAST;
|
||||
import static net.runelite.api.coords.Direction.NORTH;
|
||||
import static net.runelite.api.coords.Direction.SOUTH;
|
||||
import static net.runelite.api.coords.Direction.WEST;
|
||||
|
||||
@Value
|
||||
public class Angle
|
||||
{
|
||||
/**
|
||||
* angle, 0-2047.
|
||||
* 0 is south, west is 512, south is 1024, east is 1536s
|
||||
*/
|
||||
private final int angle;
|
||||
|
||||
/**
|
||||
* Get the nearest N/S/E/W direction for this angle
|
||||
* @return
|
||||
*/
|
||||
public Direction getNearestDirection()
|
||||
{
|
||||
int round = angle >>> 9;
|
||||
int up = angle & 256;
|
||||
if (up != 0)
|
||||
{
|
||||
// round up
|
||||
++round;
|
||||
}
|
||||
switch (round & 3)
|
||||
{
|
||||
case 0:
|
||||
return SOUTH;
|
||||
case 1:
|
||||
return WEST;
|
||||
case 2:
|
||||
return NORTH;
|
||||
case 3:
|
||||
return EAST;
|
||||
default:
|
||||
throw new IllegalStateException();
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,33 @@
|
||||
/*
|
||||
* Copyright (c) 2018, Adam <Adam@sigterm.info>
|
||||
* 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.coords;
|
||||
|
||||
public enum Direction
|
||||
{
|
||||
NORTH,
|
||||
SOUTH,
|
||||
EAST,
|
||||
WEST;
|
||||
}
|
||||
@@ -0,0 +1,44 @@
|
||||
/*
|
||||
* Copyright (c) 2018, Adam <Adam@sigterm.info>
|
||||
* 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.coords;
|
||||
|
||||
import static net.runelite.api.coords.Direction.NORTH;
|
||||
import static net.runelite.api.coords.Direction.WEST;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import org.junit.Test;
|
||||
|
||||
public class AngleTest
|
||||
{
|
||||
|
||||
@Test
|
||||
public void getNearestDirection()
|
||||
{
|
||||
Angle angle = new Angle(512 + 10);
|
||||
assertEquals(WEST, angle.getNearestDirection());
|
||||
|
||||
angle = new Angle(512 + 256 + 1);
|
||||
assertEquals(NORTH, angle.getNearestDirection());
|
||||
}
|
||||
}
|
||||
@@ -28,6 +28,7 @@ import java.awt.Polygon;
|
||||
import java.awt.geom.Area;
|
||||
import net.runelite.api.Perspective;
|
||||
import net.runelite.api.Point;
|
||||
import net.runelite.api.coords.Angle;
|
||||
import net.runelite.api.mixins.Inject;
|
||||
import net.runelite.api.mixins.Mixin;
|
||||
import net.runelite.api.mixins.Shadow;
|
||||
@@ -79,7 +80,7 @@ public abstract class RSGameObjectMixin implements RSGameObject
|
||||
@Override
|
||||
public Area getClickbox()
|
||||
{
|
||||
return Perspective.getClickbox(client, getModel(), getOrientation(), getX(), getY());
|
||||
return Perspective.getClickbox(client, getModel(), getRsOrientation(), getX(), getY());
|
||||
}
|
||||
|
||||
@Inject
|
||||
@@ -93,6 +94,15 @@ public abstract class RSGameObjectMixin implements RSGameObject
|
||||
return null;
|
||||
}
|
||||
|
||||
return model.getConvexHull(getX(), getY(), getOrientation());
|
||||
return model.getConvexHull(getX(), getY(), getRsOrientation());
|
||||
}
|
||||
|
||||
@Override
|
||||
@Inject
|
||||
public Angle getOrientation()
|
||||
{
|
||||
int orientation = getRsOrientation();
|
||||
int rotation = (getFlags() >> 6) & 3;
|
||||
return new Angle(rotation * 512 + orientation);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -59,13 +59,12 @@ public interface RSGameObject extends GameObject
|
||||
int getHeight();
|
||||
|
||||
@Import("orientation")
|
||||
int getOrientation();
|
||||
int getRsOrientation();
|
||||
|
||||
@Import("hash")
|
||||
@Override
|
||||
int getHash();
|
||||
|
||||
@Override
|
||||
@Import("flags")
|
||||
int getFlags();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user