oxiphysics_geometry/implicit_geometry/sdfextrude_traits.rs
1//! # SdfExtrude - Trait Implementations
2//!
3//! This module contains trait implementations for `SdfExtrude`.
4//!
5//! ## Implemented Traits
6//!
7//! - `Sdf`
8//!
9//! 🤖 Generated with [SplitRS](https://github.com/cool-japan/splitrs)
10
11use super::functions::*;
12use super::types::SdfExtrude;
13
14impl<F: Fn([f64; 2]) -> f64 + Send + Sync> Sdf for SdfExtrude<F> {
15 fn dist(&self, p: [f64; 3]) -> f64 {
16 let d2 = (self.profile)([p[0], p[2]]);
17 let dy = p[1].abs() - self.half_height;
18 let out_lateral = d2.max(0.0);
19 let out_cap = dy.max(0.0);
20 let inside = d2.min(0.0).max(dy.min(0.0));
21 len2([out_lateral, out_cap]) + inside
22 }
23}