strafe-client/lib/common/src/aabb.rs

57 lines
1.2 KiB
Rust
Raw Normal View History

2024-08-27 20:33:50 +00:00
use crate::integer::{vec3,Planar64Vec3};
2024-01-30 00:15:49 +00:00
#[derive(Clone)]
pub struct Aabb{
min:Planar64Vec3,
max:Planar64Vec3,
}
2024-07-25 19:13:32 +00:00
impl Default for Aabb{
fn default()->Self{
2024-08-27 20:33:50 +00:00
Self{min:vec3::MAX,max:vec3::MIN}
2024-01-30 00:15:49 +00:00
}
}
impl Aabb{
2024-07-25 19:13:32 +00:00
pub const fn new(min:Planar64Vec3,max:Planar64Vec3)->Self{
2024-07-24 02:04:53 +00:00
Self{min,max}
}
2024-07-25 19:13:32 +00:00
pub const fn max(&self)->Planar64Vec3{
self.max
}
pub const fn min(&self)->Planar64Vec3{
self.min
}
2024-01-30 00:15:49 +00:00
pub fn grow(&mut self,point:Planar64Vec3){
self.min=self.min.min(point);
self.max=self.max.max(point);
}
pub fn join(&mut self,aabb:&Aabb){
self.min=self.min.min(aabb.min);
self.max=self.max.max(aabb.max);
}
pub fn inflate(&mut self,hs:Planar64Vec3){
self.min-=hs;
self.max+=hs;
}
pub fn intersects(&self,aabb:&Aabb)->bool{
2024-08-27 20:33:50 +00:00
let bvec=self.min.lt(aabb.max)&aabb.min.lt(self.max);
bvec.all()
2024-01-30 00:15:49 +00:00
}
pub fn size(&self)->Planar64Vec3{
self.max-self.min
}
pub fn center(&self)->Planar64Vec3{
2024-08-27 20:33:50 +00:00
self.min+(self.max-self.min)>>1
2024-01-30 00:15:49 +00:00
}
//probably use floats for area & volume because we don't care about precision
// pub fn area_weight(&self)->f32{
// let d=self.max-self.min;
// d.x*d.y+d.y*d.z+d.z*d.x
// }
// pub fn volume(&self)->f32{
// let d=self.max-self.min;
// d.x*d.y*d.z
// }
2024-07-24 02:04:53 +00:00
}