89 lines
2.2 KiB
Rust
Raw Normal View History

2023-09-27 02:12:20 -07:00
use crate::integer::Planar64Vec3;
2023-10-05 20:32:02 -07:00
#[derive(Debug,Clone,Copy,Hash,Eq,PartialEq)]
pub enum AabbFace{
Right,//+X
Top,
Back,
Left,
Bottom,
Front,
}
#[derive(Clone)]
2023-09-27 02:12:20 -07:00
pub struct Aabb{
pub min:Planar64Vec3,
pub max:Planar64Vec3,
2023-10-05 20:32:02 -07:00
}
2023-10-05 22:50:16 -07:00
impl Default for Aabb {
2023-09-27 02:12:20 -07:00
fn default()->Self {
Self{min:Planar64Vec3::MAX,max:Planar64Vec3::MIN}
2023-10-05 22:50:16 -07:00
}
}
2023-09-27 02:12:20 -07:00
impl Aabb{
const VERTEX_DATA:[Planar64Vec3;8]=[
Planar64Vec3::int( 1,-1,-1),
Planar64Vec3::int( 1, 1,-1),
Planar64Vec3::int( 1, 1, 1),
Planar64Vec3::int( 1,-1, 1),
Planar64Vec3::int(-1,-1, 1),
Planar64Vec3::int(-1, 1, 1),
Planar64Vec3::int(-1, 1,-1),
Planar64Vec3::int(-1,-1,-1),
2023-10-05 20:32:02 -07:00
];
2023-09-27 02:12:20 -07:00
pub fn grow(&mut self,point:Planar64Vec3){
2023-10-05 20:32:02 -07:00
self.min=self.min.min(point);
self.max=self.max.max(point);
}
2023-09-27 02:12:20 -07:00
pub fn join(&mut self,aabb:&Aabb){
2023-10-05 20:32:25 -07:00
self.min=self.min.min(aabb.min);
self.max=self.max.max(aabb.max);
}
2023-09-27 02:12:20 -07:00
pub fn inflate(&mut self,hs:Planar64Vec3){
2023-10-05 22:50:16 -07:00
self.min-=hs;
self.max+=hs;
}
pub fn intersects(&self,aabb:&Aabb)->bool{
(self.min.cmplt(aabb.max)&aabb.min.cmplt(self.max)).all()
}
2023-09-27 02:12:20 -07:00
pub fn normal(face:AabbFace)->Planar64Vec3{
2023-10-05 20:32:02 -07:00
match face {
2023-09-27 02:12:20 -07:00
AabbFace::Right=>Planar64Vec3::int(1,0,0),
AabbFace::Top=>Planar64Vec3::int(0,1,0),
AabbFace::Back=>Planar64Vec3::int(0,0,1),
AabbFace::Left=>Planar64Vec3::int(-1,0,0),
AabbFace::Bottom=>Planar64Vec3::int(0,-1,0),
AabbFace::Front=>Planar64Vec3::int(0,0,-1),
2023-10-05 20:32:02 -07:00
}
}
2023-09-27 02:12:20 -07:00
pub fn unit_vertices()->[Planar64Vec3;8] {
2023-10-05 20:32:02 -07:00
return Self::VERTEX_DATA;
}
2023-09-27 02:12:20 -07:00
// pub fn face(&self,face:AabbFace)->Aabb {
// let mut aabb=self.clone();
// //in this implementation face = worldspace aabb face
// match face {
// AabbFace::Right => aabb.min.x=aabb.max.x,
// AabbFace::Top => aabb.min.y=aabb.max.y,
// AabbFace::Back => aabb.min.z=aabb.max.z,
// AabbFace::Left => aabb.max.x=aabb.min.x,
// AabbFace::Bottom => aabb.max.y=aabb.min.y,
// AabbFace::Front => aabb.max.z=aabb.min.z,
// }
// return aabb;
// }
pub fn center(&self)->Planar64Vec3{
return self.min.midpoint(self.max)
2023-10-05 20:32:25 -07:00
}
//probably use floats for area & volume because we don't care about precision
2023-09-27 02:12:20 -07:00
// 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
// }
2023-10-05 20:32:02 -07:00
}