mirror of
https://github.com/CookiePLMonster/SilentPatch.git
synced 2025-01-01 08:43:01 +05:00
Updated Maths.h
This commit is contained in:
parent
5f6ad2157d
commit
9b75302ba5
2 changed files with 47 additions and 14 deletions
|
@ -86,7 +86,7 @@ public:
|
||||||
inline CSimpleTransform& GetTransform()
|
inline CSimpleTransform& GetTransform()
|
||||||
{ return m_transform; }
|
{ return m_transform; }
|
||||||
inline float GetHeading()
|
inline float GetHeading()
|
||||||
{ return m_pCoords ? atan2(-m_pCoords->GetUp()->x, m_pCoords->GetUp()->y) : m_transform.m_heading; }
|
{ return m_pCoords ? atan2(-m_pCoords->GetUp().x, m_pCoords->GetUp().y) : m_transform.m_heading; }
|
||||||
|
|
||||||
inline void SetCoords(const CVector& pos)
|
inline void SetCoords(const CVector& pos)
|
||||||
{ if ( m_pCoords ) { m_pCoords->matrix.pos.x = pos.x; m_pCoords->matrix.pos.y = pos.y; m_pCoords->matrix.pos.z = pos.z; }
|
{ if ( m_pCoords ) { m_pCoords->matrix.pos.x = pos.x; m_pCoords->matrix.pos.y = pos.y; m_pCoords->matrix.pos.z = pos.z; }
|
||||||
|
|
|
@ -113,7 +113,7 @@ public:
|
||||||
{}
|
{}
|
||||||
|
|
||||||
inline CMatrix(RwMatrix* pMatrix, bool bHasMatrix=false)
|
inline CMatrix(RwMatrix* pMatrix, bool bHasMatrix=false)
|
||||||
: pMatrix(nullptr)
|
: CMatrix()
|
||||||
{ Attach(pMatrix, bHasMatrix); }
|
{ Attach(pMatrix, bHasMatrix); }
|
||||||
|
|
||||||
inline CMatrix(const CMatrix& theMatrix)
|
inline CMatrix(const CMatrix& theMatrix)
|
||||||
|
@ -121,6 +121,7 @@ public:
|
||||||
{}
|
{}
|
||||||
|
|
||||||
inline CMatrix(const CVector& vecRight, const CVector& vecUp, const CVector& vecAt, const CVector& vecPos)
|
inline CMatrix(const CVector& vecRight, const CVector& vecUp, const CVector& vecAt, const CVector& vecPos)
|
||||||
|
: CMatrix()
|
||||||
{
|
{
|
||||||
matrix.right.x = vecRight.x;
|
matrix.right.x = vecRight.x;
|
||||||
matrix.right.y = vecRight.y;
|
matrix.right.y = vecRight.y;
|
||||||
|
@ -143,6 +144,29 @@ public:
|
||||||
{ if ( haveRwMatrix && pMatrix )
|
{ if ( haveRwMatrix && pMatrix )
|
||||||
RwMatrixDestroy(pMatrix); }
|
RwMatrixDestroy(pMatrix); }
|
||||||
|
|
||||||
|
inline CMatrix& operator*=(const CMatrix& right)
|
||||||
|
{
|
||||||
|
CVector vright(this->matrix.right.x * right.matrix.right.x + this->matrix.right.y * right.matrix.up.x + this->matrix.right.z * right.matrix.at.x + right.matrix.pos.x,
|
||||||
|
this->matrix.right.x * right.matrix.right.y + this->matrix.right.y * right.matrix.up.y + this->matrix.right.z * right.matrix.at.y + right.matrix.pos.y,
|
||||||
|
this->matrix.right.x * right.matrix.right.z + this->matrix.right.y * right.matrix.up.z + this->matrix.right.z * right.matrix.at.z + right.matrix.pos.z);
|
||||||
|
CVector vup(this->matrix.up.x * right.matrix.right.x + this->matrix.up.y * right.matrix.up.x + this->matrix.up.z * right.matrix.at.x + right.matrix.pos.x,
|
||||||
|
this->matrix.up.x * right.matrix.right.y + this->matrix.up.y * right.matrix.up.y + this->matrix.up.z * right.matrix.at.y + right.matrix.pos.y,
|
||||||
|
this->matrix.up.x * right.matrix.right.z + this->matrix.up.y * right.matrix.up.z + this->matrix.up.z * right.matrix.at.z + right.matrix.pos.z);
|
||||||
|
CVector vat(this->matrix.at.x * right.matrix.right.x + this->matrix.at.y * right.matrix.up.x + this->matrix.at.z * right.matrix.at.x + right.matrix.pos.x,
|
||||||
|
this->matrix.at.x * right.matrix.right.y + this->matrix.at.y * right.matrix.up.y + this->matrix.at.z * right.matrix.at.y + right.matrix.pos.y,
|
||||||
|
this->matrix.at.x * right.matrix.right.z + this->matrix.at.y * right.matrix.up.z + this->matrix.at.z * right.matrix.at.z + right.matrix.pos.z);
|
||||||
|
CVector vpos(this->matrix.pos.x * right.matrix.right.x + this->matrix.pos.y * right.matrix.up.x + this->matrix.pos.z * right.matrix.at.x + right.matrix.pos.x,
|
||||||
|
this->matrix.pos.x * right.matrix.right.y + this->matrix.pos.y * right.matrix.up.y + this->matrix.pos.z * right.matrix.at.y + right.matrix.pos.y,
|
||||||
|
this->matrix.pos.x * right.matrix.right.z + this->matrix.pos.y * right.matrix.up.z + this->matrix.pos.z * right.matrix.at.z + right.matrix.pos.z);
|
||||||
|
|
||||||
|
GetRight() = vright;
|
||||||
|
GetUp() = vup;
|
||||||
|
GetAt() = vat;
|
||||||
|
GetPos() = vpos;
|
||||||
|
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
friend inline CMatrix operator*(const CMatrix& Rot1, const CMatrix& Rot2)
|
friend inline CMatrix operator*(const CMatrix& Rot1, const CMatrix& Rot2)
|
||||||
{ return CMatrix( CVector(Rot1.matrix.right.x * Rot2.matrix.right.x + Rot1.matrix.right.y * Rot2.matrix.up.x + Rot1.matrix.right.z * Rot2.matrix.at.x + Rot2.matrix.pos.x,
|
{ return CMatrix( CVector(Rot1.matrix.right.x * Rot2.matrix.right.x + Rot1.matrix.right.y * Rot2.matrix.up.x + Rot1.matrix.right.z * Rot2.matrix.at.x + Rot2.matrix.pos.x,
|
||||||
Rot1.matrix.right.x * Rot2.matrix.right.y + Rot1.matrix.right.y * Rot2.matrix.up.y + Rot1.matrix.right.z * Rot2.matrix.at.y + Rot2.matrix.pos.y,
|
Rot1.matrix.right.x * Rot2.matrix.right.y + Rot1.matrix.right.y * Rot2.matrix.up.y + Rot1.matrix.right.z * Rot2.matrix.at.y + Rot2.matrix.pos.y,
|
||||||
|
@ -162,14 +186,23 @@ public:
|
||||||
matrix.matrix.up.y * vec.y + matrix.matrix.right.y * vec.x + matrix.matrix.at.y * vec.z + matrix.matrix.pos.y,
|
matrix.matrix.up.y * vec.y + matrix.matrix.right.y * vec.x + matrix.matrix.at.y * vec.z + matrix.matrix.pos.y,
|
||||||
matrix.matrix.up.z * vec.y + matrix.matrix.right.z * vec.x + matrix.matrix.at.z * vec.z + matrix.matrix.pos.z); };
|
matrix.matrix.up.z * vec.y + matrix.matrix.right.z * vec.x + matrix.matrix.at.z * vec.z + matrix.matrix.pos.z); };
|
||||||
|
|
||||||
inline CVector* GetRight()
|
inline CVector& GetRight()
|
||||||
{ return reinterpret_cast<CVector*>(&matrix.right); }
|
{ return *reinterpret_cast<CVector*>(&matrix.right); }
|
||||||
inline CVector* GetUp()
|
inline CVector& GetUp()
|
||||||
{ return reinterpret_cast<CVector*>(&matrix.up); }
|
{ return *reinterpret_cast<CVector*>(&matrix.up); }
|
||||||
inline CVector* GetAt()
|
inline CVector& GetAt()
|
||||||
{ return reinterpret_cast<CVector*>(&matrix.at); }
|
{ return *reinterpret_cast<CVector*>(&matrix.at); }
|
||||||
inline CVector* GetPos()
|
inline CVector& GetPos()
|
||||||
{ return reinterpret_cast<CVector*>(&matrix.pos); }
|
{ return *reinterpret_cast<CVector*>(&matrix.pos); }
|
||||||
|
|
||||||
|
inline const CVector& GetRight() const
|
||||||
|
{ return *reinterpret_cast<const CVector*>(&matrix.right); }
|
||||||
|
inline const CVector& GetUp() const
|
||||||
|
{ return *reinterpret_cast<const CVector*>(&matrix.up); }
|
||||||
|
inline const CVector& GetAt() const
|
||||||
|
{ return *reinterpret_cast<const CVector*>(&matrix.at); }
|
||||||
|
inline const CVector& GetPos() const
|
||||||
|
{ return *reinterpret_cast<const CVector*>(&matrix.pos); }
|
||||||
|
|
||||||
inline void SetTranslateOnly(float fX, float fY, float fZ)
|
inline void SetTranslateOnly(float fX, float fY, float fZ)
|
||||||
{ matrix.pos.x = fX; matrix.pos.y = fY; matrix.pos.z = fZ; }
|
{ matrix.pos.x = fX; matrix.pos.y = fY; matrix.pos.z = fZ; }
|
||||||
|
@ -208,28 +241,28 @@ public:
|
||||||
{
|
{
|
||||||
CMatrix RotationMatrix;
|
CMatrix RotationMatrix;
|
||||||
RotationMatrix.SetRotateX(fAngle);
|
RotationMatrix.SetRotateX(fAngle);
|
||||||
*this = *this * RotationMatrix;
|
*this *= RotationMatrix;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void RotateY(float fAngle)
|
inline void RotateY(float fAngle)
|
||||||
{
|
{
|
||||||
CMatrix RotationMatrix;
|
CMatrix RotationMatrix;
|
||||||
RotationMatrix.SetRotateY(fAngle);
|
RotationMatrix.SetRotateY(fAngle);
|
||||||
*this = *this * RotationMatrix;
|
*this *= RotationMatrix;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void RotateZ(float fAngle)
|
inline void RotateZ(float fAngle)
|
||||||
{
|
{
|
||||||
CMatrix RotationMatrix;
|
CMatrix RotationMatrix;
|
||||||
RotationMatrix.SetRotateZ(fAngle);
|
RotationMatrix.SetRotateZ(fAngle);
|
||||||
*this = *this * RotationMatrix;
|
*this *= RotationMatrix;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Rotate(float fAngleX, float fAngleY, float fAngleZ)
|
inline void Rotate(float fAngleX, float fAngleY, float fAngleZ)
|
||||||
{
|
{
|
||||||
CMatrix RotationMatrix;
|
CMatrix RotationMatrix;
|
||||||
RotationMatrix.SetRotate(fAngleX, fAngleY, fAngleZ);
|
RotationMatrix.SetRotate(fAngleX, fAngleY, fAngleZ);
|
||||||
*this = *this * RotationMatrix;
|
*this *= RotationMatrix;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void SetRotateXOnly(float fAngle)
|
inline void SetRotateXOnly(float fAngle)
|
||||||
|
|
Loading…
Reference in a new issue