2020-03-22 01:45:04 +02:00
|
|
|
#pragma once
|
2015-09-30 03:56:11 +03:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
2021-01-30 08:51:39 +02:00
|
|
|
#include "Base/Shared.hpp"
|
2015-09-30 03:56:11 +03:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
namespace SqMod {
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Quaternion class for representing rotations.
|
2015-09-30 03:56:11 +03:00
|
|
|
*/
|
|
|
|
struct Quaternion
|
|
|
|
{
|
2015-11-01 10:55:47 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* The type of value used by components of type.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2016-02-21 00:25:00 +02:00
|
|
|
typedef float Value;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Helper instances for common values mostly used as return types or comparison.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-09-30 03:56:11 +03:00
|
|
|
static const Quaternion NIL;
|
|
|
|
static const Quaternion MIN;
|
|
|
|
static const Quaternion MAX;
|
2016-08-04 03:09:43 +03:00
|
|
|
static const Quaternion IDENTITY;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* The delimiter character to be used when extracting values from strings.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-09-30 03:56:11 +03:00
|
|
|
static SQChar Delim;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* The x, y, z and w components of this type.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
Value x{0}, y{0}, z{0}, w{0};
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Default constructor.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
Quaternion() noexcept = default;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-08-23 23:02:19 +03:00
|
|
|
* Construct from scalar value.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2020-03-22 09:16:40 +02:00
|
|
|
explicit Quaternion(Value sv) noexcept;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-08-23 23:02:19 +03:00
|
|
|
* Construct from Euler angles (in degrees.)
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2020-03-22 09:16:40 +02:00
|
|
|
Quaternion(Value xv, Value yv, Value zv) noexcept;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-08-23 23:02:19 +03:00
|
|
|
* Construct from individual values.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2020-03-22 09:16:40 +02:00
|
|
|
Quaternion(Value xv, Value yv, Value zv, Value wv) noexcept;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Copy constructor.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2020-03-22 09:16:40 +02:00
|
|
|
Quaternion(const Quaternion & o) noexcept = default;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Move constructor.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2020-03-22 09:16:40 +02:00
|
|
|
Quaternion(Quaternion && o) noexcept = default;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Destructor.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2016-03-10 05:57:13 +02:00
|
|
|
~Quaternion() = default;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Copy assignment operator.
|
|
|
|
*/
|
|
|
|
Quaternion & operator = (const Quaternion & o) = default;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Move assignment operator.
|
|
|
|
*/
|
|
|
|
Quaternion & operator = (Quaternion && o) = default;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Scalar value assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator = (Value s);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Euler assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator = (const Vector3 & q);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Four-dimensional vector assignment operator threated as a three-dimensional vector.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator = (const Vector4 & q);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Addition assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator += (const Quaternion & q);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Subtraction assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator -= (const Quaternion & q);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Multiplication assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator *= (const Quaternion & q);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Division assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator /= (const Quaternion & q);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Modulo assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator %= (const Quaternion & q);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value addition assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator += (Value s);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value subtraction assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator -= (Value s);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value multiplication assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator *= (Value s);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value division assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator /= (Value s);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value modulo assignment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator %= (Value s);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Pre-increment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator ++ ();
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Pre-decrement operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion & operator -- ();
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Post-increment operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2020-03-22 09:16:40 +02:00
|
|
|
Quaternion operator ++ (int); // NOLINT(cert-dcl21-cpp)
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Post-decrement operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2020-03-22 09:16:40 +02:00
|
|
|
Quaternion operator -- (int); // NOLINT(cert-dcl21-cpp)
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Addition operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator + (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Subtraction operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator - (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Multiplication operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator * (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Division operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator / (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Modulo operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator % (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value addition operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator + (Value s) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value subtraction operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator - (Value s) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value multiplication operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator * (Value s) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value division operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator / (Value s) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Scalar value modulo operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator % (Value s) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Unary plus operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator + () const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Unary minus operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
Quaternion operator - () const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Equality comparison operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
bool operator == (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Inequality comparison operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
bool operator != (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Less than comparison operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
bool operator < (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Greater than comparison operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
bool operator > (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Less than or equal comparison operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
bool operator <= (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Greater than or equal comparison operator.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
bool operator >= (const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Used by the script engine to compare two instances of this type.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD int32_t Cmp(const Quaternion & q) const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
2016-08-24 23:17:29 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Used by the script engine to compare an instance of this type with a scalar value.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD int32_t Cmp(SQFloat s) const
|
2016-08-24 23:17:29 +03:00
|
|
|
{
|
2016-08-25 01:01:03 +03:00
|
|
|
return Cmp(Quaternion(static_cast< Value >(s)));
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Used by the script engine to compare an instance of this type with a scalar value.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD int32_t Cmp(SQInteger s) const
|
2016-08-25 01:01:03 +03:00
|
|
|
{
|
|
|
|
return Cmp(Quaternion(static_cast< Value >(s)));
|
2016-08-24 23:17:29 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Used by the script engine to compare an instance of this type with a scalar value.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD int32_t Cmp(bool s) const
|
2016-08-24 23:17:29 +03:00
|
|
|
{
|
|
|
|
return Cmp(Quaternion(static_cast< Value >(s)));
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Used by the script engine to compare an instance of this type with a scalar value.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD int32_t Cmp(std::nullptr_t) const
|
2016-08-24 23:17:29 +03:00
|
|
|
{
|
|
|
|
return Cmp(Quaternion(static_cast< Value >(0)));
|
|
|
|
}
|
|
|
|
|
2015-11-01 10:55:47 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Used by the script engine to convert an instance of this type to a string.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD String ToString() const;
|
2015-11-01 10:55:47 +02:00
|
|
|
|
2016-03-10 05:57:13 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Set all components to the specified scalar value.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2016-07-25 00:08:28 +03:00
|
|
|
void SetScalar(Value ns);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-07-25 00:08:28 +03:00
|
|
|
* Copy the values from another instance of this type.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2016-07-25 00:08:28 +03:00
|
|
|
void SetQuaternion(const Quaternion & q);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Set all components to the specified values.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2016-07-25 00:08:28 +03:00
|
|
|
void SetQuaternionEx(Value nx, Value ny, Value nz, Value nw);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-07-25 00:08:28 +03:00
|
|
|
* Copy the values from a three-dimensional vector as euler rotation.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2016-07-25 00:08:28 +03:00
|
|
|
void SetVector3(const Vector3 & v);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Copy the values from a three-dimensional vector as euler rotation.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2016-07-25 00:08:28 +03:00
|
|
|
void SetVector3Ex(Value nx, Value ny, Value nz);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Copy the values from a four-dimensional vector.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2016-07-25 00:08:28 +03:00
|
|
|
void SetVector4(const Vector4 & v);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Set the values extracted from the specified string using the specified delimiter.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2019-02-17 17:23:59 +02:00
|
|
|
void SetStr(SQChar delim, StackStrF & values);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Generate random values for all components of this instance.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
void Generate();
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Generate random values for all components of this instance within the specified bounds.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
void Generate(Value min, Value max);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Generate random values for all components of this instance within the specified bounds.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2015-11-01 05:48:01 +02:00
|
|
|
void Generate(Value xmin, Value xmax, Value ymin, Value ymax, Value zmin, Value zmax, Value wmin, Value wmax);
|
2015-11-01 10:55:47 +02:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Clear the component values to default.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
|
|
|
void Clear()
|
|
|
|
{
|
|
|
|
x = 0.0, y = 0.0, z = 0.0, w = 0.0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
2016-03-10 05:57:13 +02:00
|
|
|
* Retrieve a new instance of this type with absolute component values.
|
2015-11-01 10:55:47 +02:00
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Quaternion Abs() const;
|
2016-05-22 06:20:38 +03:00
|
|
|
|
2016-08-23 23:02:19 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return whether is NaN.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD bool IsNaN() const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return squared length.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Value LengthSquared() const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Calculate dot product.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Value DotProduct(const Quaternion & quat) const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return conjugate.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Quaternion Conjugate() const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Normalize to unit length.
|
|
|
|
*/
|
|
|
|
void Normalize();
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return normalized to unit length.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Quaternion Normalized() const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Define from an angle (in degrees) and axis.
|
|
|
|
*/
|
|
|
|
void FromAngleAxis(Value angle, const Vector3 & axis);
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Define from the rotation difference between two direction vectors.
|
|
|
|
*/
|
|
|
|
void FromRotationTo(const Vector3 & start, const Vector3 & end);
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return inverse.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Quaternion Inverse() const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return Euler angles in degrees.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Vector3 ToEuler() const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return yaw angle in degrees.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Value YawAngle() const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return pitch angle in degrees.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Value PitchAngle() const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return roll angle in degrees.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Value RollAngle() const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Spherical interpolation with another quaternion.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Quaternion Slerp(Quaternion quat, Value t) const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Normalized linear interpolation with another quaternion.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Quaternion Nlerp(const Quaternion & quat, Value t) const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Normalized linear interpolation with another quaternion.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD Quaternion NlerpEx(const Quaternion & quat, Value t, bool shortest_path) const;
|
2016-08-23 23:02:19 +03:00
|
|
|
|
2020-09-03 20:33:51 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Generate a formatted string with the values from this instance.
|
|
|
|
*/
|
2021-01-30 08:51:39 +02:00
|
|
|
SQMOD_NODISCARD String Format(StackStrF & str) const;
|
2020-09-03 20:33:51 +03:00
|
|
|
|
2016-05-22 06:20:38 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Extract the values for components of the Quaternion type from a string.
|
|
|
|
*/
|
2019-02-17 17:23:59 +02:00
|
|
|
static const Quaternion & Get(StackStrF & str);
|
2016-05-22 06:20:38 +03:00
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Extract the values for components of the Quaternion type from a string.
|
|
|
|
*/
|
2019-02-17 17:23:59 +02:00
|
|
|
static const Quaternion & GetEx(SQChar delim, StackStrF & str);
|
2015-09-30 03:56:11 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
} // Namespace:: SqMod
|