browser/external/raylib-cpp-4.5.1/include/Vector4.hpp
2023-09-27 15:02:24 -04:00

171 lines
4.4 KiB
C++

#ifndef RAYLIB_CPP_INCLUDE_VECTOR4_HPP_
#define RAYLIB_CPP_INCLUDE_VECTOR4_HPP_
#ifndef RAYLIB_CPP_NO_MATH
#include <cmath>
#include <utility>
#endif
#include "./raylib.hpp"
#include "./raymath.hpp"
#include "./raylib-cpp-utils.hpp"
namespace raylib {
/**
* Vector4 type
*/
class Vector4 : public ::Vector4 {
public:
Vector4(const ::Vector4& vec) : ::Vector4{vec.x, vec.y, vec.z, vec.w} {}
Vector4(float x, float y, float z, float w) : ::Vector4{x, y, z, w} {}
Vector4(float x, float y, float z) : ::Vector4{x, y, z, 0} {}
Vector4(float x, float y) : ::Vector4{x, y, 0, 0} {}
Vector4(float x) : ::Vector4{x, 0, 0, 0} {}
Vector4() : ::Vector4{0, 0, 0, 0} {}
Vector4(::Rectangle rectangle) : ::Vector4{rectangle.x, rectangle.y, rectangle.width, rectangle.height} {}
Vector4(::Color color) {
set(ColorNormalize(color));
}
GETTERSETTER(float, X, x)
GETTERSETTER(float, Y, y)
GETTERSETTER(float, Z, z)
GETTERSETTER(float, W, w)
Vector4& operator=(const ::Vector4& vector4) {
set(vector4);
return *this;
}
bool operator==(const ::Vector4& other) {
return x == other.x
&& y == other.y
&& z == other.z
&& w == other.w;
}
bool operator!=(const ::Vector4& other) {
return !(*this == other);
}
inline ::Rectangle ToRectangle() {
return {x, y, z, w};
}
operator ::Rectangle() const {
return {x, y, z, w};
}
#ifndef RAYLIB_CPP_NO_MATH
inline Vector4 Multiply(const ::Vector4& vector4) const {
return QuaternionMultiply(*this, vector4);
}
inline Vector4 operator*(const ::Vector4& vector4) const {
return QuaternionMultiply(*this, vector4);
}
inline Vector4 Lerp(const ::Vector4& vector4, float amount) const {
return QuaternionLerp(*this, vector4, amount);
}
inline Vector4 Nlerp(const ::Vector4& vector4, float amount) const {
return QuaternionNlerp(*this, vector4, amount);
}
inline Vector4 Slerp(const ::Vector4& vector4, float amount) const {
return QuaternionSlerp(*this, vector4, amount);
}
inline Matrix ToMatrix() const {
return QuaternionToMatrix(*this);
}
inline float Length() const {
return QuaternionLength(*this);
}
inline Vector4 Normalize() const {
return QuaternionNormalize(*this);
}
inline Vector4 Invert() const {
return QuaternionInvert(*this);
}
inline void ToAxisAngle(::Vector3 *outAxis, float *outAngle) {
QuaternionToAxisAngle(*this, outAxis, outAngle);
}
/**
* Get the rotation angle and axis for a given quaternion
*/
std::pair<Vector3, float> ToAxisAngle() {
Vector3 outAxis;
float outAngle;
QuaternionToAxisAngle(*this, &outAxis, &outAngle);
return std::pair<Vector3, float>(outAxis, outAngle);
}
inline Vector4 Transform(const ::Matrix& matrix) {
return ::QuaternionTransform(*this, matrix);
}
static inline Vector4 Identity() {
return ::QuaternionIdentity();
}
static inline Vector4 FromVector3ToVector3(const ::Vector3& from , const ::Vector3& to) {
return ::QuaternionFromVector3ToVector3(from , to);
}
static inline Vector4 FromMatrix(const ::Matrix& matrix) {
return ::QuaternionFromMatrix(matrix);
}
static inline Vector4 FromAxisAngle(const ::Vector3& axis, const float angle) {
return ::QuaternionFromAxisAngle(axis, angle);
}
static inline Vector4 FromEuler(const float yaw, const float pitch, const float roll) {
return ::QuaternionFromEuler(yaw, pitch, roll);
}
static inline Vector4 FromEuler(const ::Vector3& vector3) {
return ::QuaternionFromEuler(vector3.x, vector3.y, vector3.z);
}
inline Vector3 ToEuler() {
return ::QuaternionToEuler(*this);
}
#endif
inline Color ColorFromNormalized() const {
return ::ColorFromNormalized(*this);
}
operator Color() {
return ColorFromNormalized();
}
private:
void set(const ::Vector4& vec4) {
x = vec4.x;
y = vec4.y;
z = vec4.z;
w = vec4.w;
}
};
// Alias the Vector4 as Quaternion.
typedef Vector4 Quaternion;
} // namespace raylib
using RVector4 = raylib::Vector4;
using RQuaternion = raylib::Quaternion;
#endif // RAYLIB_CPP_INCLUDE_VECTOR4_HPP_