Skip to content

Commit

Permalink
Removed RcVecUtils.Subtract(RcVec3f i, float[] verts, int j)
Browse files Browse the repository at this point in the history
  • Loading branch information
ikpil committed Jun 7, 2024
1 parent b18845a commit ebab0a1
Show file tree
Hide file tree
Showing 3 changed files with 10 additions and 21 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).
### Removed
- Removed RcVecUtils.Dot()
- Removed RcVecUtils.Scale()
- Removed RcVecUtils.Subtract(RcVec3f i, float[] verts, int j)

### Special Thanks
- [@Doprez](https://github.com/Doprez)
Expand Down
12 changes: 0 additions & 12 deletions src/DotRecast.Core/Numerics/RcVecUtils.cs
Original file line number Diff line number Diff line change
Expand Up @@ -84,18 +84,6 @@ public static RcVec3f Subtract(float[] verts, int i, int j)
);
}


[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static RcVec3f Subtract(RcVec3f i, float[] verts, int j)
{
return new RcVec3f(
i.X - verts[j],
i.Y - verts[j + 1],
i.Z - verts[j + 2]
);
}


[MethodImpl(MethodImplOptions.AggressiveInlining)]
public static void Cross(float[] dest, float[] v1, float[] v2)
{
Expand Down
18 changes: 9 additions & 9 deletions src/DotRecast.Recast/RcMeshDetails.cs
Original file line number Diff line number Diff line change
Expand Up @@ -183,11 +183,11 @@ private static bool CircumCircle(float[] verts, int p1, int p2, int p3, ref RcVe
return false;
}

private static float DistPtTri(RcVec3f p, float[] verts, int a, int b, int c)
private static float DistPtTri(RcVec3f p, RcVec3f a, RcVec3f b, RcVec3f c)
{
var v0 = RcVecUtils.Subtract(verts, c, a);
var v1 = RcVecUtils.Subtract(verts, b, a);
var v2 = RcVecUtils.Subtract(p, verts, a);
var v0 = c - a;
var v1 = b - a;
var v2 = p - a;

float dot00 = Vdot2(v0, v0);
float dot01 = Vdot2(v0, v1);
Expand All @@ -204,7 +204,7 @@ private static float DistPtTri(RcVec3f p, float[] verts, int a, int b, int c)
const float EPS = 1e-4f;
if (u >= -EPS && v >= -EPS && (u + v) <= 1 + EPS)
{
float y = verts[a + 1] + v0.Y * u + v1.Y * v;
float y = a.Y + v0.Y * u + v1.Y * v;
return MathF.Abs(y - p.Y);
}

Expand Down Expand Up @@ -303,10 +303,10 @@ private static float DistToTriMesh(RcVec3f p, float[] verts, int nverts, List<in
float dmin = float.MaxValue;
for (int i = 0; i < ntris; ++i)
{
int va = tris[i * 4 + 0] * 3;
int vb = tris[i * 4 + 1] * 3;
int vc = tris[i * 4 + 2] * 3;
float d = DistPtTri(p, verts, va, vb, vc);
RcVec3f va = RcVecUtils.Create(verts, tris[i * 4 + 0] * 3);
RcVec3f vb = RcVecUtils.Create(verts, tris[i * 4 + 1] * 3);
RcVec3f vc = RcVecUtils.Create(verts, tris[i * 4 + 2] * 3);
float d = DistPtTri(p, va, vb, vc);
if (d < dmin)
{
dmin = d;
Expand Down

0 comments on commit ebab0a1

Please sign in to comment.