1693 lines
52 KiB
C#
1693 lines
52 KiB
C#
|
#region License
|
||
|
|
||
|
/* MoonWorks - Game Development Framework
|
||
|
* Copyright 2022 Evan Hemsley
|
||
|
*/
|
||
|
|
||
|
/* Derived from code by Ethan Lee (Copyright 2009-2021).
|
||
|
* Released under the Microsoft Public License.
|
||
|
* See fna.LICENSE for details.
|
||
|
|
||
|
* Derived from code by the Mono.Xna Team (Copyright 2006).
|
||
|
* Released under the MIT License. See monoxna.LICENSE for details.
|
||
|
*/
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Using Statements
|
||
|
using System;
|
||
|
using System.Diagnostics;
|
||
|
using System.Runtime.InteropServices;
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
namespace MoonWorks.Math.Fixed
|
||
|
{
|
||
|
/// <summary>
|
||
|
/// Represents the right-handed 4x4 fixed point matrix, which can store translation, scale and rotation information.
|
||
|
/// This differs from XNA in one major way: projections are modified to give right handed NDC space.
|
||
|
/// </summary>
|
||
|
[Serializable]
|
||
|
[DebuggerDisplay("{DebugDisplayString,nq}")]
|
||
|
[StructLayout(LayoutKind.Sequential)]
|
||
|
public struct Matrix4x4 : IEquatable<Matrix4x4>
|
||
|
{
|
||
|
#region Public Properties
|
||
|
|
||
|
/// <summary>
|
||
|
/// The backward vector formed from the third row M31, M32, M33 elements.
|
||
|
/// </summary>
|
||
|
public Vector3 Backward
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return new Vector3(M31, M32, M33);
|
||
|
}
|
||
|
set
|
||
|
{
|
||
|
M31 = value.X;
|
||
|
M32 = value.Y;
|
||
|
M33 = value.Z;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// The down vector formed from the second row -M21, -M22, -M23 elements.
|
||
|
/// </summary>
|
||
|
public Vector3 Down
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return new Vector3(-M21, -M22, -M23);
|
||
|
}
|
||
|
set
|
||
|
{
|
||
|
M21 = -value.X;
|
||
|
M22 = -value.Y;
|
||
|
M23 = -value.Z;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// The forward vector formed from the third row -M31, -M32, -M33 elements.
|
||
|
/// </summary>
|
||
|
public Vector3 Forward
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return new Vector3(-M31, -M32, -M33);
|
||
|
}
|
||
|
set
|
||
|
{
|
||
|
M31 = -value.X;
|
||
|
M32 = -value.Y;
|
||
|
M33 = -value.Z;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Returns the identity matrix.
|
||
|
/// </summary>
|
||
|
public static Matrix4x4 Identity
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return identity;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// The left vector formed from the first row -M11, -M12, -M13 elements.
|
||
|
/// </summary>
|
||
|
public Vector3 Left
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return new Vector3(-M11, -M12, -M13);
|
||
|
}
|
||
|
set
|
||
|
{
|
||
|
M11 = -value.X;
|
||
|
M12 = -value.Y;
|
||
|
M13 = -value.Z;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// The right vector formed from the first row M11, M12, M13 elements.
|
||
|
/// </summary>
|
||
|
public Vector3 Right
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return new Vector3(M11, M12, M13);
|
||
|
}
|
||
|
set
|
||
|
{
|
||
|
M11 = value.X;
|
||
|
M12 = value.Y;
|
||
|
M13 = value.Z;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Position stored in this matrix.
|
||
|
/// </summary>
|
||
|
public Vector3 Translation
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return new Vector3(M41, M42, M43);
|
||
|
}
|
||
|
set
|
||
|
{
|
||
|
M41 = value.X;
|
||
|
M42 = value.Y;
|
||
|
M43 = value.Z;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// The upper vector formed from the second row M21, M22, M23 elements.
|
||
|
/// </summary>
|
||
|
public Vector3 Up
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return new Vector3(M21, M22, M23);
|
||
|
}
|
||
|
set
|
||
|
{
|
||
|
M21 = value.X;
|
||
|
M22 = value.Y;
|
||
|
M23 = value.Z;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Internal Properties
|
||
|
|
||
|
internal string DebugDisplayString
|
||
|
{
|
||
|
get
|
||
|
{
|
||
|
return string.Concat(
|
||
|
"( ", M11.ToString(), " ",
|
||
|
M12.ToString(), " ",
|
||
|
M13.ToString(), " ",
|
||
|
M14.ToString(), " ) \r\n",
|
||
|
"( ", M21.ToString(), " ",
|
||
|
M22.ToString(), " ",
|
||
|
M23.ToString(), " ",
|
||
|
M24.ToString(), " ) \r\n",
|
||
|
"( ", M31.ToString(), " ",
|
||
|
M32.ToString(), " ",
|
||
|
M33.ToString(), " ",
|
||
|
M34.ToString(), " ) \r\n",
|
||
|
"( ", M41.ToString(), " ",
|
||
|
M42.ToString(), " ",
|
||
|
M43.ToString(), " ",
|
||
|
M44.ToString(), " )"
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Public Fields
|
||
|
|
||
|
/// <summary>
|
||
|
/// A first row and first column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M11;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A first row and second column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M12;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A first row and third column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M13;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A first row and fourth column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M14;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A second row and first column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M21;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A second row and second column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M22;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A second row and third column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M23;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A second row and fourth column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M24;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A third row and first column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M31;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A third row and second column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M32;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A third row and third column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M33;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A third row and fourth column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M34;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A fourth row and first column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M41;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A fourth row and second column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M42;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A fourth row and third column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M43;
|
||
|
|
||
|
/// <summary>
|
||
|
/// A fourth row and fourth column value.
|
||
|
/// </summary>
|
||
|
public Fix64 M44;
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Private Static Variables
|
||
|
|
||
|
private static Matrix4x4 identity = new Matrix4x4(
|
||
|
1, 0, 0, 0,
|
||
|
0, 1, 0, 0,
|
||
|
0, 0, 1, 0,
|
||
|
0, 0, 0, 1
|
||
|
);
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Public Constructors
|
||
|
|
||
|
/// <summary>
|
||
|
/// Constructs a matrix.
|
||
|
/// </summary>
|
||
|
/// <param name="m11">A first row and first column value.</param>
|
||
|
/// <param name="m12">A first row and second column value.</param>
|
||
|
/// <param name="m13">A first row and third column value.</param>
|
||
|
/// <param name="m14">A first row and fourth column value.</param>
|
||
|
/// <param name="m21">A second row and first column value.</param>
|
||
|
/// <param name="m22">A second row and second column value.</param>
|
||
|
/// <param name="m23">A second row and third column value.</param>
|
||
|
/// <param name="m24">A second row and fourth column value.</param>
|
||
|
/// <param name="m31">A third row and first column value.</param>
|
||
|
/// <param name="m32">A third row and second column value.</param>
|
||
|
/// <param name="m33">A third row and third column value.</param>
|
||
|
/// <param name="m34">A third row and fourth column value.</param>
|
||
|
/// <param name="m41">A fourth row and first column value.</param>
|
||
|
/// <param name="m42">A fourth row and second column value.</param>
|
||
|
/// <param name="m43">A fourth row and third column value.</param>
|
||
|
/// <param name="m44">A fourth row and fourth column value.</param>
|
||
|
public Matrix4x4(
|
||
|
Fix64 m11, Fix64 m12, Fix64 m13, Fix64 m14,
|
||
|
Fix64 m21, Fix64 m22, Fix64 m23, Fix64 m24,
|
||
|
Fix64 m31, Fix64 m32, Fix64 m33, Fix64 m34,
|
||
|
Fix64 m41, Fix64 m42, Fix64 m43, Fix64 m44
|
||
|
)
|
||
|
{
|
||
|
M11 = m11;
|
||
|
M12 = m12;
|
||
|
M13 = m13;
|
||
|
M14 = m14;
|
||
|
M21 = m21;
|
||
|
M22 = m22;
|
||
|
M23 = m23;
|
||
|
M24 = m24;
|
||
|
M31 = m31;
|
||
|
M32 = m32;
|
||
|
M33 = m33;
|
||
|
M34 = m34;
|
||
|
M41 = m41;
|
||
|
M42 = m42;
|
||
|
M43 = m43;
|
||
|
M44 = m44;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Constructs a matrix.
|
||
|
/// </summary>
|
||
|
/// <param name="m11">A first row and first column value.</param>
|
||
|
/// <param name="m12">A first row and second column value.</param>
|
||
|
/// <param name="m13">A first row and third column value.</param>
|
||
|
/// <param name="m14">A first row and fourth column value.</param>
|
||
|
/// <param name="m21">A second row and first column value.</param>
|
||
|
/// <param name="m22">A second row and second column value.</param>
|
||
|
/// <param name="m23">A second row and third column value.</param>
|
||
|
/// <param name="m24">A second row and fourth column value.</param>
|
||
|
/// <param name="m31">A third row and first column value.</param>
|
||
|
/// <param name="m32">A third row and second column value.</param>
|
||
|
/// <param name="m33">A third row and third column value.</param>
|
||
|
/// <param name="m34">A third row and fourth column value.</param>
|
||
|
/// <param name="m41">A fourth row and first column value.</param>
|
||
|
/// <param name="m42">A fourth row and second column value.</param>
|
||
|
/// <param name="m43">A fourth row and third column value.</param>
|
||
|
/// <param name="m44">A fourth row and fourth column value.</param>
|
||
|
public Matrix4x4(
|
||
|
int m11, int m12, int m13, int m14,
|
||
|
int m21, int m22, int m23, int m24,
|
||
|
int m31, int m32, int m33, int m34,
|
||
|
int m41, int m42, int m43, int m44
|
||
|
)
|
||
|
{
|
||
|
M11 = new Fix64(m11);
|
||
|
M12 = new Fix64(m12);
|
||
|
M13 = new Fix64(m13);
|
||
|
M14 = new Fix64(m14);
|
||
|
M21 = new Fix64(m21);
|
||
|
M22 = new Fix64(m22);
|
||
|
M23 = new Fix64(m23);
|
||
|
M24 = new Fix64(m24);
|
||
|
M31 = new Fix64(m31);
|
||
|
M32 = new Fix64(m32);
|
||
|
M33 = new Fix64(m33);
|
||
|
M34 = new Fix64(m34);
|
||
|
M41 = new Fix64(m41);
|
||
|
M42 = new Fix64(m42);
|
||
|
M43 = new Fix64(m43);
|
||
|
M44 = new Fix64(m44);
|
||
|
}
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Public Methods
|
||
|
|
||
|
/// <summary>
|
||
|
/// Returns a determinant of this <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <returns>Determinant of this <see cref="Matrix4x4"/></returns>
|
||
|
/// <remarks>See more about determinant here - http://en.wikipedia.org/wiki/Determinant.
|
||
|
/// </remarks>
|
||
|
public Fix64 Determinant()
|
||
|
{
|
||
|
Fix64 num18 = (M33 * M44) - (M34 * M43);
|
||
|
Fix64 num17 = (M32 * M44) - (M34 * M42);
|
||
|
Fix64 num16 = (M32 * M43) - (M33 * M42);
|
||
|
Fix64 num15 = (M31 * M44) - (M34 * M41);
|
||
|
Fix64 num14 = (M31 * M43) - (M33 * M41);
|
||
|
Fix64 num13 = (M31 * M42) - (M32 * M41);
|
||
|
return (
|
||
|
(
|
||
|
(
|
||
|
(M11 * (((M22 * num18) - (M23 * num17)) + (M24 * num16))) -
|
||
|
(M12 * (((M21 * num18) - (M23 * num15)) + (M24 * num14)))
|
||
|
) + (M13 * (((M21 * num17) - (M22 * num15)) + (M24 * num13)))
|
||
|
) - (M14 * (((M21 * num16) - (M22 * num14)) + (M23 * num13)))
|
||
|
);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Compares whether current instance is equal to specified <see cref="Matrix4x4"/> without any tolerance.
|
||
|
/// </summary>
|
||
|
/// <param name="other">The <see cref="Matrix4x4"/> to compare.</param>
|
||
|
/// <returns><c>true</c> if the instances are equal; <c>false</c> otherwise.</returns>
|
||
|
public bool Equals(Matrix4x4 other)
|
||
|
{
|
||
|
return (M11 == other.M11 &&
|
||
|
M12 == other.M12 &&
|
||
|
M13 == other.M13 &&
|
||
|
M14 == other.M14 &&
|
||
|
M21 == other.M21 &&
|
||
|
M22 == other.M22 &&
|
||
|
M23 == other.M23 &&
|
||
|
M24 == other.M24 &&
|
||
|
M31 == other.M31 &&
|
||
|
M32 == other.M32 &&
|
||
|
M33 == other.M33 &&
|
||
|
M34 == other.M34 &&
|
||
|
M41 == other.M41 &&
|
||
|
M42 == other.M42 &&
|
||
|
M43 == other.M43 &&
|
||
|
M44 == other.M44);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Compares whether current instance is equal to specified <see cref="Object"/> without any tolerance.
|
||
|
/// </summary>
|
||
|
/// <param name="obj">The <see cref="Object"/> to compare.</param>
|
||
|
/// <returns><c>true</c> if the instances are equal; <c>false</c> otherwise.</returns>
|
||
|
public override bool Equals(object obj)
|
||
|
{
|
||
|
return (obj is Matrix4x4) && Equals((Matrix4x4) obj);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Gets the hash code of this <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <returns>Hash code of this <see cref="Matrix4x4"/>.</returns>
|
||
|
public override int GetHashCode()
|
||
|
{
|
||
|
return (
|
||
|
M11.GetHashCode() + M12.GetHashCode() + M13.GetHashCode() + M14.GetHashCode() +
|
||
|
M21.GetHashCode() + M22.GetHashCode() + M23.GetHashCode() + M24.GetHashCode() +
|
||
|
M31.GetHashCode() + M32.GetHashCode() + M33.GetHashCode() + M34.GetHashCode() +
|
||
|
M41.GetHashCode() + M42.GetHashCode() + M43.GetHashCode() + M44.GetHashCode()
|
||
|
);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Returns a <see cref="String"/> representation of this <see cref="Matrix4x4"/> in the format:
|
||
|
/// {M11:[<see cref="M11"/>] M12:[<see cref="M12"/>] M13:[<see cref="M13"/>] M14:[<see cref="M14"/>]}
|
||
|
/// {M21:[<see cref="M21"/>] M12:[<see cref="M22"/>] M13:[<see cref="M23"/>] M14:[<see cref="M24"/>]}
|
||
|
/// {M31:[<see cref="M31"/>] M32:[<see cref="M32"/>] M33:[<see cref="M33"/>] M34:[<see cref="M34"/>]}
|
||
|
/// {M41:[<see cref="M41"/>] M42:[<see cref="M42"/>] M43:[<see cref="M43"/>] M44:[<see cref="M44"/>]}
|
||
|
/// </summary>
|
||
|
/// <returns>A <see cref="String"/> representation of this <see cref="Matrix4x4"/>.</returns>
|
||
|
public override string ToString()
|
||
|
{
|
||
|
return (
|
||
|
"{M11:" + M11.ToString() +
|
||
|
" M12:" + M12.ToString() +
|
||
|
" M13:" + M13.ToString() +
|
||
|
" M14:" + M14.ToString() +
|
||
|
"} {M21:" + M21.ToString() +
|
||
|
" M22:" + M22.ToString() +
|
||
|
" M23:" + M23.ToString() +
|
||
|
" M24:" + M24.ToString() +
|
||
|
"} {M31:" + M31.ToString() +
|
||
|
" M32:" + M32.ToString() +
|
||
|
" M33:" + M33.ToString() +
|
||
|
" M34:" + M34.ToString() +
|
||
|
"} {M41:" + M41.ToString() +
|
||
|
" M42:" + M42.ToString() +
|
||
|
" M43:" + M43.ToString() +
|
||
|
" M44:" + M44.ToString() + "}"
|
||
|
);
|
||
|
}
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Public Static Methods
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> which contains sum of two matrixes.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">The first matrix to add.</param>
|
||
|
/// <param name="matrix2">The second matrix to add.</param>
|
||
|
/// <returns>The result of the matrix addition.</returns>
|
||
|
public static Matrix4x4 Add(Matrix4x4 matrix1, Matrix4x4 matrix2)
|
||
|
{
|
||
|
matrix1.M11 += matrix2.M11;
|
||
|
matrix1.M12 += matrix2.M12;
|
||
|
matrix1.M13 += matrix2.M13;
|
||
|
matrix1.M14 += matrix2.M14;
|
||
|
matrix1.M21 += matrix2.M21;
|
||
|
matrix1.M22 += matrix2.M22;
|
||
|
matrix1.M23 += matrix2.M23;
|
||
|
matrix1.M24 += matrix2.M24;
|
||
|
matrix1.M31 += matrix2.M31;
|
||
|
matrix1.M32 += matrix2.M32;
|
||
|
matrix1.M33 += matrix2.M33;
|
||
|
matrix1.M34 += matrix2.M34;
|
||
|
matrix1.M41 += matrix2.M41;
|
||
|
matrix1.M42 += matrix2.M42;
|
||
|
matrix1.M43 += matrix2.M43;
|
||
|
matrix1.M44 += matrix2.M44;
|
||
|
return matrix1;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> which contains sum of two matrixes.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">The first matrix to add.</param>
|
||
|
/// <param name="matrix2">The second matrix to add.</param>
|
||
|
/// <param name="result">The result of the matrix addition as an output parameter.</param>
|
||
|
public static void Add(ref Matrix4x4 matrix1, ref Matrix4x4 matrix2, out Matrix4x4 result)
|
||
|
{
|
||
|
result.M11 = matrix1.M11 + matrix2.M11;
|
||
|
result.M12 = matrix1.M12 + matrix2.M12;
|
||
|
result.M13 = matrix1.M13 + matrix2.M13;
|
||
|
result.M14 = matrix1.M14 + matrix2.M14;
|
||
|
result.M21 = matrix1.M21 + matrix2.M21;
|
||
|
result.M22 = matrix1.M22 + matrix2.M22;
|
||
|
result.M23 = matrix1.M23 + matrix2.M23;
|
||
|
result.M24 = matrix1.M24 + matrix2.M24;
|
||
|
result.M31 = matrix1.M31 + matrix2.M31;
|
||
|
result.M32 = matrix1.M32 + matrix2.M32;
|
||
|
result.M33 = matrix1.M33 + matrix2.M33;
|
||
|
result.M34 = matrix1.M34 + matrix2.M34;
|
||
|
result.M41 = matrix1.M41 + matrix2.M41;
|
||
|
result.M42 = matrix1.M42 + matrix2.M42;
|
||
|
result.M43 = matrix1.M43 + matrix2.M43;
|
||
|
result.M44 = matrix1.M44 + matrix2.M44;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> which contains the rotation moment around specified axis.
|
||
|
/// </summary>
|
||
|
/// <param name="axis">The axis of rotation.</param>
|
||
|
/// <param name="angle">The angle of rotation in radians.</param>
|
||
|
/// <returns>The rotation <see cref="Matrix4x4"/>.</returns>
|
||
|
public static Matrix4x4 CreateFromAxisAngle(Vector3 axis, Fix64 angle)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateFromAxisAngle(ref axis, angle, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> which contains the rotation moment around specified axis.
|
||
|
/// </summary>
|
||
|
/// <param name="axis">The axis of rotation.</param>
|
||
|
/// <param name="angle">The angle of rotation in radians.</param>
|
||
|
/// <param name="result">The rotation <see cref="Matrix4x4"/> as an output parameter.</param>
|
||
|
public static void CreateFromAxisAngle(
|
||
|
ref Vector3 axis,
|
||
|
Fix64 angle,
|
||
|
out Matrix4x4 result
|
||
|
)
|
||
|
{
|
||
|
Fix64 x = axis.X;
|
||
|
Fix64 y = axis.Y;
|
||
|
Fix64 z = axis.Z;
|
||
|
Fix64 num2 = (Fix64) System.Math.Sin((double) angle);
|
||
|
Fix64 num = (Fix64) System.Math.Cos((double) angle);
|
||
|
Fix64 num11 = x * x;
|
||
|
Fix64 num10 = y * y;
|
||
|
Fix64 num9 = z * z;
|
||
|
Fix64 num8 = x * y;
|
||
|
Fix64 num7 = x * z;
|
||
|
Fix64 num6 = y * z;
|
||
|
result.M11 = num11 + (num * (Fix64.One - num11));
|
||
|
result.M12 = (num8 - (num * num8)) + (num2 * z);
|
||
|
result.M13 = (num7 - (num * num7)) - (num2 * y);
|
||
|
result.M14 = Fix64.Zero;
|
||
|
result.M21 = (num8 - (num * num8)) - (num2 * z);
|
||
|
result.M22 = num10 + (num * (Fix64.One - num10));
|
||
|
result.M23 = (num6 - (num * num6)) + (num2 * x);
|
||
|
result.M24 = Fix64.Zero;
|
||
|
result.M31 = (num7 - (num * num7)) + (num2 * y);
|
||
|
result.M32 = (num6 - (num * num6)) - (num2 * x);
|
||
|
result.M33 = num9 + (num * (Fix64.One - num9));
|
||
|
result.M34 = Fix64.Zero;
|
||
|
result.M41 = Fix64.Zero;
|
||
|
result.M42 = Fix64.Zero;
|
||
|
result.M43 = Fix64.Zero;
|
||
|
result.M44 = Fix64.One;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> from a <see cref="FixQuaternion"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="quaternion"><see cref="FixQuaternion"/> of rotation moment.</param>
|
||
|
/// <returns>The rotation <see cref="Matrix4x4"/>.</returns>
|
||
|
public static Matrix4x4 CreateFromQuaternion(Quaternion quaternion)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateFromQuaternion(ref quaternion, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> from a <see cref="FixQuaternion"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="quaternion"><see cref="FixQuaternion"/> of rotation moment.</param>
|
||
|
/// <param name="result">The rotation <see cref="Matrix4x4"/> as an output parameter.</param>
|
||
|
public static void CreateFromQuaternion(ref Quaternion quaternion, out Matrix4x4 result)
|
||
|
{
|
||
|
Fix64 two = new Fix64(2);
|
||
|
Fix64 num9 = quaternion.X * quaternion.X;
|
||
|
Fix64 num8 = quaternion.Y * quaternion.Y;
|
||
|
Fix64 num7 = quaternion.Z * quaternion.Z;
|
||
|
Fix64 num6 = quaternion.X * quaternion.Y;
|
||
|
Fix64 num5 = quaternion.Z * quaternion.W;
|
||
|
Fix64 num4 = quaternion.Z * quaternion.X;
|
||
|
Fix64 num3 = quaternion.Y * quaternion.W;
|
||
|
Fix64 num2 = quaternion.Y * quaternion.Z;
|
||
|
Fix64 num = quaternion.X * quaternion.W;
|
||
|
result.M11 = Fix64.One - (two * (num8 + num7));
|
||
|
result.M12 = two * (num6 + num5);
|
||
|
result.M13 = two * (num4 - num3);
|
||
|
result.M14 = Fix64.Zero;
|
||
|
result.M21 = two * (num6 - num5);
|
||
|
result.M22 = Fix64.One - (two * (num7 + num9));
|
||
|
result.M23 = two * (num2 + num);
|
||
|
result.M24 = Fix64.Zero;
|
||
|
result.M31 = two * (num4 + num3);
|
||
|
result.M32 = two * (num2 - num);
|
||
|
result.M33 = Fix64.One - (two * (num8 + num9));
|
||
|
result.M34 = Fix64.Zero;
|
||
|
result.M41 = Fix64.Zero;
|
||
|
result.M42 = Fix64.Zero;
|
||
|
result.M43 = Fix64.Zero;
|
||
|
result.M44 = Fix64.One;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> from the specified yaw, pitch and roll values.
|
||
|
/// </summary>
|
||
|
/// <param name="yaw">The yaw rotation value in radians.</param>
|
||
|
/// <param name="pitch">The pitch rotation value in radians.</param>
|
||
|
/// <param name="roll">The roll rotation value in radians.</param>
|
||
|
/// <returns>The rotation <see cref="Matrix4x4"/>.</returns>
|
||
|
/// <remarks>For more information about yaw, pitch and roll visit http://en.wikipedia.org/wiki/Euler_angles.
|
||
|
/// </remarks>
|
||
|
public static Matrix4x4 CreateFromYawPitchRoll(Fix64 yaw, Fix64 pitch, Fix64 roll)
|
||
|
{
|
||
|
Matrix4x4 matrix;
|
||
|
CreateFromYawPitchRoll(yaw, pitch, roll, out matrix);
|
||
|
return matrix;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> from the specified yaw, pitch and roll values.
|
||
|
/// </summary>
|
||
|
/// <param name="yaw">The yaw rotation value in radians.</param>
|
||
|
/// <param name="pitch">The pitch rotation value in radians.</param>
|
||
|
/// <param name="roll">The roll rotation value in radians.</param>
|
||
|
/// <param name="result">The rotation <see cref="Matrix4x4"/> as an output parameter.</param>
|
||
|
/// <remarks>For more information about yaw, pitch and roll visit http://en.wikipedia.org/wiki/Euler_angles.
|
||
|
/// </remarks>
|
||
|
public static void CreateFromYawPitchRoll(
|
||
|
Fix64 yaw,
|
||
|
Fix64 pitch,
|
||
|
Fix64 roll,
|
||
|
out Matrix4x4 result
|
||
|
)
|
||
|
{
|
||
|
Quaternion quaternion;
|
||
|
Quaternion.CreateFromYawPitchRoll(yaw, pitch, roll, out quaternion);
|
||
|
CreateFromQuaternion(ref quaternion, out result);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> around X axis.
|
||
|
/// </summary>
|
||
|
/// <param name="radians">Angle in radians.</param>
|
||
|
/// <returns>The rotation <see cref="Matrix4x4"/> around X axis.</returns>
|
||
|
public static Matrix4x4 CreateRotationX(Fix64 radians)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateRotationX(radians, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> around X axis.
|
||
|
/// </summary>
|
||
|
/// <param name="radians">Angle in radians.</param>
|
||
|
/// <param name="result">The rotation <see cref="Matrix4x4"/> around X axis as an output parameter.</param>
|
||
|
public static void CreateRotationX(Fix64 radians, out Matrix4x4 result)
|
||
|
{
|
||
|
result = Matrix4x4.Identity;
|
||
|
|
||
|
Fix64 val1 = Fix64.Cos(radians);
|
||
|
Fix64 val2 = Fix64.Sin(radians);
|
||
|
|
||
|
result.M22 = val1;
|
||
|
result.M23 = val2;
|
||
|
result.M32 = -val2;
|
||
|
result.M33 = val1;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> around Y axis.
|
||
|
/// </summary>
|
||
|
/// <param name="radians">Angle in radians.</param>
|
||
|
/// <returns>The rotation <see cref="Matrix4x4"/> around Y axis.</returns>
|
||
|
public static Matrix4x4 CreateRotationY(Fix64 radians)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateRotationY(radians, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> around Y axis.
|
||
|
/// </summary>
|
||
|
/// <param name="radians">Angle in radians.</param>
|
||
|
/// <param name="result">The rotation <see cref="Matrix4x4"/> around Y axis as an output parameter.</param>
|
||
|
public static void CreateRotationY(Fix64 radians, out Matrix4x4 result)
|
||
|
{
|
||
|
result = Matrix4x4.Identity;
|
||
|
|
||
|
Fix64 val1 = Fix64.Cos(radians);
|
||
|
Fix64 val2 = Fix64.Sin(radians);
|
||
|
|
||
|
result.M11 = val1;
|
||
|
result.M13 = -val2;
|
||
|
result.M31 = val2;
|
||
|
result.M33 = val1;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> around Z axis.
|
||
|
/// </summary>
|
||
|
/// <param name="radians">Angle in radians.</param>
|
||
|
/// <returns>The rotation <see cref="Matrix4x4"/> around Z axis.</returns>
|
||
|
public static Matrix4x4 CreateRotationZ(Fix64 radians)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateRotationZ(radians, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new rotation <see cref="Matrix4x4"/> around Z axis.
|
||
|
/// </summary>
|
||
|
/// <param name="radians">Angle in radians.</param>
|
||
|
/// <param name="result">The rotation <see cref="Matrix4x4"/> around Z axis as an output parameter.</param>
|
||
|
public static void CreateRotationZ(Fix64 radians, out Matrix4x4 result)
|
||
|
{
|
||
|
result = Matrix4x4.Identity;
|
||
|
|
||
|
Fix64 val1 = Fix64.Cos(radians);
|
||
|
Fix64 val2 = Fix64.Sin(radians);
|
||
|
|
||
|
result.M11 = val1;
|
||
|
result.M12 = val2;
|
||
|
result.M21 = -val2;
|
||
|
result.M22 = val1;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new scaling <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="scale">Scale value for all three axises.</param>
|
||
|
/// <returns>The scaling <see cref="Matrix4x4"/>.</returns>
|
||
|
public static Matrix4x4 CreateScale(Fix64 scale)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateScale(scale, scale, scale, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new scaling <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="scale">Scale value for all three axises.</param>
|
||
|
/// <param name="result">The scaling <see cref="Matrix4x4"/> as an output parameter.</param>
|
||
|
public static void CreateScale(Fix64 scale, out Matrix4x4 result)
|
||
|
{
|
||
|
CreateScale(scale, scale, scale, out result);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new scaling <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="xScale">Scale value for X axis.</param>
|
||
|
/// <param name="yScale">Scale value for Y axis.</param>
|
||
|
/// <param name="zScale">Scale value for Z axis.</param>
|
||
|
/// <returns>The scaling <see cref="Matrix4x4"/>.</returns>
|
||
|
public static Matrix4x4 CreateScale(Fix64 xScale, Fix64 yScale, Fix64 zScale)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateScale(xScale, yScale, zScale, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new scaling <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="xScale">Scale value for X axis.</param>
|
||
|
/// <param name="yScale">Scale value for Y axis.</param>
|
||
|
/// <param name="zScale">Scale value for Z axis.</param>
|
||
|
/// <param name="result">The scaling <see cref="Matrix4x4"/> as an output parameter.</param>
|
||
|
public static void CreateScale(
|
||
|
Fix64 xScale,
|
||
|
Fix64 yScale,
|
||
|
Fix64 zScale,
|
||
|
out Matrix4x4 result
|
||
|
)
|
||
|
{
|
||
|
result.M11 = xScale;
|
||
|
result.M12 = Fix64.Zero;
|
||
|
result.M13 = Fix64.Zero;
|
||
|
result.M14 = Fix64.Zero;
|
||
|
result.M21 = Fix64.Zero;
|
||
|
result.M22 = yScale;
|
||
|
result.M23 = Fix64.Zero;
|
||
|
result.M24 = Fix64.Zero;
|
||
|
result.M31 = Fix64.Zero;
|
||
|
result.M32 = Fix64.Zero;
|
||
|
result.M33 = zScale;
|
||
|
result.M34 = Fix64.Zero;
|
||
|
result.M41 = Fix64.Zero;
|
||
|
result.M42 = Fix64.Zero;
|
||
|
result.M43 = Fix64.Zero;
|
||
|
result.M44 = Fix64.One;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new scaling <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="scales"><see cref="FixVector3"/> representing x,y and z scale values.</param>
|
||
|
/// <returns>The scaling <see cref="Matrix4x4"/>.</returns>
|
||
|
public static Matrix4x4 CreateScale(Vector3 scales)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateScale(ref scales, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new scaling <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="scales"><see cref="FixVector3"/> representing x,y and z scale values.</param>
|
||
|
/// <param name="result">The scaling <see cref="Matrix4x4"/> as an output parameter.</param>
|
||
|
public static void CreateScale(ref Vector3 scales, out Matrix4x4 result)
|
||
|
{
|
||
|
result.M11 = scales.X;
|
||
|
result.M12 = Fix64.Zero;
|
||
|
result.M13 = Fix64.Zero;
|
||
|
result.M14 = Fix64.Zero;
|
||
|
result.M21 = Fix64.Zero;
|
||
|
result.M22 = scales.Y;
|
||
|
result.M23 = Fix64.Zero;
|
||
|
result.M24 = Fix64.Zero;
|
||
|
result.M31 = Fix64.Zero;
|
||
|
result.M32 = Fix64.Zero;
|
||
|
result.M33 = scales.Z;
|
||
|
result.M34 = Fix64.Zero;
|
||
|
result.M41 = Fix64.Zero;
|
||
|
result.M42 = Fix64.Zero;
|
||
|
result.M43 = Fix64.Zero;
|
||
|
result.M44 = Fix64.One;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new translation <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="xPosition">X coordinate of translation.</param>
|
||
|
/// <param name="yPosition">Y coordinate of translation.</param>
|
||
|
/// <param name="zPosition">Z coordinate of translation.</param>
|
||
|
/// <returns>The translation <see cref="Matrix4x4"/>.</returns>
|
||
|
public static Matrix4x4 CreateTranslation(
|
||
|
Fix64 xPosition,
|
||
|
Fix64 yPosition,
|
||
|
Fix64 zPosition
|
||
|
)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateTranslation(xPosition, yPosition, zPosition, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new translation <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="position">X,Y and Z coordinates of translation.</param>
|
||
|
/// <param name="result">The translation <see cref="Matrix4x4"/> as an output parameter.</param>
|
||
|
public static void CreateTranslation(ref Vector3 position, out Matrix4x4 result)
|
||
|
{
|
||
|
result.M11 = Fix64.One;
|
||
|
result.M12 = Fix64.Zero;
|
||
|
result.M13 = Fix64.Zero;
|
||
|
result.M14 = Fix64.Zero;
|
||
|
result.M21 = Fix64.Zero;
|
||
|
result.M22 = Fix64.One;
|
||
|
result.M23 = Fix64.Zero;
|
||
|
result.M24 = Fix64.Zero;
|
||
|
result.M31 = Fix64.Zero;
|
||
|
result.M32 = Fix64.Zero;
|
||
|
result.M33 = Fix64.One;
|
||
|
result.M34 = Fix64.Zero;
|
||
|
result.M41 = position.X;
|
||
|
result.M42 = position.Y;
|
||
|
result.M43 = position.Z;
|
||
|
result.M44 = Fix64.One;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new translation <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="position">X,Y and Z coordinates of translation.</param>
|
||
|
/// <returns>The translation <see cref="Matrix4x4"/>.</returns>
|
||
|
public static Matrix4x4 CreateTranslation(Vector3 position)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
CreateTranslation(ref position, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new translation <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="xPosition">X coordinate of translation.</param>
|
||
|
/// <param name="yPosition">Y coordinate of translation.</param>
|
||
|
/// <param name="zPosition">Z coordinate of translation.</param>
|
||
|
/// <param name="result">The translation <see cref="Matrix4x4"/> as an output parameter.</param>
|
||
|
public static void CreateTranslation(
|
||
|
Fix64 xPosition,
|
||
|
Fix64 yPosition,
|
||
|
Fix64 zPosition,
|
||
|
out Matrix4x4 result
|
||
|
)
|
||
|
{
|
||
|
result.M11 = Fix64.One;
|
||
|
result.M12 = Fix64.Zero;
|
||
|
result.M13 = Fix64.Zero;
|
||
|
result.M14 = Fix64.Zero;
|
||
|
result.M21 = Fix64.Zero;
|
||
|
result.M22 = Fix64.One;
|
||
|
result.M23 = Fix64.Zero;
|
||
|
result.M24 = Fix64.Zero;
|
||
|
result.M31 = Fix64.Zero;
|
||
|
result.M32 = Fix64.Zero;
|
||
|
result.M33 = Fix64.One;
|
||
|
result.M34 = Fix64.Zero;
|
||
|
result.M41 = xPosition;
|
||
|
result.M42 = yPosition;
|
||
|
result.M43 = zPosition;
|
||
|
result.M44 = Fix64.One;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new world <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="position">The position vector.</param>
|
||
|
/// <param name="forward">The forward direction vector.</param>
|
||
|
/// <param name="up">The upward direction vector. Usually <see cref="FixVector3.Up"/>.</param>
|
||
|
/// <returns>The world <see cref="Matrix4x4"/>.</returns>
|
||
|
public static Matrix4x4 CreateWorld(Vector3 position, Vector3 forward, Vector3 up)
|
||
|
{
|
||
|
Matrix4x4 ret;
|
||
|
CreateWorld(ref position, ref forward, ref up, out ret);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new world <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="position">The position vector.</param>
|
||
|
/// <param name="forward">The forward direction vector.</param>
|
||
|
/// <param name="up">The upward direction vector. Usually <see cref="FixVector3.Up"/>.</param>
|
||
|
/// <param name="result">The world <see cref="Matrix4x4"/> as an output parameter.</param>
|
||
|
public static void CreateWorld(
|
||
|
ref Vector3 position,
|
||
|
ref Vector3 forward,
|
||
|
ref Vector3 up,
|
||
|
out Matrix4x4 result
|
||
|
)
|
||
|
{
|
||
|
Vector3 x, y, z;
|
||
|
z = Vector3.Normalize(forward);
|
||
|
Vector3.Cross(ref forward, ref up, out x);
|
||
|
Vector3.Cross(ref x, ref forward, out y);
|
||
|
x.Normalize();
|
||
|
y.Normalize();
|
||
|
|
||
|
result = new Matrix4x4();
|
||
|
result.Right = x;
|
||
|
result.Up = y;
|
||
|
result.Forward = z;
|
||
|
result.Translation = position;
|
||
|
result.M44 = Fix64.One;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Divides the elements of a <see cref="Matrix4x4"/> by the elements of another matrix.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="matrix2">Divisor <see cref="Matrix4x4"/>.</param>
|
||
|
/// <returns>The result of dividing the matrix.</returns>
|
||
|
public static Matrix4x4 Divide(Matrix4x4 matrix1, Matrix4x4 matrix2)
|
||
|
{
|
||
|
matrix1.M11 = matrix1.M11 / matrix2.M11;
|
||
|
matrix1.M12 = matrix1.M12 / matrix2.M12;
|
||
|
matrix1.M13 = matrix1.M13 / matrix2.M13;
|
||
|
matrix1.M14 = matrix1.M14 / matrix2.M14;
|
||
|
matrix1.M21 = matrix1.M21 / matrix2.M21;
|
||
|
matrix1.M22 = matrix1.M22 / matrix2.M22;
|
||
|
matrix1.M23 = matrix1.M23 / matrix2.M23;
|
||
|
matrix1.M24 = matrix1.M24 / matrix2.M24;
|
||
|
matrix1.M31 = matrix1.M31 / matrix2.M31;
|
||
|
matrix1.M32 = matrix1.M32 / matrix2.M32;
|
||
|
matrix1.M33 = matrix1.M33 / matrix2.M33;
|
||
|
matrix1.M34 = matrix1.M34 / matrix2.M34;
|
||
|
matrix1.M41 = matrix1.M41 / matrix2.M41;
|
||
|
matrix1.M42 = matrix1.M42 / matrix2.M42;
|
||
|
matrix1.M43 = matrix1.M43 / matrix2.M43;
|
||
|
matrix1.M44 = matrix1.M44 / matrix2.M44;
|
||
|
return matrix1;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Divides the elements of a <see cref="Matrix4x4"/> by the elements of another matrix.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="matrix2">Divisor <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="result">The result of dividing the matrix as an output parameter.</param>
|
||
|
public static void Divide(ref Matrix4x4 matrix1, ref Matrix4x4 matrix2, out Matrix4x4 result)
|
||
|
{
|
||
|
result.M11 = matrix1.M11 / matrix2.M11;
|
||
|
result.M12 = matrix1.M12 / matrix2.M12;
|
||
|
result.M13 = matrix1.M13 / matrix2.M13;
|
||
|
result.M14 = matrix1.M14 / matrix2.M14;
|
||
|
result.M21 = matrix1.M21 / matrix2.M21;
|
||
|
result.M22 = matrix1.M22 / matrix2.M22;
|
||
|
result.M23 = matrix1.M23 / matrix2.M23;
|
||
|
result.M24 = matrix1.M24 / matrix2.M24;
|
||
|
result.M31 = matrix1.M31 / matrix2.M31;
|
||
|
result.M32 = matrix1.M32 / matrix2.M32;
|
||
|
result.M33 = matrix1.M33 / matrix2.M33;
|
||
|
result.M34 = matrix1.M34 / matrix2.M34;
|
||
|
result.M41 = matrix1.M41 / matrix2.M41;
|
||
|
result.M42 = matrix1.M42 / matrix2.M42;
|
||
|
result.M43 = matrix1.M43 / matrix2.M43;
|
||
|
result.M44 = matrix1.M44 / matrix2.M44;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Divides the elements of a <see cref="Matrix4x4"/> by a scalar.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="divider">Divisor scalar.</param>
|
||
|
/// <returns>The result of dividing a matrix by a scalar.</returns>
|
||
|
public static Matrix4x4 Divide(Matrix4x4 matrix1, Fix64 divider)
|
||
|
{
|
||
|
Fix64 num = Fix64.One / divider;
|
||
|
matrix1.M11 = matrix1.M11 * num;
|
||
|
matrix1.M12 = matrix1.M12 * num;
|
||
|
matrix1.M13 = matrix1.M13 * num;
|
||
|
matrix1.M14 = matrix1.M14 * num;
|
||
|
matrix1.M21 = matrix1.M21 * num;
|
||
|
matrix1.M22 = matrix1.M22 * num;
|
||
|
matrix1.M23 = matrix1.M23 * num;
|
||
|
matrix1.M24 = matrix1.M24 * num;
|
||
|
matrix1.M31 = matrix1.M31 * num;
|
||
|
matrix1.M32 = matrix1.M32 * num;
|
||
|
matrix1.M33 = matrix1.M33 * num;
|
||
|
matrix1.M34 = matrix1.M34 * num;
|
||
|
matrix1.M41 = matrix1.M41 * num;
|
||
|
matrix1.M42 = matrix1.M42 * num;
|
||
|
matrix1.M43 = matrix1.M43 * num;
|
||
|
matrix1.M44 = matrix1.M44 * num;
|
||
|
return matrix1;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Divides the elements of a <see cref="Matrix4x4"/> by a scalar.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="divider">Divisor scalar.</param>
|
||
|
/// <param name="result">The result of dividing a matrix by a scalar as an output parameter.</param>
|
||
|
public static void Divide(ref Matrix4x4 matrix1, Fix64 divider, out Matrix4x4 result)
|
||
|
{
|
||
|
Fix64 num = Fix64.One / divider;
|
||
|
result.M11 = matrix1.M11 * num;
|
||
|
result.M12 = matrix1.M12 * num;
|
||
|
result.M13 = matrix1.M13 * num;
|
||
|
result.M14 = matrix1.M14 * num;
|
||
|
result.M21 = matrix1.M21 * num;
|
||
|
result.M22 = matrix1.M22 * num;
|
||
|
result.M23 = matrix1.M23 * num;
|
||
|
result.M24 = matrix1.M24 * num;
|
||
|
result.M31 = matrix1.M31 * num;
|
||
|
result.M32 = matrix1.M32 * num;
|
||
|
result.M33 = matrix1.M33 * num;
|
||
|
result.M34 = matrix1.M34 * num;
|
||
|
result.M41 = matrix1.M41 * num;
|
||
|
result.M42 = matrix1.M42 * num;
|
||
|
result.M43 = matrix1.M43 * num;
|
||
|
result.M44 = matrix1.M44 * num;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> that contains a multiplication of two matrix.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="matrix2">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <returns>Result of the matrix multiplication.</returns>
|
||
|
public static Matrix4x4 Multiply(
|
||
|
Matrix4x4 matrix1,
|
||
|
Matrix4x4 matrix2
|
||
|
)
|
||
|
{
|
||
|
Fix64 m11 = (
|
||
|
(matrix1.M11 * matrix2.M11) +
|
||
|
(matrix1.M12 * matrix2.M21) +
|
||
|
(matrix1.M13 * matrix2.M31) +
|
||
|
(matrix1.M14 * matrix2.M41)
|
||
|
);
|
||
|
Fix64 m12 = (
|
||
|
(matrix1.M11 * matrix2.M12) +
|
||
|
(matrix1.M12 * matrix2.M22) +
|
||
|
(matrix1.M13 * matrix2.M32) +
|
||
|
(matrix1.M14 * matrix2.M42)
|
||
|
);
|
||
|
Fix64 m13 = (
|
||
|
(matrix1.M11 * matrix2.M13) +
|
||
|
(matrix1.M12 * matrix2.M23) +
|
||
|
(matrix1.M13 * matrix2.M33) +
|
||
|
(matrix1.M14 * matrix2.M43)
|
||
|
);
|
||
|
Fix64 m14 = (
|
||
|
(matrix1.M11 * matrix2.M14) +
|
||
|
(matrix1.M12 * matrix2.M24) +
|
||
|
(matrix1.M13 * matrix2.M34) +
|
||
|
(matrix1.M14 * matrix2.M44)
|
||
|
);
|
||
|
Fix64 m21 = (
|
||
|
(matrix1.M21 * matrix2.M11) +
|
||
|
(matrix1.M22 * matrix2.M21) +
|
||
|
(matrix1.M23 * matrix2.M31) +
|
||
|
(matrix1.M24 * matrix2.M41)
|
||
|
);
|
||
|
Fix64 m22 = (
|
||
|
(matrix1.M21 * matrix2.M12) +
|
||
|
(matrix1.M22 * matrix2.M22) +
|
||
|
(matrix1.M23 * matrix2.M32) +
|
||
|
(matrix1.M24 * matrix2.M42)
|
||
|
);
|
||
|
Fix64 m23 = (
|
||
|
(matrix1.M21 * matrix2.M13) +
|
||
|
(matrix1.M22 * matrix2.M23) +
|
||
|
(matrix1.M23 * matrix2.M33) +
|
||
|
(matrix1.M24 * matrix2.M43)
|
||
|
);
|
||
|
Fix64 m24 = (
|
||
|
(matrix1.M21 * matrix2.M14) +
|
||
|
(matrix1.M22 * matrix2.M24) +
|
||
|
(matrix1.M23 * matrix2.M34) +
|
||
|
(matrix1.M24 * matrix2.M44)
|
||
|
);
|
||
|
Fix64 m31 = (
|
||
|
(matrix1.M31 * matrix2.M11) +
|
||
|
(matrix1.M32 * matrix2.M21) +
|
||
|
(matrix1.M33 * matrix2.M31) +
|
||
|
(matrix1.M34 * matrix2.M41)
|
||
|
);
|
||
|
Fix64 m32 = (
|
||
|
(matrix1.M31 * matrix2.M12) +
|
||
|
(matrix1.M32 * matrix2.M22) +
|
||
|
(matrix1.M33 * matrix2.M32) +
|
||
|
(matrix1.M34 * matrix2.M42)
|
||
|
);
|
||
|
Fix64 m33 = (
|
||
|
(matrix1.M31 * matrix2.M13) +
|
||
|
(matrix1.M32 * matrix2.M23) +
|
||
|
(matrix1.M33 * matrix2.M33) +
|
||
|
(matrix1.M34 * matrix2.M43)
|
||
|
);
|
||
|
Fix64 m34 = (
|
||
|
(matrix1.M31 * matrix2.M14) +
|
||
|
(matrix1.M32 * matrix2.M24) +
|
||
|
(matrix1.M33 * matrix2.M34) +
|
||
|
(matrix1.M34 * matrix2.M44)
|
||
|
);
|
||
|
Fix64 m41 = (
|
||
|
(matrix1.M41 * matrix2.M11) +
|
||
|
(matrix1.M42 * matrix2.M21) +
|
||
|
(matrix1.M43 * matrix2.M31) +
|
||
|
(matrix1.M44 * matrix2.M41)
|
||
|
);
|
||
|
Fix64 m42 = (
|
||
|
(matrix1.M41 * matrix2.M12) +
|
||
|
(matrix1.M42 * matrix2.M22) +
|
||
|
(matrix1.M43 * matrix2.M32) +
|
||
|
(matrix1.M44 * matrix2.M42)
|
||
|
);
|
||
|
Fix64 m43 = (
|
||
|
(matrix1.M41 * matrix2.M13) +
|
||
|
(matrix1.M42 * matrix2.M23) +
|
||
|
(matrix1.M43 * matrix2.M33) +
|
||
|
(matrix1.M44 * matrix2.M43)
|
||
|
);
|
||
|
Fix64 m44 = (
|
||
|
(matrix1.M41 * matrix2.M14) +
|
||
|
(matrix1.M42 * matrix2.M24) +
|
||
|
(matrix1.M43 * matrix2.M34) +
|
||
|
(matrix1.M44 * matrix2.M44)
|
||
|
);
|
||
|
matrix1.M11 = m11;
|
||
|
matrix1.M12 = m12;
|
||
|
matrix1.M13 = m13;
|
||
|
matrix1.M14 = m14;
|
||
|
matrix1.M21 = m21;
|
||
|
matrix1.M22 = m22;
|
||
|
matrix1.M23 = m23;
|
||
|
matrix1.M24 = m24;
|
||
|
matrix1.M31 = m31;
|
||
|
matrix1.M32 = m32;
|
||
|
matrix1.M33 = m33;
|
||
|
matrix1.M34 = m34;
|
||
|
matrix1.M41 = m41;
|
||
|
matrix1.M42 = m42;
|
||
|
matrix1.M43 = m43;
|
||
|
matrix1.M44 = m44;
|
||
|
return matrix1;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> that contains a multiplication of two matrix.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="matrix2">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="result">Result of the matrix multiplication as an output parameter.</param>
|
||
|
public static void Multiply(ref Matrix4x4 matrix1, ref Matrix4x4 matrix2, out Matrix4x4 result)
|
||
|
{
|
||
|
Fix64 m11 = (
|
||
|
(matrix1.M11 * matrix2.M11) +
|
||
|
(matrix1.M12 * matrix2.M21) +
|
||
|
(matrix1.M13 * matrix2.M31) +
|
||
|
(matrix1.M14 * matrix2.M41)
|
||
|
);
|
||
|
Fix64 m12 = (
|
||
|
(matrix1.M11 * matrix2.M12) +
|
||
|
(matrix1.M12 * matrix2.M22) +
|
||
|
(matrix1.M13 * matrix2.M32) +
|
||
|
(matrix1.M14 * matrix2.M42)
|
||
|
);
|
||
|
Fix64 m13 = (
|
||
|
(matrix1.M11 * matrix2.M13) +
|
||
|
(matrix1.M12 * matrix2.M23) +
|
||
|
(matrix1.M13 * matrix2.M33) +
|
||
|
(matrix1.M14 * matrix2.M43)
|
||
|
);
|
||
|
Fix64 m14 = (
|
||
|
(matrix1.M11 * matrix2.M14) +
|
||
|
(matrix1.M12 * matrix2.M24) +
|
||
|
(matrix1.M13 * matrix2.M34) +
|
||
|
(matrix1.M14 * matrix2.M44)
|
||
|
);
|
||
|
Fix64 m21 = (
|
||
|
(matrix1.M21 * matrix2.M11) +
|
||
|
(matrix1.M22 * matrix2.M21) +
|
||
|
(matrix1.M23 * matrix2.M31) +
|
||
|
(matrix1.M24 * matrix2.M41)
|
||
|
);
|
||
|
Fix64 m22 = (
|
||
|
(matrix1.M21 * matrix2.M12) +
|
||
|
(matrix1.M22 * matrix2.M22) +
|
||
|
(matrix1.M23 * matrix2.M32) +
|
||
|
(matrix1.M24 * matrix2.M42)
|
||
|
);
|
||
|
Fix64 m23 = (
|
||
|
(matrix1.M21 * matrix2.M13) +
|
||
|
(matrix1.M22 * matrix2.M23) +
|
||
|
(matrix1.M23 * matrix2.M33) +
|
||
|
(matrix1.M24 * matrix2.M43)
|
||
|
);
|
||
|
Fix64 m24 = (
|
||
|
(matrix1.M21 * matrix2.M14) +
|
||
|
(matrix1.M22 * matrix2.M24) +
|
||
|
(matrix1.M23 * matrix2.M34) +
|
||
|
(matrix1.M24 * matrix2.M44)
|
||
|
);
|
||
|
Fix64 m31 = (
|
||
|
(matrix1.M31 * matrix2.M11) +
|
||
|
(matrix1.M32 * matrix2.M21) +
|
||
|
(matrix1.M33 * matrix2.M31) +
|
||
|
(matrix1.M34 * matrix2.M41)
|
||
|
);
|
||
|
Fix64 m32 = (
|
||
|
(matrix1.M31 * matrix2.M12) +
|
||
|
(matrix1.M32 * matrix2.M22) +
|
||
|
(matrix1.M33 * matrix2.M32) +
|
||
|
(matrix1.M34 * matrix2.M42)
|
||
|
);
|
||
|
Fix64 m33 = (
|
||
|
(matrix1.M31 * matrix2.M13) +
|
||
|
(matrix1.M32 * matrix2.M23) +
|
||
|
(matrix1.M33 * matrix2.M33) +
|
||
|
(matrix1.M34 * matrix2.M43)
|
||
|
);
|
||
|
Fix64 m34 = (
|
||
|
(matrix1.M31 * matrix2.M14) +
|
||
|
(matrix1.M32 * matrix2.M24) +
|
||
|
(matrix1.M33 * matrix2.M34) +
|
||
|
(matrix1.M34 * matrix2.M44)
|
||
|
);
|
||
|
Fix64 m41 = (
|
||
|
(matrix1.M41 * matrix2.M11) +
|
||
|
(matrix1.M42 * matrix2.M21) +
|
||
|
(matrix1.M43 * matrix2.M31) +
|
||
|
(matrix1.M44 * matrix2.M41)
|
||
|
);
|
||
|
Fix64 m42 = (
|
||
|
(matrix1.M41 * matrix2.M12) +
|
||
|
(matrix1.M42 * matrix2.M22) +
|
||
|
(matrix1.M43 * matrix2.M32) +
|
||
|
(matrix1.M44 * matrix2.M42)
|
||
|
);
|
||
|
Fix64 m43 = (
|
||
|
(matrix1.M41 * matrix2.M13) +
|
||
|
(matrix1.M42 * matrix2.M23) +
|
||
|
(matrix1.M43 * matrix2.M33) +
|
||
|
(matrix1.M44 * matrix2.M43)
|
||
|
);
|
||
|
Fix64 m44 = (
|
||
|
(matrix1.M41 * matrix2.M14) +
|
||
|
(matrix1.M42 * matrix2.M24) +
|
||
|
(matrix1.M43 * matrix2.M34) +
|
||
|
(matrix1.M44 * matrix2.M44)
|
||
|
);
|
||
|
result.M11 = m11;
|
||
|
result.M12 = m12;
|
||
|
result.M13 = m13;
|
||
|
result.M14 = m14;
|
||
|
result.M21 = m21;
|
||
|
result.M22 = m22;
|
||
|
result.M23 = m23;
|
||
|
result.M24 = m24;
|
||
|
result.M31 = m31;
|
||
|
result.M32 = m32;
|
||
|
result.M33 = m33;
|
||
|
result.M34 = m34;
|
||
|
result.M41 = m41;
|
||
|
result.M42 = m42;
|
||
|
result.M43 = m43;
|
||
|
result.M44 = m44;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> that contains a multiplication of <see cref="Matrix4x4"/> and a scalar.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="scaleFactor">Scalar value.</param>
|
||
|
/// <returns>Result of the matrix multiplication with a scalar.</returns>
|
||
|
public static Matrix4x4 Multiply(Matrix4x4 matrix1, Fix64 scaleFactor)
|
||
|
{
|
||
|
matrix1.M11 *= scaleFactor;
|
||
|
matrix1.M12 *= scaleFactor;
|
||
|
matrix1.M13 *= scaleFactor;
|
||
|
matrix1.M14 *= scaleFactor;
|
||
|
matrix1.M21 *= scaleFactor;
|
||
|
matrix1.M22 *= scaleFactor;
|
||
|
matrix1.M23 *= scaleFactor;
|
||
|
matrix1.M24 *= scaleFactor;
|
||
|
matrix1.M31 *= scaleFactor;
|
||
|
matrix1.M32 *= scaleFactor;
|
||
|
matrix1.M33 *= scaleFactor;
|
||
|
matrix1.M34 *= scaleFactor;
|
||
|
matrix1.M41 *= scaleFactor;
|
||
|
matrix1.M42 *= scaleFactor;
|
||
|
matrix1.M43 *= scaleFactor;
|
||
|
matrix1.M44 *= scaleFactor;
|
||
|
return matrix1;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> that contains a multiplication of <see cref="Matrix4x4"/> and a scalar.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="scaleFactor">Scalar value.</param>
|
||
|
/// <param name="result">Result of the matrix multiplication with a scalar as an output parameter.</param>
|
||
|
public static void Multiply(ref Matrix4x4 matrix1, Fix64 scaleFactor, out Matrix4x4 result)
|
||
|
{
|
||
|
result.M11 = matrix1.M11 * scaleFactor;
|
||
|
result.M12 = matrix1.M12 * scaleFactor;
|
||
|
result.M13 = matrix1.M13 * scaleFactor;
|
||
|
result.M14 = matrix1.M14 * scaleFactor;
|
||
|
result.M21 = matrix1.M21 * scaleFactor;
|
||
|
result.M22 = matrix1.M22 * scaleFactor;
|
||
|
result.M23 = matrix1.M23 * scaleFactor;
|
||
|
result.M24 = matrix1.M24 * scaleFactor;
|
||
|
result.M31 = matrix1.M31 * scaleFactor;
|
||
|
result.M32 = matrix1.M32 * scaleFactor;
|
||
|
result.M33 = matrix1.M33 * scaleFactor;
|
||
|
result.M34 = matrix1.M34 * scaleFactor;
|
||
|
result.M41 = matrix1.M41 * scaleFactor;
|
||
|
result.M42 = matrix1.M42 * scaleFactor;
|
||
|
result.M43 = matrix1.M43 * scaleFactor;
|
||
|
result.M44 = matrix1.M44 * scaleFactor;
|
||
|
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Returns a matrix with the all values negated.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <returns>Result of the matrix negation.</returns>
|
||
|
public static Matrix4x4 Negate(Matrix4x4 matrix)
|
||
|
{
|
||
|
matrix.M11 = -matrix.M11;
|
||
|
matrix.M12 = -matrix.M12;
|
||
|
matrix.M13 = -matrix.M13;
|
||
|
matrix.M14 = -matrix.M14;
|
||
|
matrix.M21 = -matrix.M21;
|
||
|
matrix.M22 = -matrix.M22;
|
||
|
matrix.M23 = -matrix.M23;
|
||
|
matrix.M24 = -matrix.M24;
|
||
|
matrix.M31 = -matrix.M31;
|
||
|
matrix.M32 = -matrix.M32;
|
||
|
matrix.M33 = -matrix.M33;
|
||
|
matrix.M34 = -matrix.M34;
|
||
|
matrix.M41 = -matrix.M41;
|
||
|
matrix.M42 = -matrix.M42;
|
||
|
matrix.M43 = -matrix.M43;
|
||
|
matrix.M44 = -matrix.M44;
|
||
|
return matrix;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Returns a matrix with the all values negated.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix">Source <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="result">Result of the matrix negation as an output parameter.</param>
|
||
|
public static void Negate(ref Matrix4x4 matrix, out Matrix4x4 result)
|
||
|
{
|
||
|
result.M11 = -matrix.M11;
|
||
|
result.M12 = -matrix.M12;
|
||
|
result.M13 = -matrix.M13;
|
||
|
result.M14 = -matrix.M14;
|
||
|
result.M21 = -matrix.M21;
|
||
|
result.M22 = -matrix.M22;
|
||
|
result.M23 = -matrix.M23;
|
||
|
result.M24 = -matrix.M24;
|
||
|
result.M31 = -matrix.M31;
|
||
|
result.M32 = -matrix.M32;
|
||
|
result.M33 = -matrix.M33;
|
||
|
result.M34 = -matrix.M34;
|
||
|
result.M41 = -matrix.M41;
|
||
|
result.M42 = -matrix.M42;
|
||
|
result.M43 = -matrix.M43;
|
||
|
result.M44 = -matrix.M44;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> that contains subtraction of one matrix from another.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">The first <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="matrix2">The second <see cref="Matrix4x4"/>.</param>
|
||
|
/// <returns>The result of the matrix subtraction.</returns>
|
||
|
public static Matrix4x4 Subtract(Matrix4x4 matrix1, Matrix4x4 matrix2)
|
||
|
{
|
||
|
matrix1.M11 -= matrix2.M11;
|
||
|
matrix1.M12 -= matrix2.M12;
|
||
|
matrix1.M13 -= matrix2.M13;
|
||
|
matrix1.M14 -= matrix2.M14;
|
||
|
matrix1.M21 -= matrix2.M21;
|
||
|
matrix1.M22 -= matrix2.M22;
|
||
|
matrix1.M23 -= matrix2.M23;
|
||
|
matrix1.M24 -= matrix2.M24;
|
||
|
matrix1.M31 -= matrix2.M31;
|
||
|
matrix1.M32 -= matrix2.M32;
|
||
|
matrix1.M33 -= matrix2.M33;
|
||
|
matrix1.M34 -= matrix2.M34;
|
||
|
matrix1.M41 -= matrix2.M41;
|
||
|
matrix1.M42 -= matrix2.M42;
|
||
|
matrix1.M43 -= matrix2.M43;
|
||
|
matrix1.M44 -= matrix2.M44;
|
||
|
return matrix1;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Creates a new <see cref="Matrix4x4"/> that contains subtraction of one matrix from another.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">The first <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="matrix2">The second <see cref="Matrix4x4"/>.</param>
|
||
|
/// <param name="result">The result of the matrix subtraction as an output parameter.</param>
|
||
|
public static void Subtract(ref Matrix4x4 matrix1, ref Matrix4x4 matrix2, out Matrix4x4 result)
|
||
|
{
|
||
|
result.M11 = matrix1.M11 - matrix2.M11;
|
||
|
result.M12 = matrix1.M12 - matrix2.M12;
|
||
|
result.M13 = matrix1.M13 - matrix2.M13;
|
||
|
result.M14 = matrix1.M14 - matrix2.M14;
|
||
|
result.M21 = matrix1.M21 - matrix2.M21;
|
||
|
result.M22 = matrix1.M22 - matrix2.M22;
|
||
|
result.M23 = matrix1.M23 - matrix2.M23;
|
||
|
result.M24 = matrix1.M24 - matrix2.M24;
|
||
|
result.M31 = matrix1.M31 - matrix2.M31;
|
||
|
result.M32 = matrix1.M32 - matrix2.M32;
|
||
|
result.M33 = matrix1.M33 - matrix2.M33;
|
||
|
result.M34 = matrix1.M34 - matrix2.M34;
|
||
|
result.M41 = matrix1.M41 - matrix2.M41;
|
||
|
result.M42 = matrix1.M42 - matrix2.M42;
|
||
|
result.M43 = matrix1.M43 - matrix2.M43;
|
||
|
result.M44 = matrix1.M44 - matrix2.M44;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Swap the matrix rows and columns.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix">The matrix for transposing operation.</param>
|
||
|
/// <returns>The new <see cref="Matrix4x4"/> which contains the transposing result.</returns>
|
||
|
public static Matrix4x4 Transpose(Matrix4x4 matrix)
|
||
|
{
|
||
|
Matrix4x4 ret;
|
||
|
Transpose(ref matrix, out ret);
|
||
|
return ret;
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Swap the matrix rows and columns.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix">The matrix for transposing operation.</param>
|
||
|
/// <param name="result">The new <see cref="Matrix4x4"/> which contains the transposing result as an output parameter.</param>
|
||
|
public static void Transpose(ref Matrix4x4 matrix, out Matrix4x4 result)
|
||
|
{
|
||
|
Matrix4x4 ret;
|
||
|
|
||
|
ret.M11 = matrix.M11;
|
||
|
ret.M12 = matrix.M21;
|
||
|
ret.M13 = matrix.M31;
|
||
|
ret.M14 = matrix.M41;
|
||
|
|
||
|
ret.M21 = matrix.M12;
|
||
|
ret.M22 = matrix.M22;
|
||
|
ret.M23 = matrix.M32;
|
||
|
ret.M24 = matrix.M42;
|
||
|
|
||
|
ret.M31 = matrix.M13;
|
||
|
ret.M32 = matrix.M23;
|
||
|
ret.M33 = matrix.M33;
|
||
|
ret.M34 = matrix.M43;
|
||
|
|
||
|
ret.M41 = matrix.M14;
|
||
|
ret.M42 = matrix.M24;
|
||
|
ret.M43 = matrix.M34;
|
||
|
ret.M44 = matrix.M44;
|
||
|
|
||
|
result = ret;
|
||
|
}
|
||
|
|
||
|
public static Matrix4x4 Transform(Matrix4x4 value, Quaternion rotation)
|
||
|
{
|
||
|
Matrix4x4 result;
|
||
|
Transform(ref value, ref rotation, out result);
|
||
|
return result;
|
||
|
}
|
||
|
|
||
|
public static void Transform(
|
||
|
ref Matrix4x4 value,
|
||
|
ref Quaternion rotation,
|
||
|
out Matrix4x4 result
|
||
|
)
|
||
|
{
|
||
|
Matrix4x4 rotMatrix = CreateFromQuaternion(rotation);
|
||
|
Multiply(ref value, ref rotMatrix, out result);
|
||
|
}
|
||
|
|
||
|
#endregion
|
||
|
|
||
|
#region Public Static Operator Overloads
|
||
|
|
||
|
/// <summary>
|
||
|
/// Adds two matrixes.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/> on the left of the add sign.</param>
|
||
|
/// <param name="matrix2">Source <see cref="Matrix4x4"/> on the right of the add sign.</param>
|
||
|
/// <returns>Sum of the matrixes.</returns>
|
||
|
public static Matrix4x4 operator +(Matrix4x4 matrix1, Matrix4x4 matrix2)
|
||
|
{
|
||
|
return Matrix4x4.Add(matrix1, matrix2);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Divides the elements of a <see cref="Matrix4x4"/> by the elements of another <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/> on the left of the div sign.</param>
|
||
|
/// <param name="matrix2">Divisor <see cref="Matrix4x4"/> on the right of the div sign.</param>
|
||
|
/// <returns>The result of dividing the matrixes.</returns>
|
||
|
public static Matrix4x4 operator /(Matrix4x4 matrix1, Matrix4x4 matrix2)
|
||
|
{
|
||
|
return Matrix4x4.Divide(matrix1, matrix2);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Divides the elements of a <see cref="Matrix4x4"/> by a scalar.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix">Source <see cref="Matrix4x4"/> on the left of the div sign.</param>
|
||
|
/// <param name="divider">Divisor scalar on the right of the div sign.</param>
|
||
|
/// <returns>The result of dividing a matrix by a scalar.</returns>
|
||
|
public static Matrix4x4 operator /(Matrix4x4 matrix, Fix64 divider)
|
||
|
{
|
||
|
return Matrix4x4.Divide(matrix, divider);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Compares whether two <see cref="Matrix4x4"/> instances are equal without any tolerance.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/> on the left of the equal sign.</param>
|
||
|
/// <param name="matrix2">Source <see cref="Matrix4x4"/> on the right of the equal sign.</param>
|
||
|
/// <returns><c>true</c> if the instances are equal; <c>false</c> otherwise.</returns>
|
||
|
public static bool operator ==(Matrix4x4 matrix1, Matrix4x4 matrix2)
|
||
|
{
|
||
|
return matrix1.Equals(matrix2);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Compares whether two <see cref="Matrix4x4"/> instances are not equal without any tolerance.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/> on the left of the not equal sign.</param>
|
||
|
/// <param name="matrix2">Source <see cref="Matrix4x4"/> on the right of the not equal sign.</param>
|
||
|
/// <returns><c>true</c> if the instances are not equal; <c>false</c> otherwise.</returns>
|
||
|
public static bool operator !=(Matrix4x4 matrix1, Matrix4x4 matrix2)
|
||
|
{
|
||
|
return !matrix1.Equals(matrix2);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Multiplies two matrixes.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/> on the left of the mul sign.</param>
|
||
|
/// <param name="matrix2">Source <see cref="Matrix4x4"/> on the right of the mul sign.</param>
|
||
|
/// <returns>Result of the matrix multiplication.</returns>
|
||
|
/// <remarks>
|
||
|
/// Using matrix multiplication algorithm - see http://en.wikipedia.org/wiki/Matrix_multiplication.
|
||
|
/// </remarks>
|
||
|
public static Matrix4x4 operator *(Matrix4x4 matrix1, Matrix4x4 matrix2)
|
||
|
{
|
||
|
return Multiply(matrix1, matrix2);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Multiplies the elements of matrix by a scalar.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix">Source <see cref="Matrix4x4"/> on the left of the mul sign.</param>
|
||
|
/// <param name="scaleFactor">Scalar value on the right of the mul sign.</param>
|
||
|
/// <returns>Result of the matrix multiplication with a scalar.</returns>
|
||
|
public static Matrix4x4 operator *(Matrix4x4 matrix, Fix64 scaleFactor)
|
||
|
{
|
||
|
return Multiply(matrix, scaleFactor);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Subtracts the values of one <see cref="Matrix4x4"/> from another <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix1">Source <see cref="Matrix4x4"/> on the left of the sub sign.</param>
|
||
|
/// <param name="matrix2">Source <see cref="Matrix4x4"/> on the right of the sub sign.</param>
|
||
|
/// <returns>Result of the matrix subtraction.</returns>
|
||
|
public static Matrix4x4 operator -(Matrix4x4 matrix1, Matrix4x4 matrix2)
|
||
|
{
|
||
|
return Subtract(matrix1, matrix2);
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Inverts values in the specified <see cref="Matrix4x4"/>.
|
||
|
/// </summary>
|
||
|
/// <param name="matrix">Source <see cref="Matrix4x4"/> on the right of the sub sign.</param>
|
||
|
/// <returns>Result of the inversion.</returns>
|
||
|
public static Matrix4x4 operator -(Matrix4x4 matrix)
|
||
|
{
|
||
|
return Negate(matrix);
|
||
|
}
|
||
|
|
||
|
#endregion
|
||
|
}
|
||
|
}
|