forked from StrafesNET/strafe-project
relocate functions
This commit is contained in:
parent
4cc1a172bd
commit
1ef659e46a
@ -112,13 +112,6 @@ fn is_space_enclosed_4(
|
|||||||
const fn get_push_ray_0(point:Planar64Vec3)->Option<Ray>{
|
const fn get_push_ray_0(point:Planar64Vec3)->Option<Ray>{
|
||||||
Some(Ray{origin:point,direction:Planar64Vec3::ZERO})
|
Some(Ray{origin:point,direction:Planar64Vec3::ZERO})
|
||||||
}
|
}
|
||||||
const fn get_best_push_ray_and_indices_0(point:Planar64Vec3)->Option<(Ray,Indices)>{
|
|
||||||
match get_push_ray_0(point){
|
|
||||||
Some(ray)=>Some((ray,Indices::new_const())),
|
|
||||||
None=>None,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn get_push_ray_1(point:Planar64Vec3,c0:&Contact)->Option<Ray>{
|
fn get_push_ray_1(point:Planar64Vec3,c0:&Contact)->Option<Ray>{
|
||||||
let direction=solve1(c0)?;
|
let direction=solve1(c0)?;
|
||||||
let s0=decompose1(direction,c0.velocity)?;
|
let s0=decompose1(direction,c0.velocity)?;
|
||||||
@ -130,11 +123,6 @@ fn get_push_ray_1(point:Planar64Vec3,c0:&Contact)->Option<Ray>{
|
|||||||
)?;
|
)?;
|
||||||
Some(Ray{origin,direction})
|
Some(Ray{origin,direction})
|
||||||
}
|
}
|
||||||
fn get_best_push_ray_and_indices_1(point:Planar64Vec3,ci0:CI)->Option<(Ray,Indices)>{
|
|
||||||
get_push_ray_1(point,ci0.contact)
|
|
||||||
.map(|ray|(ray,Indices::from_iter([ci0.index])))
|
|
||||||
}
|
|
||||||
|
|
||||||
fn get_push_ray_2(point:Planar64Vec3,c0:&Contact,c1:&Contact)->Option<Ray>{
|
fn get_push_ray_2(point:Planar64Vec3,c0:&Contact,c1:&Contact)->Option<Ray>{
|
||||||
let direction=solve2(c0,c1)?;
|
let direction=solve2(c0,c1)?;
|
||||||
let (s0,s1)=decompose2(direction,c0.velocity,c1.velocity)?;
|
let (s0,s1)=decompose2(direction,c0.velocity,c1.velocity)?;
|
||||||
@ -147,6 +135,30 @@ fn get_push_ray_2(point:Planar64Vec3,c0:&Contact,c1:&Contact)->Option<Ray>{
|
|||||||
)?;
|
)?;
|
||||||
Some(Ray{origin,direction})
|
Some(Ray{origin,direction})
|
||||||
}
|
}
|
||||||
|
fn get_push_ray_3(point:Planar64Vec3,c0:&Contact,c1:&Contact,c2:&Contact)->Option<Ray>{
|
||||||
|
let direction=solve3(c0,c1,c2)?;
|
||||||
|
let (s0,s1,s2)=decompose3(direction,c0.velocity,c1.velocity,c2.velocity)?;
|
||||||
|
if s0<Planar64::ZERO||s1<Planar64::ZERO||s2<Planar64::ZERO{
|
||||||
|
return None;
|
||||||
|
}
|
||||||
|
let origin=point+solve3(
|
||||||
|
&c0.relative_to(point),
|
||||||
|
&c1.relative_to(point),
|
||||||
|
&c2.relative_to(point),
|
||||||
|
)?;
|
||||||
|
Some(Ray{origin,direction})
|
||||||
|
}
|
||||||
|
|
||||||
|
const fn get_best_push_ray_and_indices_0(point:Planar64Vec3)->Option<(Ray,Indices)>{
|
||||||
|
match get_push_ray_0(point){
|
||||||
|
Some(ray)=>Some((ray,Indices::new_const())),
|
||||||
|
None=>None,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fn get_best_push_ray_and_indices_1(point:Planar64Vec3,ci0:CI)->Option<(Ray,Indices)>{
|
||||||
|
get_push_ray_1(point,ci0.contact)
|
||||||
|
.map(|ray|(ray,Indices::from_iter([ci0.index])))
|
||||||
|
}
|
||||||
fn get_best_push_ray_and_indices_2(point:Planar64Vec3,ci0:CI,ci1:CI)->Option<(Ray,Indices)>{
|
fn get_best_push_ray_and_indices_2(point:Planar64Vec3,ci0:CI,ci1:CI)->Option<(Ray,Indices)>{
|
||||||
if is_space_enclosed_2(ci0.contact.normal,ci1.contact.normal){
|
if is_space_enclosed_2(ci0.contact.normal,ci1.contact.normal){
|
||||||
return None;
|
return None;
|
||||||
@ -161,20 +173,6 @@ fn get_best_push_ray_and_indices_2(point:Planar64Vec3,ci0:CI,ci1:CI)->Option<(Ra
|
|||||||
}
|
}
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_push_ray_3(point:Planar64Vec3,c0:&Contact,c1:&Contact,c2:&Contact)->Option<Ray>{
|
|
||||||
let direction=solve3(c0,c1,c2)?;
|
|
||||||
let (s0,s1,s2)=decompose3(direction,c0.velocity,c1.velocity,c2.velocity)?;
|
|
||||||
if s0<Planar64::ZERO||s1<Planar64::ZERO||s2<Planar64::ZERO{
|
|
||||||
return None;
|
|
||||||
}
|
|
||||||
let origin=point+solve3(
|
|
||||||
&c0.relative_to(point),
|
|
||||||
&c1.relative_to(point),
|
|
||||||
&c2.relative_to(point),
|
|
||||||
)?;
|
|
||||||
Some(Ray{origin,direction})
|
|
||||||
}
|
|
||||||
fn get_best_push_ray_and_indices_3(point:Planar64Vec3,ci0:CI,ci1:CI,ci2:CI)->Option<(Ray,Indices)>{
|
fn get_best_push_ray_and_indices_3(point:Planar64Vec3,ci0:CI,ci1:CI,ci2:CI)->Option<(Ray,Indices)>{
|
||||||
if is_space_enclosed_3(ci0.contact.normal,ci1.contact.normal,ci2.contact.normal){
|
if is_space_enclosed_3(ci0.contact.normal,ci1.contact.normal,ci2.contact.normal){
|
||||||
return None;
|
return None;
|
||||||
@ -200,7 +198,6 @@ fn get_best_push_ray_and_indices_3(point:Planar64Vec3,ci0:CI,ci1:CI,ci2:CI)->Opt
|
|||||||
}
|
}
|
||||||
return None;
|
return None;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn get_best_push_ray_and_indices_4(point:Planar64Vec3,ci0:CI,ci1:CI,ci2:CI,ci3:CI)->Option<(Ray,Indices)>{
|
fn get_best_push_ray_and_indices_4(point:Planar64Vec3,ci0:CI,ci1:CI,ci2:CI,ci3:CI)->Option<(Ray,Indices)>{
|
||||||
if is_space_enclosed_4(ci0.contact.normal,ci1.contact.normal,ci2.contact.normal,ci3.contact.normal){
|
if is_space_enclosed_4(ci0.contact.normal,ci1.contact.normal,ci2.contact.normal,ci3.contact.normal){
|
||||||
return None;
|
return None;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user