2022-10-09 05:13:17 +00:00
|
|
|
#ifndef _CQUATERNION
|
|
|
|
#define _CQUATERNION
|
2022-08-13 02:48:34 +00:00
|
|
|
|
|
|
|
#include "types.h"
|
|
|
|
|
2022-09-19 04:19:46 +00:00
|
|
|
#include "Kyoto/Math/CMatrix3f.hpp"
|
|
|
|
#include "Kyoto/Math/CTransform4f.hpp"
|
|
|
|
|
2022-10-03 04:49:11 +00:00
|
|
|
class CRelAngle;
|
|
|
|
class CUnitVector3f;
|
|
|
|
|
2022-08-13 02:48:34 +00:00
|
|
|
class CQuaternion {
|
2022-08-14 18:38:41 +00:00
|
|
|
public:
|
2022-10-09 05:37:23 +00:00
|
|
|
CQuaternion(float w, float x, float y, float z) : w(w), x(x), y(y), z(z) {}
|
2022-09-21 05:18:07 +00:00
|
|
|
// __ct__11CQuaternionFfRC9CVector3f
|
|
|
|
|
2022-09-18 05:55:13 +00:00
|
|
|
// CQuaternion(const CQuaternion& other)
|
|
|
|
// : w(other.w)
|
|
|
|
// , x(other.x)
|
|
|
|
// , y(other.y)
|
|
|
|
// , z(other.z) {}
|
2022-09-21 05:18:07 +00:00
|
|
|
// CQuaternion& operator=(const CQuaternion& other) {
|
|
|
|
// w = other.w;
|
|
|
|
// x = other.x;
|
|
|
|
// y = other.y;
|
|
|
|
// z = other.z;
|
|
|
|
// }
|
2022-09-18 05:55:13 +00:00
|
|
|
|
2022-09-19 04:19:46 +00:00
|
|
|
CQuaternion operator*(const CQuaternion&) const;
|
2022-09-21 05:18:07 +00:00
|
|
|
// __amu__11CQuaternionFRC11CQuaternion
|
|
|
|
// ScalarVector__11CQuaternionFfRC9CVector3f
|
2022-09-19 04:19:46 +00:00
|
|
|
// Slerp__11CQuaternionFRC11CQuaternionRC11CQuaternionf
|
|
|
|
// ShortestRotationArc__11CQuaternionFRC9CVector3fRC9CVector3f
|
|
|
|
// LookAt__11CQuaternionFRC13CUnitVector3fRC13CUnitVector3fRC9CRelAngle
|
|
|
|
// normalize_angle__Ff
|
|
|
|
// IsValidQuaternion__11CQuaternionCFf
|
|
|
|
// SlerpLocal__11CQuaternionFRC11CQuaternionRC11CQuaternionf
|
|
|
|
// AngleFrom__11CQuaternionCFRC11CQuaternion
|
|
|
|
// BuildEquivalent__11CQuaternionCFv
|
|
|
|
// BuildNormalized__11CQuaternionCFv
|
2022-10-03 04:49:11 +00:00
|
|
|
static CQuaternion AxisAngle(const CUnitVector3f&, const CRelAngle&);
|
|
|
|
CVector3f Transform(const CVector3f&) const;
|
2022-09-19 04:19:46 +00:00
|
|
|
// XRotation__11CQuaternionFRC9CRelAngle
|
|
|
|
// YRotation__11CQuaternionFRC9CRelAngle
|
|
|
|
// ZRotation__11CQuaternionFRC9CRelAngle
|
|
|
|
// BuildTransform__11CQuaternionCFv
|
|
|
|
CTransform4f BuildTransform4f() const;
|
|
|
|
CTransform4f BuildTransform4f(const CVector3f&) const;
|
2022-10-03 04:49:11 +00:00
|
|
|
CQuaternion BuildInverted() const {
|
2022-10-09 05:37:23 +00:00
|
|
|
// double w = this->w;
|
|
|
|
// double x = -this->x;
|
|
|
|
// double y = -this->y;
|
|
|
|
// double z = -this->z;
|
2022-09-21 05:18:07 +00:00
|
|
|
return CQuaternion(w, -x, -y, -z);
|
2022-10-03 04:49:11 +00:00
|
|
|
}
|
2022-09-19 04:19:46 +00:00
|
|
|
|
|
|
|
static CQuaternion FromMatrixRows(const CVector3f&, const CVector3f&, const CVector3f&);
|
|
|
|
static CQuaternion FromMatrix(const CMatrix3f&);
|
|
|
|
static CQuaternion FromMatrix(const CTransform4f&);
|
|
|
|
|
2022-09-18 05:55:13 +00:00
|
|
|
static const CQuaternion& NoRotation() { return sNoRotation; }
|
2022-08-14 18:38:41 +00:00
|
|
|
|
2022-10-16 22:49:37 +00:00
|
|
|
static float Dot(const CQuaternion& a, const CQuaternion& b) {
|
|
|
|
return (a.GetW() * b.GetW()) + (a.GetX() * b.GetX()) + (a.GetY() * b.GetY()) + (a.GetZ() * b.GetZ());
|
|
|
|
}
|
|
|
|
|
|
|
|
float GetW() const { return w; }
|
|
|
|
float GetX() const { return x; }
|
|
|
|
float GetY() const { return y; }
|
|
|
|
float GetZ() const { return z; }
|
|
|
|
|
2022-08-13 02:48:34 +00:00
|
|
|
private:
|
2022-10-09 05:37:23 +00:00
|
|
|
float w;
|
|
|
|
float x;
|
|
|
|
float y;
|
|
|
|
float z;
|
2022-09-18 05:55:13 +00:00
|
|
|
|
|
|
|
static const CQuaternion sNoRotation;
|
2022-08-13 02:48:34 +00:00
|
|
|
};
|
|
|
|
|
2022-10-09 05:13:17 +00:00
|
|
|
#endif // _CQUATERNION
|