From 7831ebfc3109d4a4c2029f50e432dd1d4be9ef82 Mon Sep 17 00:00:00 2001 From: Sébastien Crozet Date: Tue, 5 Jul 2022 15:15:17 +0200 Subject: Add methods to read the mass or volume of a collider. --- src/geometry/collider.rs | 30 +++++++++++++++++++++++++----- src/geometry/collider_set.rs | 4 ++-- 2 files changed, 27 insertions(+), 7 deletions(-) (limited to 'src/geometry') diff --git a/src/geometry/collider.rs b/src/geometry/collider.rs index 421523f..7b0cc4c 100644 --- a/src/geometry/collider.rs +++ b/src/geometry/collider.rs @@ -237,12 +237,32 @@ impl Collider { &self.material } - /// The density of this collider, if set. - pub fn density(&self) -> Option { + /// The volume (or surface in 2D) of this collider. + pub fn volume(&self) -> Real { + self.shape.mass_properties(1.0).mass() + } + + /// The density of this collider. + pub fn density(&self) -> Real { + match &self.mprops { + ColliderMassProps::Density(density) => *density, + ColliderMassProps::Mass(mass) => { + let inv_volume = self.shape.mass_properties(1.0).inv_mass; + mass * inv_volume + } + ColliderMassProps::MassProperties(mprops) => { + let inv_volume = self.shape.mass_properties(1.0).inv_mass; + mprops.mass() * inv_volume + } + } + } + + /// The mass of this collider. + pub fn mass(&self) -> Real { match &self.mprops { - ColliderMassProps::Density(density) => Some(*density), - ColliderMassProps::Mass(_) => None, - ColliderMassProps::MassProperties(_) => None, + ColliderMassProps::Density(density) => self.shape.mass_properties(*density).mass(), + ColliderMassProps::Mass(mass) => *mass, + ColliderMassProps::MassProperties(mprops) => mprops.mass(), } } diff --git a/src/geometry/collider_set.rs b/src/geometry/collider_set.rs index b9f4ae3..b141445 100644 --- a/src/geometry/collider_set.rs +++ b/src/geometry/collider_set.rs @@ -137,7 +137,7 @@ impl ColliderSet { if let Some(parent_handle) = curr_parent { if let Some(rb) = bodies.get_mut(parent_handle) { - rb.remove_collider_internal(handle, &*collider); + rb.remove_collider_internal(handle); } } @@ -189,7 +189,7 @@ impl ColliderSet { if let Some(parent_rb) = bodies.get_mut_internal_with_modification_tracking(parent.handle) { - parent_rb.remove_collider_internal(handle, &collider); + parent_rb.remove_collider_internal(handle); if wake_up { islands.wake_up(bodies, parent.handle, true); -- cgit