diff options
| author | Sébastien Crozet <developer@crozet.re> | 2020-09-01 17:05:24 +0200 |
|---|---|---|
| committer | Sébastien Crozet <developer@crozet.re> | 2020-09-01 17:05:24 +0200 |
| commit | 2f2a073ce47eaa17f44d88b9dc6cc56362c374e2 (patch) | |
| tree | 0b32867995fecb4cd4f0fbd5de17c4e8bd0d9fd8 /src/dynamics/rigid_body.rs | |
| parent | 9622827dc6aadb391512b95381edb1efc26b1b90 (diff) | |
| download | rapier-2f2a073ce47eaa17f44d88b9dc6cc56362c374e2.tar.gz rapier-2f2a073ce47eaa17f44d88b9dc6cc56362c374e2.tar.bz2 rapier-2f2a073ce47eaa17f44d88b9dc6cc56362c374e2.zip | |
Fix mass property update when adding a collider.
Diffstat (limited to 'src/dynamics/rigid_body.rs')
| -rw-r--r-- | src/dynamics/rigid_body.rs | 10 |
1 files changed, 7 insertions, 3 deletions
diff --git a/src/dynamics/rigid_body.rs b/src/dynamics/rigid_body.rs index d9cddd1..a2fcacc 100644 --- a/src/dynamics/rigid_body.rs +++ b/src/dynamics/rigid_body.rs @@ -139,7 +139,9 @@ impl RigidBody { /// Adds a collider to this rigid-body. pub(crate) fn add_collider_internal(&mut self, handle: ColliderHandle, coll: &Collider) { - let mass_properties = coll.mass_properties(); + let mass_properties = coll + .mass_properties() + .transform_by(coll.position_wrt_parent()); self.colliders.push(handle); self.mass_properties += mass_properties; self.update_world_mass_properties(); @@ -149,7 +151,9 @@ impl RigidBody { pub(crate) fn remove_collider_internal(&mut self, handle: ColliderHandle, coll: &Collider) { if let Some(i) = self.colliders.iter().position(|e| *e == handle) { self.colliders.swap_remove(i); - let mass_properties = coll.mass_properties(); + let mass_properties = coll + .mass_properties() + .transform_by(coll.position_wrt_parent()); self.mass_properties -= mass_properties; self.update_world_mass_properties(); } @@ -189,7 +193,7 @@ impl RigidBody { } fn integrate_velocity(&self, dt: f32) -> Isometry<f32> { - let com = &self.position * self.mass_properties.local_com; // FIXME: use non-origin center of masses. + let com = &self.position * self.mass_properties.local_com; let shift = Translation::from(com.coords); shift * Isometry::new(self.linvel * dt, self.angvel * dt) * shift.inverse() } |
