2024-01-30 00:15:49 +00:00
|
|
|
use crate::integer::Planar64Vec3;
|
|
|
|
|
|
|
|
#[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-01-30 00:15:49 +00:00
|
|
|
Self{min:Planar64Vec3::MAX,max:Planar64Vec3::MIN}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
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{
|
|
|
|
(self.min.cmplt(aabb.max)&aabb.min.cmplt(self.max)).all()
|
|
|
|
}
|
|
|
|
pub fn size(&self)->Planar64Vec3{
|
|
|
|
self.max-self.min
|
|
|
|
}
|
|
|
|
pub fn center(&self)->Planar64Vec3{
|
|
|
|
self.min.midpoint(self.max)
|
|
|
|
}
|
|
|
|
//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
|
|
|
}
|