diff options
| author | Loek Le Blansch <loek@pipeframe.xyz> | 2024-12-11 18:54:56 +0100 | 
|---|---|---|
| committer | Loek Le Blansch <loek@pipeframe.xyz> | 2024-12-11 18:54:56 +0100 | 
| commit | 904b853a277c3fcd0f84561b6e45bcbd4f0b25c6 (patch) | |
| tree | 84b8b3d3c29471e4edc2707444b21ac406ee2799 /src/crepe/api/Vector2.hpp | |
| parent | 876746db205b259430b6b438227c986dbf0cb59d (diff) | |
| parent | 30c17c98e54c1534664de08ca3838c40c859d166 (diff) | |
merge master
Diffstat (limited to 'src/crepe/api/Vector2.hpp')
| -rw-r--r-- | src/crepe/api/Vector2.hpp | 48 | 
1 files changed, 48 insertions, 0 deletions
| diff --git a/src/crepe/api/Vector2.hpp b/src/crepe/api/Vector2.hpp index cad15f8..ff53cb0 100644 --- a/src/crepe/api/Vector2.hpp +++ b/src/crepe/api/Vector2.hpp @@ -1,5 +1,7 @@  #pragma once +#include <cmath> +  #include "Vector2.h"  namespace crepe { @@ -115,4 +117,50 @@ bool Vector2<T>::operator!=(const Vector2<T> & other) const {  	return !(*this == other);  } +template <class T> +void Vector2<T>::truncate(T max) { +	if (length() > max) { +		normalize(); +		*this *= max; +	} +} + +template <class T> +void Vector2<T>::normalize() { +	T len = length(); +	if (len > 0) { +		*this /= len; +	} +} + +template <class T> +T Vector2<T>::length() const { +	return std::sqrt(x * x + y * y); +} + +template <class T> +T Vector2<T>::length_squared() const { +	return x * x + y * y; +} + +template <class T> +T Vector2<T>::dot(const Vector2<T> & other) const { +	return x * other.x + y * other.y; +} + +template <class T> +T Vector2<T>::distance(const Vector2<T> & other) const { +	return (*this - other).length(); +} + +template <class T> +T Vector2<T>::distance_squared(const Vector2<T> & other) const { +	return (*this - other).length_squared(); +} + +template <class T> +Vector2<T> Vector2<T>::perpendicular() const { +	return {-y, x}; +} +  } // namespace crepe |