mirror of
https://github.com/lisk77/comet.git
synced 2025-10-23 21:38:50 +00:00
feat: added more vector functions to the InnerSpace
trait
This commit is contained in:
parent
f7d29f49d5
commit
531609e95b
1 changed files with 109 additions and 45 deletions
|
@ -6,7 +6,13 @@ use std::ops::*;
|
||||||
pub trait InnerSpace {
|
pub trait InnerSpace {
|
||||||
fn dot(&self, other: &Self) -> f32;
|
fn dot(&self, other: &Self) -> f32;
|
||||||
fn dist(&self, other: &Self) -> f32;
|
fn dist(&self, other: &Self) -> f32;
|
||||||
fn v_angle(&self, other: &Self) -> f32;
|
fn angle(&self, other: &Self) -> f32;
|
||||||
|
fn length(&self) -> f32;
|
||||||
|
fn normalize(&self) -> Self;
|
||||||
|
fn normalize_mut(&mut self);
|
||||||
|
fn project_onto(&self, other: &Self) -> Self;
|
||||||
|
fn reflect(&self, normal: &Self) -> Self;
|
||||||
|
fn lerp(&self, other: &Self, t: f32) -> Self;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ##################################################
|
// ##################################################
|
||||||
|
@ -50,18 +56,6 @@ impl Vec2 {
|
||||||
pub fn set_y(&mut self, new_y: f32) {
|
pub fn set_y(&mut self, new_y: f32) {
|
||||||
self.y = new_y;
|
self.y = new_y;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn length(&self) -> f32 {
|
|
||||||
(self.x * self.x + self.y * self.y).sqrt()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn normalize(&self) -> Self {
|
|
||||||
let factor = 1.0 / self.length();
|
|
||||||
Vec2 {
|
|
||||||
x: factor * self.x,
|
|
||||||
y: factor * self.y,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Add<Vec2> for Vec2 {
|
impl Add<Vec2> for Vec2 {
|
||||||
|
@ -410,19 +404,6 @@ impl Vec3 {
|
||||||
pub fn set_z(&mut self, new_z: f32) {
|
pub fn set_z(&mut self, new_z: f32) {
|
||||||
self.z = new_z;
|
self.z = new_z;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn length(&self) -> f32 {
|
|
||||||
(self.x * self.x + self.y * self.y + self.z * self.z).sqrt()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn normalize(&self) -> Self {
|
|
||||||
let factor = 1.0 / self.length();
|
|
||||||
Vec3 {
|
|
||||||
x: factor * self.x,
|
|
||||||
y: factor * self.y,
|
|
||||||
z: factor * self.z,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Add<Vec3> for Vec3 {
|
impl Add<Vec3> for Vec3 {
|
||||||
|
@ -736,20 +717,6 @@ impl Vec4 {
|
||||||
Vec4 { x, y, z, w }
|
Vec4 { x, y, z, w }
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn length(&self) -> f32 {
|
|
||||||
(self.x * self.x + self.y * self.y + self.z * self.z + self.w * self.w).sqrt()
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn normalize(&self) -> Self {
|
|
||||||
let factor = 1.0 / self.length();
|
|
||||||
Vec4 {
|
|
||||||
x: factor * self.x,
|
|
||||||
y: factor * self.y,
|
|
||||||
z: factor * self.z,
|
|
||||||
w: factor * self.w,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn x(&self) -> f32 {
|
pub fn x(&self) -> f32 {
|
||||||
self.x
|
self.x
|
||||||
}
|
}
|
||||||
|
@ -881,10 +848,40 @@ impl InnerSpace for Vec2 {
|
||||||
.length()
|
.length()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn v_angle(&self, other: &Self) -> f32 {
|
fn angle(&self, other: &Self) -> f32 {
|
||||||
//debug!("{:?}", dot(self,other)/(self.length()*other.length()));
|
|
||||||
acos(self.dot(other) / (self.length() * other.length()))
|
acos(self.dot(other) / (self.length() * other.length()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn length(&self) -> f32 {
|
||||||
|
(self.x * self.x + self.y * self.y).sqrt()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn normalize(&self) -> Self {
|
||||||
|
let factor = 1.0 / self.length();
|
||||||
|
Vec2 {
|
||||||
|
x: factor * self.x,
|
||||||
|
y: factor * self.y,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn normalize_mut(&mut self) {
|
||||||
|
let factor = 1.0 / self.length();
|
||||||
|
self.x *= factor;
|
||||||
|
self.y *= factor;
|
||||||
|
}
|
||||||
|
|
||||||
|
fn project_onto(&self, other: &Self) -> Self {
|
||||||
|
let factor = self.dot(other) / other.dot(other);
|
||||||
|
*other * factor
|
||||||
|
}
|
||||||
|
|
||||||
|
fn reflect(&self, normal: &Self) -> Self {
|
||||||
|
*self - *normal * 2.0 * self.dot(normal)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn lerp(&self, other: &Self, t: f32) -> Self {
|
||||||
|
*self * (1.0 - t) + *other * t
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl InnerSpace for Vec3 {
|
impl InnerSpace for Vec3 {
|
||||||
|
@ -901,9 +898,42 @@ impl InnerSpace for Vec3 {
|
||||||
.length()
|
.length()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn v_angle(&self, other: &Self) -> f32 {
|
fn angle(&self, other: &Self) -> f32 {
|
||||||
acos(self.dot(other) / (self.length() * other.length()))
|
acos(self.dot(other) / (self.length() * other.length()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn length(&self) -> f32 {
|
||||||
|
(self.x * self.x + self.y * self.y + self.z * self.z).sqrt()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn normalize(&self) -> Self {
|
||||||
|
let factor = 1.0 / self.length();
|
||||||
|
Vec3 {
|
||||||
|
x: factor * self.x,
|
||||||
|
y: factor * self.y,
|
||||||
|
z: factor * self.z,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn normalize_mut(&mut self) {
|
||||||
|
let factor = 1.0 / self.length();
|
||||||
|
self.x *= factor;
|
||||||
|
self.y *= factor;
|
||||||
|
self.z *= factor;
|
||||||
|
}
|
||||||
|
|
||||||
|
fn project_onto(&self, other: &Self) -> Self {
|
||||||
|
let factor = self.dot(other) / other.dot(other);
|
||||||
|
*other * factor
|
||||||
|
}
|
||||||
|
|
||||||
|
fn reflect(&self, normal: &Self) -> Self {
|
||||||
|
*self - *normal * 2.0 * self.dot(normal)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn lerp(&self, other: &Self, t: f32) -> Self {
|
||||||
|
*self * (1.0 - t) + *other * t
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl InnerSpace for Vec4 {
|
impl InnerSpace for Vec4 {
|
||||||
|
@ -921,9 +951,44 @@ impl InnerSpace for Vec4 {
|
||||||
.length()
|
.length()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn v_angle(&self, other: &Self) -> f32 {
|
fn angle(&self, other: &Self) -> f32 {
|
||||||
acos(self.dot(other) / (self.length() * other.length()))
|
acos(self.dot(other) / (self.length() * other.length()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn length(&self) -> f32 {
|
||||||
|
(self.x * self.x + self.y * self.y + self.z * self.z + self.w * self.w).sqrt()
|
||||||
|
}
|
||||||
|
|
||||||
|
fn normalize(&self) -> Self {
|
||||||
|
let factor = 1.0 / self.length();
|
||||||
|
Vec4 {
|
||||||
|
x: factor * self.x,
|
||||||
|
y: factor * self.y,
|
||||||
|
z: factor * self.z,
|
||||||
|
w: factor * self.w,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn normalize_mut(&mut self) {
|
||||||
|
let factor = 1.0 / self.length();
|
||||||
|
self.x *= factor;
|
||||||
|
self.y *= factor;
|
||||||
|
self.z *= factor;
|
||||||
|
self.w *= factor;
|
||||||
|
}
|
||||||
|
|
||||||
|
fn project_onto(&self, other: &Self) -> Self {
|
||||||
|
let factor = self.dot(other) / other.dot(other);
|
||||||
|
*other * factor
|
||||||
|
}
|
||||||
|
|
||||||
|
fn reflect(&self, normal: &Self) -> Self {
|
||||||
|
*self - *normal * 2.0 * self.dot(normal)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn lerp(&self, other: &Self, t: f32) -> Self {
|
||||||
|
*self * (1.0 - t) + *other * t
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
macro_rules! generate_swizzles2 {
|
macro_rules! generate_swizzles2 {
|
||||||
|
@ -974,7 +1039,6 @@ macro_rules! generate_swizzles4 {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
generate_swizzles2!(Vec2,
|
generate_swizzles2!(Vec2,
|
||||||
xx => (x, x), xy => (x, y),
|
xx => (x, x), xy => (x, y),
|
||||||
yx => (y, x), yy => (y, y)
|
yx => (y, x), yy => (y, y)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue