Add methods to read the mass or volume of a collider.
This commit is contained in:
@@ -237,12 +237,32 @@ impl Collider {
|
||||
&self.material
|
||||
}
|
||||
|
||||
/// The density of this collider, if set.
|
||||
pub fn density(&self) -> Option<Real> {
|
||||
/// 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) => Some(*density),
|
||||
ColliderMassProps::Mass(_) => None,
|
||||
ColliderMassProps::MassProperties(_) => None,
|
||||
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) => self.shape.mass_properties(*density).mass(),
|
||||
ColliderMassProps::Mass(mass) => *mass,
|
||||
ColliderMassProps::MassProperties(mprops) => mprops.mass(),
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -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);
|
||||
|
||||
Reference in New Issue
Block a user