#include "Vector3.h" #include Vector3 Vector3::operator+(const Vector3 & v) const { return Vector3(x+v.x, y+v.y, z+v.z); } Vector3 Vector3::operator*(const Vector3 & v) const { return Vector3(x*v.x, y*v.y, z*v.z); } void Vector3::operator*=(float scale) { x *= scale; y *= scale; z *= scale; } Vector3 Vector3::operator/(float scale) const { return Vector3(x/scale, y/scale, z/scale); } void Vector3::operator/=(float scale) { x /= scale; y /= scale; z /= scale; } void Vector3::operator=(const Vector3 & v) { x = v.x; y = v.y; z = v.z; } void Vector3::Normalize() { float magnitude = Magnitude(); x /= magnitude; y /= magnitude; z /= magnitude; } float Vector3::Magnitude() { return sqrtf(x*x + y*y + z*z); } Vector3 operator*(float f, const Vector3 & v) { return Vector3(f*v.x, f*v.y, f*v.z); } float Dot(const Vector3 & l, const Vector3 & r) { return l.x * r.x + l.y * r.y + l.z * r.z; }