blob: 63c91182eb2b8d4b821b7f9d479e9be917d8df85 [file] [log] [blame]
#ifndef _NIMA_VEC2D_HPP_
#define _NIMA_VEC2D_HPP_
#include <cstddef>
namespace nima
{
class Mat2D;
class Vec2D
{
private:
float m_Buffer[2];
public:
Vec2D();
Vec2D(const Vec2D& copy);
Vec2D(float x, float y);
inline const float* values() const { return m_Buffer; }
float& operator[](std::size_t idx) { return m_Buffer[idx]; }
const float& operator[](std::size_t idx) const { return m_Buffer[idx]; }
static void transform(Vec2D& result, const Vec2D& a, const Mat2D& m);
static void subtract(Vec2D& result, const Vec2D& a, const Vec2D& b);
static void add(Vec2D& result, const Vec2D& a, const Vec2D& b);
static float length(const Vec2D& a);
static void copy(Vec2D& result, const Vec2D& a);
static void normalize(Vec2D& result, const Vec2D& a);
static float dot(const Vec2D& a, const Vec2D& b);
};
inline Vec2D operator*(const Mat2D& a, const Vec2D& b)
{
Vec2D result;
Vec2D::transform(result, b, a);
return result;
}
inline Vec2D operator-(const Vec2D& a, const Vec2D& b)
{
Vec2D result;
Vec2D::subtract(result, a, b);
return result;
}
inline Vec2D operator+(const Vec2D& a, const Vec2D& b)
{
Vec2D result;
Vec2D::add(result, a, b);
return result;
}
}
#endif