2017-10-31 17:12:50 +00:00
|
|
|
#pragma once
|
|
|
|
#ifndef ES_CORE_MATH_VECTOR3F_H
|
|
|
|
#define ES_CORE_MATH_VECTOR3F_H
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-11-13 22:16:38 +00:00
|
|
|
#include "math/Misc.h"
|
2017-10-28 20:24:35 +00:00
|
|
|
#include <assert.h>
|
|
|
|
|
|
|
|
class Vector2f;
|
|
|
|
class Vector4f;
|
|
|
|
|
|
|
|
class Vector3f
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
|
2017-11-13 22:16:38 +00:00
|
|
|
Vector3f() { }
|
|
|
|
Vector3f(const float _f) : mX(_f), mY(_f), mZ(_f) { }
|
|
|
|
Vector3f(const float _x, const float _y, const float _z) : mX(_x), mY(_y), mZ(_z) { }
|
|
|
|
explicit Vector3f(const Vector2f& _v) : mX(((Vector3f&)_v).mX), mY(((Vector3f&)_v).mY), mZ(0) { }
|
|
|
|
explicit Vector3f(const Vector2f& _v, const float _z) : mX(((Vector3f&)_v).mX), mY(((Vector3f&)_v).mY), mZ(_z) { }
|
|
|
|
explicit Vector3f(const Vector4f& _v) : mX(((Vector3f&)_v).mX), mY(((Vector3f&)_v).mY), mZ(((Vector3f&)_v).mZ) { }
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-11-22 21:29:52 +00:00
|
|
|
const bool operator==(const Vector3f& _other) const { return ((mX == _other.mX) && (mY == _other.mY) && (mZ == _other.mZ)); }
|
|
|
|
const bool operator!=(const Vector3f& _other) const { return ((mX != _other.mX) || (mY != _other.mY) || (mZ != _other.mZ)); }
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-11-22 21:29:52 +00:00
|
|
|
const Vector3f operator+ (const Vector3f& _other) const { return { mX + _other.mX, mY + _other.mY, mZ + _other.mZ }; }
|
|
|
|
const Vector3f operator- (const Vector3f& _other) const { return { mX - _other.mX, mY - _other.mY, mZ - _other.mZ }; }
|
|
|
|
const Vector3f operator* (const Vector3f& _other) const { return { mX * _other.mX, mY * _other.mY, mZ * _other.mZ }; }
|
|
|
|
const Vector3f operator/ (const Vector3f& _other) const { return { mX / _other.mX, mY / _other.mY, mZ / _other.mZ }; }
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-11-22 21:29:52 +00:00
|
|
|
const Vector3f operator+ (const float& _other) const { return { mX + _other, mY + _other, mZ + _other }; }
|
|
|
|
const Vector3f operator- (const float& _other) const { return { mX - _other, mY - _other, mZ - _other }; }
|
|
|
|
const Vector3f operator* (const float& _other) const { return { mX * _other, mY * _other, mZ * _other }; }
|
|
|
|
const Vector3f operator/ (const float& _other) const { return { mX / _other, mY / _other, mZ / _other }; }
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-11-22 21:29:52 +00:00
|
|
|
const Vector3f operator- () const { return { -mX , -mY, -mZ }; }
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-11-22 21:29:52 +00:00
|
|
|
Vector3f& operator+=(const Vector3f& _other) { *this = *this + _other; return *this; }
|
|
|
|
Vector3f& operator-=(const Vector3f& _other) { *this = *this - _other; return *this; }
|
|
|
|
Vector3f& operator*=(const Vector3f& _other) { *this = *this * _other; return *this; }
|
|
|
|
Vector3f& operator/=(const Vector3f& _other) { *this = *this / _other; return *this; }
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-11-22 21:29:52 +00:00
|
|
|
Vector3f& operator+=(const float& _other) { *this = *this + _other; return *this; }
|
|
|
|
Vector3f& operator-=(const float& _other) { *this = *this - _other; return *this; }
|
|
|
|
Vector3f& operator*=(const float& _other) { *this = *this * _other; return *this; }
|
|
|
|
Vector3f& operator/=(const float& _other) { *this = *this / _other; return *this; }
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-11-22 21:29:52 +00:00
|
|
|
float& operator[](const int _index) { assert(_index < 3 && "index out of range"); return (&mX)[_index]; }
|
|
|
|
const float& operator[](const int _index) const { assert(_index < 3 && "index out of range"); return (&mX)[_index]; }
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2018-02-15 14:05:47 +00:00
|
|
|
inline float& x() { return mX; }
|
|
|
|
inline float& y() { return mY; }
|
|
|
|
inline float& z() { return mZ; }
|
|
|
|
inline const float& x() const { return mX; }
|
|
|
|
inline const float& y() const { return mY; }
|
|
|
|
inline const float& z() const { return mZ; }
|
2017-10-28 20:24:35 +00:00
|
|
|
|
|
|
|
inline Vector2f& v2() { return *(Vector2f*)this; }
|
|
|
|
inline const Vector2f& v2() const { return *(Vector2f*)this; }
|
|
|
|
|
2017-11-13 22:16:38 +00:00
|
|
|
Vector3f& round();
|
2017-11-22 21:29:52 +00:00
|
|
|
Vector3f& lerp (const Vector3f& _start, const Vector3f& _end, const float _fraction);
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-11-22 21:29:52 +00:00
|
|
|
static const Vector3f Zero () { return { 0, 0, 0 }; }
|
2017-10-28 20:24:35 +00:00
|
|
|
static const Vector3f UnitX() { return { 1, 0, 0 }; }
|
|
|
|
static const Vector3f UnitY() { return { 0, 1, 0 }; }
|
|
|
|
static const Vector3f UnitZ() { return { 0, 0, 1 }; }
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
float mX;
|
|
|
|
float mY;
|
|
|
|
float mZ;
|
|
|
|
|
2017-11-13 22:16:38 +00:00
|
|
|
}; // Vector3f
|
2017-10-28 20:24:35 +00:00
|
|
|
|
2017-10-31 17:12:50 +00:00
|
|
|
#endif // ES_CORE_MATH_VECTOR3F_H
|