-
Notifications
You must be signed in to change notification settings - Fork 102
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Obsolete Point3D/GameLocation (#472)
Mitigate jerky movement when pathing is activated
- Loading branch information
Showing
353 changed files
with
4,392 additions
and
6,803 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
using System; | ||
|
||
namespace DOL.GS.Geometry; | ||
|
||
public struct Angle | ||
{ | ||
private const int STEPS_TO_CIRCUMVOLUTION = 360 * 4096; | ||
private const int HEADING_TO_STEPS = STEPS_TO_CIRCUMVOLUTION / 4096; | ||
private const int DEGREE_TO_STEPS = STEPS_TO_CIRCUMVOLUTION / 360; | ||
private const double RADIANS_TO_STEPS = STEPS_TO_CIRCUMVOLUTION / 2 / Math.PI; | ||
|
||
private int steps; | ||
|
||
///<remarks>for internal use only</remarks> | ||
private static Angle Steps(int steps) | ||
{ | ||
steps %= STEPS_TO_CIRCUMVOLUTION; | ||
if (steps < 0) steps += STEPS_TO_CIRCUMVOLUTION; | ||
return new() { steps = steps }; | ||
} | ||
|
||
public static Angle Heading(int heading) | ||
=> Steps(heading * HEADING_TO_STEPS); | ||
|
||
public static Angle Degrees(int degrees) | ||
=> Steps(degrees * DEGREE_TO_STEPS); | ||
|
||
public static Angle Radians(double radians) | ||
=> Steps((int)Math.Round(radians * RADIANS_TO_STEPS)); | ||
|
||
public double InRadians => steps / RADIANS_TO_STEPS; | ||
public ushort InDegrees => (ushort)(steps / DEGREE_TO_STEPS); | ||
public ushort InHeading => (ushort)(steps / HEADING_TO_STEPS); | ||
|
||
public override bool Equals(object obj) | ||
{ | ||
if (obj is Angle angle) return angle.steps == steps; | ||
return false; | ||
} | ||
|
||
public override int GetHashCode() | ||
=> base.GetHashCode(); | ||
|
||
public override string ToString() | ||
=> steps.ToString(); | ||
|
||
public static bool operator ==(Angle a, Angle b) | ||
=> a.Equals(b); | ||
|
||
public static bool operator !=(Angle a, Angle b) | ||
=> !a.Equals(b); | ||
|
||
public static Angle operator +(Angle a, Angle b) | ||
=> Steps(a.steps + b.steps); | ||
|
||
public static Angle operator -(Angle a, Angle b) | ||
=> Steps(a.steps - b.steps); | ||
|
||
public static readonly Angle Zero = new() { steps = 0 }; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
namespace DOL.GS.Geometry; | ||
|
||
public struct Coordinate | ||
{ | ||
private Vector coordinate { get; init; } | ||
|
||
public int X => coordinate.X; | ||
public int Y => coordinate.Y; | ||
public int Z => coordinate.Z; | ||
|
||
public static Coordinate Create(int x = 0, int y = 0, int z = 0) | ||
=> new() { coordinate = Vector.Create(x, y, z) }; | ||
|
||
public Coordinate With(int? x = null, int? y = null, int? z = null) | ||
=> new() { coordinate = Vector.Create(x ?? X, y ?? Y, z ?? Z) }; | ||
|
||
public double DistanceTo(Position pos, bool ignoreZ = false) | ||
=> DistanceTo(pos.Coordinate, ignoreZ); | ||
|
||
public double DistanceTo(Coordinate loc, bool ignoreZ = false) | ||
{ | ||
if (Equals(Nowhere) || loc.Equals(Nowhere)) return double.PositiveInfinity; | ||
|
||
if (ignoreZ) return (loc - this).Length2D; | ||
else return (loc - this).Length; | ||
} | ||
|
||
public Angle GetOrientationTo(Coordinate loc) | ||
=> (loc - this).Orientation; | ||
|
||
public static Coordinate operator +(Coordinate loc, Vector v) | ||
=> new() { coordinate = loc.coordinate + v }; | ||
|
||
public static Coordinate operator -(Coordinate loc, Vector v) | ||
=> new() { coordinate = loc.coordinate - v }; | ||
|
||
public static Vector operator -(Coordinate locA, Coordinate locB) | ||
=> Vector.Create(x: locA.X - locB.X, y: locA.Y - locB.Y, z: locA.Z - locB.Z); | ||
|
||
public static bool operator ==(Coordinate a, Coordinate b) | ||
=> a.Equals(b); | ||
|
||
public static bool operator !=(Coordinate a, Coordinate b) | ||
=> !a.Equals(b); | ||
|
||
public override bool Equals(object obj) | ||
{ | ||
if (obj is Coordinate loc) | ||
{ | ||
return X == loc.X && Y == loc.Y && Z == loc.Z; | ||
} | ||
return false; | ||
} | ||
|
||
public override int GetHashCode() | ||
=> base.GetHashCode(); | ||
|
||
public override string ToString() | ||
=> $"{X}, {Y}, {Z}"; | ||
|
||
public readonly static Coordinate Nowhere = Create(-1, -1, -1); | ||
public readonly static Coordinate Zero = Create(0, 0, 0); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
using System; | ||
|
||
namespace DOL.GS.Geometry; | ||
|
||
public static class CoordinateTransitionExtensions | ||
{ | ||
[Obsolete("This extension is transitional and going to be removed.")] | ||
public static Point3D ToPoint3D(this Coordinate coordinate) | ||
=> new Point3D(coordinate.X, coordinate.Y, coordinate.Z); | ||
|
||
[Obsolete("This extension is transitional and going to be removed.")] | ||
public static Coordinate ToCoordinate(this IPoint3D point) | ||
=> Coordinate.Create(point.X, point.Y, point.Z); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,45 @@ | ||
using DOL.Database; | ||
|
||
namespace DOL.GS.Geometry; | ||
|
||
public static class DataObjectPositionExtensions | ||
{ | ||
public static Position GetPosition(this Mob mob) | ||
=> Position.Create(mob.Region, mob.X, mob.Y, mob.Z, Angle.Heading(mob.Heading)); | ||
|
||
public static Position GetPosition(this Teleport teleport) | ||
=> Position.Create((ushort)teleport.RegionID, teleport.X, teleport.Y, teleport.Z, Angle.Heading(teleport.Heading)); | ||
|
||
public static Position GetSourcePosition(this ZonePoint zonePoint) | ||
=> Position.Create(zonePoint.SourceRegion, zonePoint.SourceX, zonePoint.SourceY, zonePoint.SourceZ); | ||
|
||
public static Position GetTargetPosition(this ZonePoint zonePoint) | ||
=> Position.Create(zonePoint.TargetRegion, zonePoint.TargetX, zonePoint.TargetY, zonePoint.TargetZ, Angle.Heading(zonePoint.TargetHeading)); | ||
|
||
public static Position GetPosition(this DOLCharacters dolc) | ||
=> Position.Create((ushort)dolc.Region, dolc.Xpos, dolc.Ypos, dolc.Zpos, Angle.Heading(dolc.Direction)); | ||
|
||
public static void SetPosition(this DOLCharacters dolc, Position pos) | ||
{ | ||
dolc.Region = pos.RegionID; | ||
dolc.Xpos = pos.X; | ||
dolc.Ypos = pos.Y; | ||
dolc.Zpos = pos.Z; | ||
dolc.Direction = pos.Orientation.InHeading; | ||
} | ||
|
||
public static Position GetBindPosition(this DOLCharacters dolc) | ||
=> Position.Create((ushort)dolc.BindRegion, dolc.BindXpos, dolc.BindYpos, dolc.BindZpos, Angle.Heading(dolc.BindHeading)); | ||
|
||
public static Position GetPosition(this DBKeep dbKeep) | ||
=> Position.Create(dbKeep.Region, dbKeep.X, dbKeep.Y, dbKeep.Z, Angle.Degrees(dbKeep.Heading)); | ||
|
||
public static void SetPosition(this DBKeep dbKeep, Position pos) | ||
{ | ||
dbKeep.Region = pos.RegionID; | ||
dbKeep.X = pos.X; | ||
dbKeep.Y = pos.Y; | ||
dbKeep.Z = pos.Z; | ||
dbKeep.Heading = (ushort)pos.Orientation.InDegrees; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
using System; | ||
using System.Linq; | ||
|
||
namespace DOL.GS.Geometry; | ||
|
||
public class LinePath | ||
{ | ||
private Coordinate[] wayPoints = Array.Empty<Coordinate>(); | ||
private int indexCounter = 0; | ||
|
||
public static LinePath Create(Coordinate[] wayPoints) | ||
=> new LinePath() { wayPoints = wayPoints }; | ||
|
||
public Coordinate Start => wayPoints.Length == 0 ? Coordinate.Nowhere : wayPoints.First(); | ||
|
||
public Coordinate End => wayPoints.Length == 0 ? Coordinate.Nowhere : wayPoints.Last(); | ||
|
||
public void SelectNextWayPoint() => indexCounter++; | ||
|
||
public Coordinate CurrentWayPoint => (indexCounter < PointCount - 1) ? wayPoints[indexCounter] : Coordinate.Nowhere; | ||
|
||
public int PointCount => wayPoints.Length; | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
using System; | ||
|
||
namespace DOL.GS.Geometry; | ||
|
||
public class Motion | ||
{ | ||
public static Motion Create(Position start, Coordinate destination, short withSpeed) | ||
=> new Motion() { Start = start, Destination = destination, Speed = withSpeed }; | ||
|
||
public int StartTimeInMilliSeconds { get; } = Environment.TickCount; | ||
public Position Start { get; init; } = Position.Nowhere; | ||
public Coordinate Destination { get; init; } = Coordinate.Nowhere; | ||
public short Speed { get; init; } = 0; | ||
|
||
public Position CurrentPosition | ||
=> GetPositonAfter(Environment.TickCount - StartTimeInMilliSeconds); | ||
public double FullDistance => Destination.DistanceTo(Start, ignoreZ: true); | ||
public double RemainingDistance => Destination.DistanceTo(CurrentPosition, ignoreZ: true); | ||
|
||
public Position GetPositonAfter(int elapsedTimeInMilliSeconds) | ||
{ | ||
if (Speed == 0 || Start.Coordinate == Destination) return Start; | ||
|
||
var distanceTravelled = Speed * elapsedTimeInMilliSeconds * 0.001; | ||
if (Destination == Coordinate.Nowhere) return Start + Vector.Create(Start.Orientation, distanceTravelled); | ||
|
||
var movementVector = Destination - Start.Coordinate; | ||
if (distanceTravelled > FullDistance) return Position.Create(Start.RegionID, Destination, movementVector.Orientation); | ||
|
||
return Start.With(movementVector.Orientation) + movementVector * (distanceTravelled / FullDistance); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,82 @@ | ||
namespace DOL.GS.Geometry; | ||
|
||
public struct Position | ||
{ | ||
public ushort RegionID { get; init; } = 0; | ||
public Coordinate Coordinate { get; init; } = Coordinate.Zero; | ||
public Angle Orientation { get; init; } = Angle.Zero; | ||
|
||
public int X => Coordinate.X; | ||
public int Y => Coordinate.Y; | ||
public int Z => Coordinate.Z; | ||
|
||
public Region Region => WorldMgr.GetRegion(RegionID); | ||
|
||
public Position() { } | ||
|
||
public static Position Create(ushort regionID, int x, int y, int z, ushort heading) | ||
=> new() { RegionID = regionID, Coordinate = Coordinate.Create(x, y, z), Orientation = Angle.Heading(heading) }; | ||
|
||
public static Position Create(ushort regionID, int x = 0, int y = 0, int z = 0, Angle? orientation = null) | ||
=> new() { RegionID = regionID, Coordinate = Coordinate.Create(x, y, z), Orientation = orientation ?? Angle.Zero }; | ||
|
||
public static Position CreateInZone(ushort zoneID, int x = 0, int y = 0, int z = 0, ushort heading = 0) | ||
{ | ||
var zone = WorldMgr.GetZone(zoneID); | ||
return Create(zone.ZoneRegion.ID, x + zone.Offset.X, y + zone.Offset.Y, z + zone.Offset.Z, heading); | ||
} | ||
|
||
public static Position Create(ushort regionID, Coordinate coordinate, ushort heading = 0) | ||
=> new() { RegionID = regionID, Coordinate = coordinate, Orientation = Angle.Heading(heading) }; | ||
|
||
public static Position Create(ushort regionID, Coordinate coordinate, Angle orientation) | ||
=> new() { RegionID = regionID, Coordinate = coordinate, Orientation = orientation }; | ||
|
||
public Position With(ushort? regionID = null, int? x = null, int? y = null, int? z = null, ushort? heading = null) | ||
{ | ||
var newOrientation = heading != null ? Angle.Heading((ushort)heading) : Orientation; | ||
var newRegionID = regionID ?? RegionID; | ||
return Create(newRegionID, Coordinate.With(x, y, z), newOrientation); | ||
} | ||
|
||
public Position With(Coordinate coordinate) | ||
=> Create(RegionID, coordinate, Orientation); | ||
|
||
public Position With(Angle orientation) | ||
=> Create(RegionID, Coordinate, orientation); | ||
|
||
public Position TurnedAround() | ||
=> With(orientation: Orientation + Angle.Degrees(180)); | ||
|
||
public static Position operator +(Position a, Vector b) | ||
=> a.With(coordinate: a.Coordinate + b); | ||
|
||
public static Position operator -(Position a, Vector b) | ||
=> a.With(coordinate: a.Coordinate - b); | ||
|
||
public static bool operator ==(Position a, Position b) | ||
=> a.Equals(b); | ||
|
||
public static bool operator !=(Position a, Position b) | ||
=> !a.Equals(b); | ||
|
||
public override bool Equals(object obj) | ||
{ | ||
if (obj is Position otherPos) | ||
{ | ||
return otherPos.RegionID == RegionID | ||
&& otherPos.Coordinate.Equals(Coordinate) | ||
&& otherPos.Orientation == Orientation; | ||
} | ||
return false; | ||
} | ||
|
||
public override int GetHashCode() | ||
=> base.GetHashCode(); | ||
|
||
public override string ToString() | ||
=> $"({Coordinate}, {Orientation.InHeading})"; | ||
|
||
public readonly static Position Nowhere = Create(regionID: ushort.MaxValue, Coordinate.Nowhere, Angle.Zero); | ||
public readonly static Position Zero = new(); | ||
} |
Oops, something went wrong.