mirror of
https://github.com/dashr9230/SA-MP.git
synced 2025-01-06 01:23:30 +08:00
147 lines
3.6 KiB
C++
147 lines
3.6 KiB
C++
|
|
#include "main.h"
|
|
|
|
#ifndef copysign
|
|
#define copysign _copysign
|
|
#endif
|
|
|
|
#ifndef MAX
|
|
#define MAX(x, y) ((y) < (x) ? (x) : (y))
|
|
#endif
|
|
|
|
//----------------------------------------------------
|
|
|
|
void CrossProduct(PVECTOR result, PVECTOR v1, PVECTOR v2)
|
|
{
|
|
result->X = v1->Y * v2->Z - v1->Z * v2->Y;
|
|
result->Y = v1->Z * v2->X - v1->X * v2->Z;
|
|
result->Z = v1->X * v2->Y - v1->Y * v2->X;
|
|
}
|
|
|
|
//----------------------------------------------------
|
|
|
|
void TransformVector(PVECTOR result, PMATRIX4X4 m, PVECTOR v)
|
|
{
|
|
result->X = m->at.X * v->Z + m->right.X * v->X + m->up.X * v->Y + m->pos.X;
|
|
result->Y = m->at.Y * v->Z + m->right.Y * v->X + m->up.Y * v->Y + m->pos.Y;
|
|
result->Z = m->at.Z * v->Z + m->right.Z * v->X + m->up.Z * v->Y + m->pos.Z;
|
|
}
|
|
|
|
//----------------------------------------------------
|
|
|
|
void MatrixToQuaternion(float m00, float m01, float m02,
|
|
float m10, float m11, float m12,
|
|
float m20, float m21, float m22,
|
|
float &qw, float &qx, float &qy, float &qz)
|
|
{
|
|
double w, x, y, z;
|
|
|
|
w = sqrt(MAX(0.0f, 1.0f + m00 + m11 + m22)) / 2.0f;
|
|
x = sqrt(MAX(0.0f, 1.0f + m00 - m11 - m22)) / 2.0f;
|
|
y = sqrt(MAX(0.0f, 1.0f - m00 + m11 - m22)) / 2.0f;
|
|
z = sqrt(MAX(0.0f, 1.0f - m00 - m11 + m22)) / 2.0f;
|
|
|
|
if(w < 0.0f) w = 0.0f;
|
|
if(x < 0.0f) x = 0.0f;
|
|
if(y < 0.0f) y = 0.0f;
|
|
if(z < 0.0f) z = 0.0f;
|
|
|
|
x = copysign(x, m21 - m12);
|
|
y = copysign(y, m02 - m20);
|
|
z = copysign(z, m10 - m01);
|
|
|
|
qw = w;
|
|
qx = x;
|
|
qy = y;
|
|
qz = z;
|
|
}
|
|
|
|
//----------------------------------------------------
|
|
|
|
void QuaternionToMatrix(float qw, float qx, float qy, float qz,
|
|
float &m00, float &m01, float &m02,
|
|
float &m10, float &m11, float &m12,
|
|
float &m20, float &m21, float &m22)
|
|
{
|
|
float ww = qw * qw;
|
|
float xx = qx * qx;
|
|
float yy = qy * qy;
|
|
float zz = qz * qz;
|
|
m00 = xx - yy - zz + ww;
|
|
m11 = yy - xx - zz + ww;
|
|
m22 = zz - (yy + xx) + ww;
|
|
|
|
float xy = qx * qy;
|
|
float wz = qw * qz;
|
|
m10 = wz + xy + wz + xy;
|
|
m01 = xy - wz + xy - wz;
|
|
|
|
float xz = qx * qz;
|
|
float wy = qw * qy;
|
|
m20 = xz - wy + xz - wy;
|
|
m02 = wy + xz + wy + xz;
|
|
|
|
float yz = qy * qz;
|
|
float wx = qw * qx;
|
|
m21 = wx + yz + wx + yz;
|
|
m12 = yz - wx + yz - wx;
|
|
}
|
|
|
|
//----------------------------------------------------
|
|
|
|
void QuaternionToMatrix(PQUATERNION q, PMATRIX4X4 m)
|
|
{
|
|
QuaternionToMatrix(q->W, q->X, q->Y, q->Z,
|
|
m->right.X, m->right.Y, m->right.Z,
|
|
m->up.X, m->up.Y, m->up.Z,
|
|
m->at.X, m->at.Y, m->at.Z);
|
|
}
|
|
|
|
//----------------------------------------------------
|
|
|
|
void MatrixToQuaternion(PMATRIX4X4 m, PQUATERNION q)
|
|
{
|
|
MatrixToQuaternion(m->right.X, m->right.Y, m->right.Z,
|
|
m->up.X, m->up.Y, m->up.Z,
|
|
m->at.X, m->at.Y, m->at.Z,
|
|
q->W, q->X, q->Y, q->Z);
|
|
}
|
|
|
|
//----------------------------------------------------
|
|
|
|
void EulerToQuaternion(PVECTOR v, PQUATERNION q)
|
|
{
|
|
float cz = cosf(v->Z * 0.5f);
|
|
float cy = cosf(v->Y * 0.5f);
|
|
float cx = cosf(v->X * 0.5f);
|
|
float sz = sinf(v->Z * 0.5f);
|
|
float sy = sinf(v->Y * 0.5f);
|
|
float sx = sinf(v->X * 0.5f);
|
|
|
|
q->W = cz * cy * cx + sz * sy * sx;
|
|
q->X = cz * cy * sx - sz * sy * cx;
|
|
q->Y = cz * sy * cx + sz * cy * sx;
|
|
q->Z = sz * cy * cx - cz * sy * sx;
|
|
}
|
|
|
|
//----------------------------------------------------
|
|
|
|
void QuaternionToEuler(PQUATERNION q, PVECTOR v)
|
|
{
|
|
float sqw = q->W * q->W;
|
|
float sqx = q->X * q->X;
|
|
float sqy = q->Y * q->Y;
|
|
float sqz = q->Z * q->Z;
|
|
|
|
float t0 = q->X * q->Y + q->Z * q->W;
|
|
v->X = atan2f(t0 + t0, sqx - sqy - sqz + sqw);
|
|
|
|
v->Y = asinf((q->X * q->Z - q->Y * q->W) * -2.0f);
|
|
|
|
float t1 = q->Y * q->Z + q->X * q->W;
|
|
v->Z = atan2f(t1 + t1, -sqx - sqy + sqz + sqw);
|
|
}
|
|
|
|
//----------------------------------------------------
|
|
// EOF
|