summaryrefslogtreecommitdiffstats
path: root/modules/mono
diff options
context:
space:
mode:
authorRaul Santos <raulsntos@gmail.com>2023-10-03 17:27:43 +0200
committerRaul Santos <raulsntos@gmail.com>2024-08-08 06:31:46 +0200
commit262671c64486ee8515e2e29750225778f152b16d (patch)
tree1b9336e235bd9fae8e9b7043bfd592146603e8cd /modules/mono
parent4bef4d9808848c38c3f285edb300b4f3a843e543 (diff)
downloadredot-engine-262671c64486ee8515e2e29750225778f152b16d.tar.gz
C#: Expose `Transform2D.Determinant()`
Diffstat (limited to 'modules/mono')
-rw-r--r--modules/mono/glue/GodotSharp/GodotSharp/Core/Transform2D.cs17
1 files changed, 9 insertions, 8 deletions
diff --git a/modules/mono/glue/GodotSharp/GodotSharp/Core/Transform2D.cs b/modules/mono/glue/GodotSharp/GodotSharp/Core/Transform2D.cs
index a5fa89d3bf..f943a3049d 100644
--- a/modules/mono/glue/GodotSharp/GodotSharp/Core/Transform2D.cs
+++ b/modules/mono/glue/GodotSharp/GodotSharp/Core/Transform2D.cs
@@ -47,7 +47,7 @@ namespace Godot
{
get
{
- real_t detSign = Mathf.Sign(BasisDeterminant());
+ real_t detSign = Mathf.Sign(Determinant());
return new Vector2(X.Length(), detSign * Y.Length());
}
}
@@ -59,7 +59,7 @@ namespace Godot
{
get
{
- real_t detSign = Mathf.Sign(BasisDeterminant());
+ real_t detSign = Mathf.Sign(Determinant());
return Mathf.Acos(X.Normalized().Dot(detSign * Y.Normalized())) - Mathf.Pi * 0.5f;
}
}
@@ -135,7 +135,7 @@ namespace Godot
/// <returns>The inverse transformation matrix.</returns>
public readonly Transform2D AffineInverse()
{
- real_t det = BasisDeterminant();
+ real_t det = Determinant();
if (det == 0)
throw new InvalidOperationException("Matrix determinant is zero and cannot be inverted.");
@@ -157,15 +157,16 @@ namespace Godot
/// <summary>
/// Returns the determinant of the basis matrix. If the basis is
- /// uniformly scaled, its determinant is the square of the scale.
+ /// uniformly scaled, then its determinant equals the square of the
+ /// scale factor.
///
- /// A negative determinant means the Y scale is negative.
- /// A zero determinant means the basis isn't invertible,
- /// and is usually considered invalid.
+ /// A negative determinant means the basis was flipped, so one part of
+ /// the scale is negative. A zero determinant means the basis isn't
+ /// invertible, and is usually considered invalid.
/// </summary>
/// <returns>The determinant of the basis matrix.</returns>
[MethodImpl(MethodImplOptions.AggressiveInlining)]
- private readonly real_t BasisDeterminant()
+ public readonly real_t Determinant()
{
return (X.X * Y.Y) - (X.Y * Y.X);
}