blob: 3460c5686716aee8cd3e306268a96358c71b72b1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
#ifndef VEC3_H
#define VEC3_H
#include <iostream>
#include "fml.h"
namespace fml {
class vec3 {
public:
scalar v[3];
public:
vec3();
vec3(scalar x);
vec3(scalar x, scalar y, scalar z);
scalar &operator[](int index);
scalar operator[](int index) const;
vec3 operator*(scalar scale) const;
vec3 operator/(scalar scale) const;
vec3 operator+(const vec3 &other) const;
vec3 operator-(const vec3 &other) const;
vec3 operator-() const;
const vec3 &operator*=(scalar scale);
const vec3 &operator/=(scalar scale);
const vec3 &operator+=(const vec3 &other);
const vec3 &operator-=(const vec3 &other);
scalar magnitude() const;
scalar magnitudeSquared() const;
vec3 normalize() const;
scalar dot(const vec3 &other) const;
vec3 cross(const vec3 &other) const;
};
vec3 operator*(scalar scale, const vec3 &v);
std::ostream &operator<<(std::ostream &output, const vec3 &v);
std::istream &operator>>(std::istream &input, vec3 &v);
}
#endif
|