1
0
mirror of https://github.com/VCMP-SqMod/SqMod.git synced 2024-11-08 08:47:17 +01:00
SqMod/source/Base/AABB.cpp

479 lines
14 KiB
C++
Raw Normal View History

// ------------------------------------------------------------------------------------------------
2015-09-30 02:56:11 +02:00
#include "Base/AABB.hpp"
#include "Base/Vector4.hpp"
#include "Base/Shared.hpp"
// ------------------------------------------------------------------------------------------------
namespace SqMod {
// ------------------------------------------------------------------------------------------------
const AABB AABB::NIL = AABB(0);
const AABB AABB::MIN = AABB(-1, -1, -1, 1, 1, 1);
const AABB AABB::MAX = AABB(Vector3::MIN, Vector3::MAX);
// ------------------------------------------------------------------------------------------------
SQChar AABB::Delim = ',';
// ------------------------------------------------------------------------------------------------
SQInteger AABB::Typename(HSQUIRRELVM vm)
{
static SQChar name[] = _SC("AABB");
sq_pushstring(vm, name, sizeof(name));
return 1;
}
2015-09-30 02:56:11 +02:00
// ------------------------------------------------------------------------------------------------
AABB::AABB()
: min(-1.0), max(1.0)
2015-09-30 02:56:11 +02:00
{
/* ... */
2015-09-30 02:56:11 +02:00
}
// ------------------------------------------------------------------------------------------------
AABB::AABB(Value sv)
: min(-sv), max(fabs(sv))
2015-09-30 02:56:11 +02:00
{
/* ... */
2015-09-30 02:56:11 +02:00
}
// ------------------------------------------------------------------------------------------------
AABB::AABB(Value xv, Value yv, Value zv)
: min(-xv, -yv, -zv), max(fabs(xv), fabs(yv), fabs(zv))
2015-09-30 02:56:11 +02:00
{
/* ... */
2015-09-30 02:56:11 +02:00
}
// ------------------------------------------------------------------------------------------------
AABB::AABB(Value xmin, Value ymin, Value zmin, Value xmax, Value ymax, Value zmax)
2015-09-30 02:56:11 +02:00
: min(xmin, ymin, zmin), max(xmax, ymax, zmax)
{
/* ... */
2015-09-30 02:56:11 +02:00
}
// ------------------------------------------------------------------------------------------------
AABB::AABB(const Vector3 & vmin, const Vector3 & vmax)
2015-09-30 02:56:11 +02:00
: min(vmin), max(vmax)
{
/* ... */
2015-09-30 02:56:11 +02:00
}
// ------------------------------------------------------------------------------------------------
AABB & AABB::operator = (Value s)
2015-09-30 02:56:11 +02:00
{
min.Set(-s);
max.Set(fabs(s));
2015-09-30 02:56:11 +02:00
return *this;
}
AABB & AABB::operator = (const Vector3 & v)
2015-09-30 02:56:11 +02:00
{
min.Set(-v);
max.Set(v.Abs());
return *this;
}
AABB & AABB::operator = (const Vector4 & v)
2015-09-30 02:56:11 +02:00
{
min.Set(-v);
max.Set(v.Abs());
return *this;
}
// ------------------------------------------------------------------------------------------------
AABB & AABB::operator += (const AABB & b)
2015-09-30 02:56:11 +02:00
{
min += b.min;
max += b.max;
return *this;
}
AABB & AABB::operator -= (const AABB & b)
2015-09-30 02:56:11 +02:00
{
min -= b.min;
max -= b.max;
return *this;
}
AABB & AABB::operator *= (const AABB & b)
2015-09-30 02:56:11 +02:00
{
min *= b.min;
max *= b.max;
return *this;
}
AABB & AABB::operator /= (const AABB & b)
2015-09-30 02:56:11 +02:00
{
min /= b.min;
max /= b.max;
return *this;
}
AABB & AABB::operator %= (const AABB & b)
2015-09-30 02:56:11 +02:00
{
min %= b.min;
max %= b.max;
return *this;
}
// ------------------------------------------------------------------------------------------------
AABB & AABB::operator += (Value s)
2015-09-30 02:56:11 +02:00
{
min += s;
max += s;
return *this;
}
AABB & AABB::operator -= (Value s)
2015-09-30 02:56:11 +02:00
{
min -= s;
max -= s;
return *this;
}
AABB & AABB::operator *= (Value s)
2015-09-30 02:56:11 +02:00
{
min *= s;
max *= s;
return *this;
}
AABB & AABB::operator /= (Value s)
2015-09-30 02:56:11 +02:00
{
min /= s;
max /= s;
return *this;
}
AABB & AABB::operator %= (Value s)
2015-09-30 02:56:11 +02:00
{
min %= s;
max %= s;
return *this;
}
// ------------------------------------------------------------------------------------------------
AABB & AABB::operator ++ ()
2015-09-30 02:56:11 +02:00
{
++min;
++max;
return *this;
}
AABB & AABB::operator -- ()
2015-09-30 02:56:11 +02:00
{
--min;
--max;
return *this;
}
// ------------------------------------------------------------------------------------------------
AABB AABB::operator ++ (int)
2015-09-30 02:56:11 +02:00
{
AABB state(*this);
++min;
++max;
return state;
}
AABB AABB::operator -- (int)
2015-09-30 02:56:11 +02:00
{
AABB state(*this);
--min;
--max;
return state;
}
// ------------------------------------------------------------------------------------------------
AABB AABB::operator + (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return AABB(min + b.min, max + b.max);
}
AABB AABB::operator - (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return AABB(min - b.min, max - b.max);
}
AABB AABB::operator * (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return AABB(min * b.min, max * b.max);
}
AABB AABB::operator / (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return AABB(min / b.min, max / b.max);
}
AABB AABB::operator % (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return AABB(min % b.min, max % b.max);
}
// ------------------------------------------------------------------------------------------------
AABB AABB::operator + (Value s) const
2015-09-30 02:56:11 +02:00
{
return AABB(min + s, max + s);
}
AABB AABB::operator - (Value s) const
2015-09-30 02:56:11 +02:00
{
return AABB(min - s, max - s);
}
AABB AABB::operator * (Value s) const
2015-09-30 02:56:11 +02:00
{
return AABB(min * s, max * s);
}
AABB AABB::operator / (Value s) const
2015-09-30 02:56:11 +02:00
{
return AABB(min / s, max / s);
}
AABB AABB::operator % (Value s) const
2015-09-30 02:56:11 +02:00
{
return AABB(min % s, max % s);
}
// ------------------------------------------------------------------------------------------------
AABB AABB::operator + () const
2015-09-30 02:56:11 +02:00
{
return AABB(min.Abs(), max.Abs());
}
AABB AABB::operator - () const
2015-09-30 02:56:11 +02:00
{
return AABB(-min, -max);
}
// ------------------------------------------------------------------------------------------------
bool AABB::operator == (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return (min == b.min) && (max == b.max);
}
bool AABB::operator != (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return (min != b.min) && (max != b.max);
}
bool AABB::operator < (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return (min < b.min) && (max < b.max);
}
bool AABB::operator > (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return (min > b.min) && (max > b.max);
}
bool AABB::operator <= (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return (min <= b.min) && (max <= b.max);
}
bool AABB::operator >= (const AABB & b) const
2015-09-30 02:56:11 +02:00
{
return (min >= b.min) && (max >= b.max);
}
// ------------------------------------------------------------------------------------------------
Int32 AABB::Cmp(const AABB & o) const
2015-09-30 02:56:11 +02:00
{
if (*this == o)
return 0;
else if (*this > o)
return 1;
else
return -1;
2015-09-30 02:56:11 +02:00
}
// ------------------------------------------------------------------------------------------------
CSStr AABB::ToString() const
2015-09-30 02:56:11 +02:00
{
return ToStrF("%f,%f,%f,%f,%f,%f", min.x, min.y, min.z, max.x, max.y, max.z);
2015-09-30 02:56:11 +02:00
}
// ------------------------------------------------------------------------------------------------
void AABB::Set(Value ns)
2015-09-30 02:56:11 +02:00
{
min = -ns;
max = fabs(ns);
2015-09-30 02:56:11 +02:00
}
void AABB::Set(Value nx, Value ny, Value nz)
2015-09-30 02:56:11 +02:00
{
min.Set(-nx, -ny, -nz);
max.Set(fabs(nx), fabs(ny), fabs(nz));
2015-09-30 02:56:11 +02:00
}
void AABB::Set(Value xmin, Value ymin, Value zmin, Value xmax, Value ymax, Value zmax)
2015-09-30 02:56:11 +02:00
{
min.Set(xmin, ymin, zmin);
max.Set(xmax, ymax, zmax);
}
// ------------------------------------------------------------------------------------------------
void AABB::Set(const AABB & b)
2015-09-30 02:56:11 +02:00
{
min = b.min;
max = b.max;
}
// ------------------------------------------------------------------------------------------------
void AABB::Set(const Vector3 & v)
2015-09-30 02:56:11 +02:00
{
min = -v;
max = v.Abs();
}
void AABB::Set(const Vector3 & nmin, const Vector3 & nmax)
2015-09-30 02:56:11 +02:00
{
min = nmin;
max = nmax;
}
// ------------------------------------------------------------------------------------------------
void AABB::Set(const Vector4 & v)
2015-09-30 02:56:11 +02:00
{
min = -v;
max = v.Abs();
}
void AABB::Set(const Vector4 & nmin, const Vector4 & nmax)
2015-09-30 02:56:11 +02:00
{
min = nmin;
max = nmax;
}
// ------------------------------------------------------------------------------------------------
void AABB::Set(CSStr values, SQChar delim)
2015-09-30 02:56:11 +02:00
{
Set(GetAABB(values, delim));
}
// ------------------------------------------------------------------------------------------------
AABB AABB::Abs() const
2015-09-30 02:56:11 +02:00
{
return AABB(min.Abs(), max.Abs());
}
// ------------------------------------------------------------------------------------------------
const AABB & GetAABB(CSStr str)
{
return GetAABB(str, AABB::Delim);
}
// ------------------------------------------------------------------------------------------------
const AABB & GetAABB(CSStr str, SQChar delim)
{
// The format specifications that will be used to scan the string
static SQChar fs[] = _SC(" %f , %f , %f , %f , %f , %f ");
static AABB box;
// Clear previous values, if any
box.Clear();
// Is the specified string empty?
if (!str || *str == '\0')
{
return box; // Return the value as is!
}
// Assign the specified delimiter
fs[4] = delim;
fs[9] = delim;
fs[14] = delim;
fs[19] = delim;
fs[24] = delim;
// Attempt to extract the component values from the specified string
std::sscanf(str, fs, &box.min.x, &box.min.y, &box.min.z, &box.max.x, &box.max.y, &box.max.z);
// Return the resulted value
return box;
}
2015-09-30 02:56:11 +02:00
// ================================================================================================
void Register_AABB(HSQUIRRELVM vm)
2015-09-30 02:56:11 +02:00
{
typedef AABB::Value Val;
RootTable(vm).Bind(_SC("AABB"), Class< AABB >(vm, _SC("AABB"))
/* Constructors */
2015-09-30 02:56:11 +02:00
.Ctor()
.Ctor< Val >()
.Ctor< Val, Val, Val >()
.Ctor< Val, Val, Val, Val, Val, Val >()
.Ctor< const Vector3 &, const Vector3 & >()
/* Static Members */
2015-09-30 02:56:11 +02:00
.SetStaticValue(_SC("delim"), &AABB::Delim)
/* Member Variables */
2015-09-30 02:56:11 +02:00
.Var(_SC("min"), &AABB::min)
.Var(_SC("max"), &AABB::max)
/* Properties */
2015-09-30 02:56:11 +02:00
.Prop(_SC("abs"), &AABB::Abs)
/* Core Metamethods */
2015-09-30 02:56:11 +02:00
.Func(_SC("_tostring"), &AABB::ToString)
.SquirrelFunc(_SC("_typename"), &AABB::Typename)
2015-09-30 02:56:11 +02:00
.Func(_SC("_cmp"), &AABB::Cmp)
/* Metamethods */
2015-09-30 02:56:11 +02:00
.Func<AABB (AABB::*)(const AABB &) const>(_SC("_add"), &AABB::operator +)
.Func<AABB (AABB::*)(const AABB &) const>(_SC("_sub"), &AABB::operator -)
.Func<AABB (AABB::*)(const AABB &) const>(_SC("_mul"), &AABB::operator *)
.Func<AABB (AABB::*)(const AABB &) const>(_SC("_div"), &AABB::operator /)
.Func<AABB (AABB::*)(const AABB &) const>(_SC("_modulo"), &AABB::operator %)
.Func<AABB (AABB::*)(void) const>(_SC("_unm"), &AABB::operator -)
/* Setters */
.Overload<void (AABB::*)(Val)>(_SC("Set"), &AABB::Set)
.Overload<void (AABB::*)(Val, Val, Val)>(_SC("Set"), &AABB::Set)
.Overload<void (AABB::*)(Val, Val, Val, Val, Val, Val)>(_SC("Set"), &AABB::Set)
.Overload<void (AABB::*)(const AABB &)>(_SC("SetBox"), &AABB::Set)
.Overload<void (AABB::*)(const Vector3 &)>(_SC("SetVec3"), &AABB::Set)
.Overload<void (AABB::*)(const Vector3 &, const Vector3 &)>(_SC("SetVec3"), &AABB::Set)
.Overload<void (AABB::*)(const Vector4 &)>(_SC("SetVec4"), &AABB::Set)
.Overload<void (AABB::*)(const Vector4 &, const Vector4 &)>(_SC("SetVec4"), &AABB::Set)
.Overload<void (AABB::*)(CSStr, SQChar)>(_SC("SetStr"), &AABB::Set)
/* Utility Methods */
.Func(_SC("Clear"), &AABB::Clear)
/* Operator Exposure */
2015-09-30 02:56:11 +02:00
.Func<AABB & (AABB::*)(const AABB &)>(_SC("opAddAssign"), &AABB::operator +=)
.Func<AABB & (AABB::*)(const AABB &)>(_SC("opSubAssign"), &AABB::operator -=)
.Func<AABB & (AABB::*)(const AABB &)>(_SC("opMulAssign"), &AABB::operator *=)
.Func<AABB & (AABB::*)(const AABB &)>(_SC("opDivAssign"), &AABB::operator /=)
.Func<AABB & (AABB::*)(const AABB &)>(_SC("opModAssign"), &AABB::operator %=)
.Func<AABB & (AABB::*)(AABB::Value)>(_SC("opAddAssignS"), &AABB::operator +=)
.Func<AABB & (AABB::*)(AABB::Value)>(_SC("opSubAssignS"), &AABB::operator -=)
.Func<AABB & (AABB::*)(AABB::Value)>(_SC("opMulAssignS"), &AABB::operator *=)
.Func<AABB & (AABB::*)(AABB::Value)>(_SC("opDivAssignS"), &AABB::operator /=)
.Func<AABB & (AABB::*)(AABB::Value)>(_SC("opModAssignS"), &AABB::operator %=)
.Func<AABB & (AABB::*)(void)>(_SC("opPreInc"), &AABB::operator ++)
.Func<AABB & (AABB::*)(void)>(_SC("opPreDec"), &AABB::operator --)
.Func<AABB (AABB::*)(int)>(_SC("opPostInc"), &AABB::operator ++)
.Func<AABB (AABB::*)(int)>(_SC("opPostDec"), &AABB::operator --)
.Func<AABB (AABB::*)(const AABB &) const>(_SC("opAdd"), &AABB::operator +)
.Func<AABB (AABB::*)(AABB::Value) const>(_SC("opAddS"), &AABB::operator +)
.Func<AABB (AABB::*)(const AABB &) const>(_SC("opSub"), &AABB::operator -)
.Func<AABB (AABB::*)(AABB::Value) const>(_SC("opSubS"), &AABB::operator -)
.Func<AABB (AABB::*)(const AABB &) const>(_SC("opMul"), &AABB::operator *)
.Func<AABB (AABB::*)(AABB::Value) const>(_SC("opMulS"), &AABB::operator *)
.Func<AABB (AABB::*)(const AABB &) const>(_SC("opDiv"), &AABB::operator /)
.Func<AABB (AABB::*)(AABB::Value) const>(_SC("opDivS"), &AABB::operator /)
.Func<AABB (AABB::*)(const AABB &) const>(_SC("opMod"), &AABB::operator %)
.Func<AABB (AABB::*)(AABB::Value) const>(_SC("opModS"), &AABB::operator %)
.Func<AABB (AABB::*)(void) const>(_SC("opUnPlus"), &AABB::operator +)
.Func<AABB (AABB::*)(void) const>(_SC("opUnMinus"), &AABB::operator -)
.Func<bool (AABB::*)(const AABB &) const>(_SC("opEqual"), &AABB::operator ==)
.Func<bool (AABB::*)(const AABB &) const>(_SC("opNotEqual"), &AABB::operator !=)
.Func<bool (AABB::*)(const AABB &) const>(_SC("opLessThan"), &AABB::operator <)
.Func<bool (AABB::*)(const AABB &) const>(_SC("opGreaterThan"), &AABB::operator >)
.Func<bool (AABB::*)(const AABB &) const>(_SC("opLessEqual"), &AABB::operator <=)
.Func<bool (AABB::*)(const AABB &) const>(_SC("opGreaterEqual"), &AABB::operator >=)
// Static Overloads
.StaticOverload< const AABB & (*)(CSStr) >(_SC("FromStr"), &GetAABB)
.StaticOverload< const AABB & (*)(CSStr, SQChar) >(_SC("FromStr"), &GetAABB)
2015-09-30 02:56:11 +02:00
);
}
} // Namespace:: SqMod