oxiphysics_geometry/implicit_geometry/
sdfextrude_traits.rs1#[allow(unused_imports)]
12use super::functions::*;
13#[allow(unused_imports)]
14use super::functions::*;
15use super::types::SdfExtrude;
16
17impl<F: Fn([f64; 2]) -> f64 + Send + Sync> Sdf for SdfExtrude<F> {
18 fn dist(&self, p: [f64; 3]) -> f64 {
19 let d2 = (self.profile)([p[0], p[2]]);
20 let dy = p[1].abs() - self.half_height;
21 let out_lateral = d2.max(0.0);
22 let out_cap = dy.max(0.0);
23 let inside = d2.min(0.0).max(dy.min(0.0));
24 len2([out_lateral, out_cap]) + inside
25 }
26}