diff options
| author | Sébastien Crozet <developer@crozet.re> | 2020-11-02 19:00:12 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-11-02 19:00:12 +0100 |
| commit | b4bf737f02872e152fb9a7804d0759095ee55e24 (patch) | |
| tree | 63662f1a0c3dbe083cc64903bcb42cedec62d254 /src_testbed | |
| parent | 9c72a0458b89741ce31744efa2d33f4b75de0d79 (diff) | |
| parent | a4a4ddb5b4f03a6cf855ff4120803863e3c60a4f (diff) | |
| download | rapier-b4bf737f02872e152fb9a7804d0759095ee55e24.tar.gz rapier-b4bf737f02872e152fb9a7804d0759095ee55e24.tar.bz2 rapier-b4bf737f02872e152fb9a7804d0759095ee55e24.zip | |
Merge pull request #50 from dimforge/joint_removal
Implement joint removal.
Diffstat (limited to 'src_testbed')
| -rw-r--r-- | src_testbed/testbed.rs | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/src_testbed/testbed.rs b/src_testbed/testbed.rs index 3bf720a..7160b3b 100644 --- a/src_testbed/testbed.rs +++ b/src_testbed/testbed.rs @@ -847,6 +847,16 @@ impl Testbed { ); } } + WindowEvent::Key(Key::J, Action::Release, _) => { + // Delete 10% of the remaining joints. + let joints: Vec<_> = self.physics.joints.iter().map(|e| e.0).collect(); + let num_to_delete = (joints.len() / 10).max(1); + for to_delete in &joints[..num_to_delete] { + self.physics + .joints + .remove(*to_delete, &mut self.physics.bodies, true); + } + } WindowEvent::CursorPos(x, y, _) => { self.cursor_pos.x = x as f32; self.cursor_pos.y = y as f32; |
