diff options
| author | Sébastien Crozet <developer@crozet.re> | 2020-10-27 09:57:26 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2020-10-27 09:57:26 +0100 |
| commit | 93153f5d93358e83c8a4ca2b7195bf9aae95ffb9 (patch) | |
| tree | 16ccb1aedc30d5c09d59e6ee5c7faa987e67b202 /src_testbed/physx_backend.rs | |
| parent | f8acf6a5e9d3ba537dac6502b0e0541236b418c5 (diff) | |
| parent | ffbc3c02c7d328d5c48a3efb84d35f5911f1880b (diff) | |
| download | rapier-93153f5d93358e83c8a4ca2b7195bf9aae95ffb9.tar.gz rapier-93153f5d93358e83c8a4ca2b7195bf9aae95ffb9.tar.bz2 rapier-93153f5d93358e83c8a4ca2b7195bf9aae95ffb9.zip | |
Merge pull request #41 from dimforge/cylinder
Add cylinder and cone support + use a trait-object for shapes.
Diffstat (limited to 'src_testbed/physx_backend.rs')
| -rw-r--r-- | src_testbed/physx_backend.rs | 45 |
1 files changed, 23 insertions, 22 deletions
diff --git a/src_testbed/physx_backend.rs b/src_testbed/physx_backend.rs index ec2e2bf..74d6af2 100644 --- a/src_testbed/physx_backend.rs +++ b/src_testbed/physx_backend.rs @@ -6,7 +6,7 @@ use rapier::counters::Counters; use rapier::dynamics::{ IntegrationParameters, JointParams, JointSet, RigidBodyHandle, RigidBodySet, }; -use rapier::geometry::{Collider, ColliderSet, Shape}; +use rapier::geometry::{Collider, ColliderSet}; use rapier::utils::WBasis; use std::collections::HashMap; @@ -422,27 +422,29 @@ fn physx_collider_from_rapier_collider( collider: &Collider, ) -> Option<(ColliderDesc, Isometry3<f32>)> { let mut local_pose = *collider.position_wrt_parent(); - let desc = match collider.shape() { - Shape::Cuboid(cuboid) => ColliderDesc::Box( + let shape = collider.shape(); + + let desc = if let Some(cuboid) = shape.as_cuboid() { + ColliderDesc::Box( cuboid.half_extents.x, cuboid.half_extents.y, cuboid.half_extents.z, - ), - Shape::Ball(ball) => ColliderDesc::Sphere(ball.radius), - Shape::Capsule(capsule) => { - let center = capsule.center(); - let mut dir = capsule.b - capsule.a; - - if dir.x < 0.0 { - dir = -dir; - } - - let rot = UnitQuaternion::rotation_between(&Vector3::x(), &dir); - local_pose *= - Translation3::from(center.coords) * rot.unwrap_or(UnitQuaternion::identity()); - ColliderDesc::Capsule(capsule.radius, capsule.height()) + ) + } else if let Some(ball) = shape.as_ball() { + ColliderDesc::Sphere(ball.radius) + } else if let Some(capsule) = shape.as_capsule() { + let center = capsule.center(); + let mut dir = capsule.segment.b - capsule.segment.a; + + if dir.x < 0.0 { + dir = -dir; } - Shape::Trimesh(trimesh) => ColliderDesc::TriMesh { + + let rot = UnitQuaternion::rotation_between(&Vector3::x(), &dir); + local_pose *= Translation3::from(center.coords) * rot.unwrap_or(UnitQuaternion::identity()); + ColliderDesc::Capsule(capsule.radius, capsule.height()) + } else if let Some(trimesh) = shape.as_trimesh() { + ColliderDesc::TriMesh { vertices: trimesh .vertices() .iter() @@ -450,11 +452,10 @@ fn physx_collider_from_rapier_collider( .collect(), indices: trimesh.flat_indices().to_vec(), mesh_scale: Vector3::repeat(1.0).into_glam(), - }, - _ => { - eprintln!("Creating a shape unknown to the PhysX backend."); - return None; } + } else { + eprintln!("Creating a shape unknown to the PhysX backend."); + return None; }; Some((desc, local_pose)) |
