diff options
author | Sergeanur <s.anureev@yandex.ua> | 2020-09-14 19:48:49 +0200 |
---|---|---|
committer | Sergeanur <s.anureev@yandex.ua> | 2020-09-14 20:10:23 +0200 |
commit | a8a28c151273e5d1a33707b61304e27762eb6378 (patch) | |
tree | f6b62a86f7d4496ee405279092fe029545694748 /src/math/Quaternion.h | |
parent | Merge pull request #702 from Sergeanur/VC/MusicManager (diff) | |
download | re3-a8a28c151273e5d1a33707b61304e27762eb6378.tar re3-a8a28c151273e5d1a33707b61304e27762eb6378.tar.gz re3-a8a28c151273e5d1a33707b61304e27762eb6378.tar.bz2 re3-a8a28c151273e5d1a33707b61304e27762eb6378.tar.lz re3-a8a28c151273e5d1a33707b61304e27762eb6378.tar.xz re3-a8a28c151273e5d1a33707b61304e27762eb6378.tar.zst re3-a8a28c151273e5d1a33707b61304e27762eb6378.zip |
Diffstat (limited to '')
-rw-r--r-- | src/math/Quaternion.h | 18 |
1 files changed, 6 insertions, 12 deletions
diff --git a/src/math/Quaternion.h b/src/math/Quaternion.h index dac49362..a5a34626 100644 --- a/src/math/Quaternion.h +++ b/src/math/Quaternion.h @@ -10,18 +10,8 @@ public: float Magnitude(void) const { return Sqrt(x*x + y*y + z*z + w*w); } float MagnitudeSqr(void) const { return x*x + y*y + z*z + w*w; } - void Normalise(void) { - float sq = MagnitudeSqr(); - if(sq == 0.0f) - w = 1.0f; - else{ - float invsqrt = RecipSqrt(sq); - x *= invsqrt; - y *= invsqrt; - z *= invsqrt; - w *= invsqrt; - } - } + void Normalise(void); + void Multiply(const CQuaternion &q1, const CQuaternion &q2); const CQuaternion &operator+=(CQuaternion const &right) { x += right.x; @@ -60,8 +50,12 @@ public: } void Slerp(const CQuaternion &q1, const CQuaternion &q2, float theta, float invSin, float t); + void Get(RwV3d *axis, float *angle); void Set(RwV3d *axis, float angle); void Get(RwMatrix *matrix); + void Set(const RwMatrix &matrix); + void Set(float f1, float f2, float f3); + void Get(float *f1, float *f2, float *f3); }; inline float |