2014-08-27 05:20:24 +06:00
|
|
|
#ifndef __GENERAL
|
|
|
|
#define __GENERAL
|
|
|
|
|
2018-03-28 01:28:45 +05:00
|
|
|
#include <cstdint>
|
|
|
|
|
2014-08-27 05:20:24 +06:00
|
|
|
class CRGBA
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
BYTE r, g, b, a;
|
|
|
|
|
|
|
|
inline CRGBA() {}
|
|
|
|
|
|
|
|
inline CRGBA(const CRGBA& in)
|
|
|
|
: r(in.r), g(in.g), b(in.b), a(in.a)
|
|
|
|
{}
|
|
|
|
|
|
|
|
inline CRGBA(const CRGBA& in, BYTE alpha)
|
|
|
|
: r(in.r), g(in.g), b(in.b), a(alpha)
|
|
|
|
{}
|
|
|
|
|
|
|
|
|
|
|
|
inline CRGBA(BYTE red, BYTE green, BYTE blue, BYTE alpha = 255)
|
|
|
|
: r(red), g(green), b(blue), a(alpha)
|
|
|
|
{}
|
|
|
|
};
|
|
|
|
|
|
|
|
class CRect
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
float x1, y1;
|
|
|
|
float x2, y2;
|
|
|
|
|
|
|
|
inline CRect() {}
|
|
|
|
inline CRect(float a, float b, float c, float d)
|
|
|
|
: x1(a), y1(b), x2(c), y2(d)
|
|
|
|
{}
|
|
|
|
};
|
|
|
|
|
2017-09-28 02:12:05 +05:00
|
|
|
class CVector
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
float x, y, z;
|
|
|
|
|
|
|
|
CVector()
|
|
|
|
{}
|
|
|
|
|
|
|
|
constexpr CVector(float fX, float fY, float fZ=0.0f)
|
|
|
|
: x(fX), y(fY), z(fZ)
|
|
|
|
{}
|
|
|
|
|
|
|
|
|
|
|
|
CVector& operator+=(const CVector& vec)
|
|
|
|
{ x += vec.x; y += vec.y; z += vec.z;
|
|
|
|
return *this; }
|
|
|
|
CVector& operator-=(const CVector& vec)
|
|
|
|
{ x -= vec.x; y -= vec.y; z -= vec.z;
|
|
|
|
return *this; }
|
|
|
|
|
|
|
|
inline float Magnitude() const
|
|
|
|
{ return sqrt(x * x + y * y + z * z); }
|
|
|
|
inline constexpr float MagnitudeSqr() const
|
|
|
|
{ return x * x + y * y + z * z; }
|
|
|
|
inline CVector& Normalize()
|
|
|
|
{ float fInvLen = 1.0f / Magnitude(); x *= fInvLen; y *= fInvLen; z *= fInvLen; return *this; }
|
|
|
|
|
|
|
|
friend inline float DotProduct(const CVector& vec1, const CVector& vec2)
|
|
|
|
{ return vec1.x * vec2.x + vec1.x * vec2.y + vec1.z * vec2.z; }
|
|
|
|
friend inline CVector CrossProduct(const CVector& vec1, const CVector& vec2)
|
|
|
|
{ return CVector( vec1.y * vec2.z - vec1.z * vec2.y,
|
|
|
|
vec1.z * vec2.x - vec1.x * vec2.z,
|
|
|
|
vec1.x * vec2.y - vec1.y * vec2.x); }
|
|
|
|
|
|
|
|
friend inline CVector operator*(const CVector& in, float fMul)
|
|
|
|
{ return CVector(in.x * fMul, in.y * fMul, in.z * fMul); }
|
|
|
|
friend inline CVector operator+(const CVector& vec1, const CVector& vec2)
|
|
|
|
{ return CVector(vec1.x + vec2.x, vec1.y + vec2.y, vec1.z + vec2.z); }
|
|
|
|
friend inline CVector operator-(const CVector& vec1, const CVector& vec2)
|
|
|
|
{ return CVector(vec1.x - vec2.x, vec1.y - vec2.y, vec1.z - vec2.z); }
|
|
|
|
friend inline CVector operator-(const CVector& vec)
|
|
|
|
{ return CVector(-vec.x, -vec.y, -vec.z); }
|
|
|
|
};
|
|
|
|
|
2014-08-27 05:20:24 +06:00
|
|
|
#endif
|