From 27267d3bb01c009f3fe62c3ce7c39c072ee8eeaa Mon Sep 17 00:00:00 2001 From: Salman Abuhaimed <85521119+BKSalman@users.noreply.github.com> Date: Tue, 19 Jul 2022 12:14:31 +0300 Subject: [PATCH] simplified ground detection --- src/components.rs | 2 +- src/systems.rs | 43 +++++++++++++------------------------------ 2 files changed, 14 insertions(+), 31 deletions(-) diff --git a/src/components.rs b/src/components.rs index 4ad6f43..d444630 100644 --- a/src/components.rs +++ b/src/components.rs @@ -369,5 +369,5 @@ pub struct GroundDetection { #[derive(Component)] pub struct GroundSensor { pub ground_detection_entity: Entity, - pub intersecting_ground_entities: HashSet, + // pub intersecting_ground_entities: HashSet, // probably not needed anymore } diff --git a/src/systems.rs b/src/systems.rs index 96bec12..20afdcb 100644 --- a/src/systems.rs +++ b/src/systems.rs @@ -473,8 +473,8 @@ pub fn spawn_ground_sensor( .insert(GlobalTransform::default()) .insert(GroundSensor { ground_detection_entity: entity, - intersecting_ground_entities: - HashSet::new(), + // intersecting_ground_entities: + // HashSet::new(), // probably not needed anymore }); }, ); @@ -484,39 +484,22 @@ pub fn spawn_ground_sensor( pub fn ground_detection( mut ground_detectors: Query<&mut GroundDetection>, - mut ground_sensors: Query<(Entity, &mut GroundSensor)>, - mut collisions: EventReader, + ground_sensors: Query<(Entity, &GroundSensor)>, + rapier_context: Res, // rigid_bodies: Query<&RigidBody>, ) { - for (entity, mut ground_sensor) in - ground_sensors.iter_mut() - { - for collision in collisions.iter() { - match collision { - CollisionEvent::Started(a, b, _) => { - if a == &entity { - ground_sensor - .intersecting_ground_entities - .insert(*b); - } - } - CollisionEvent::Stopped(a, b, _) => { - if a == &entity { - ground_sensor - .intersecting_ground_entities - .remove(&b); - } - } + for (entity, ground_sensor) in ground_sensors.iter() { + let mut intersection = false; + for (_collider1, _collider2, intersecting) in rapier_context.intersections_with(entity) { + if intersecting { + intersection = intersecting; } } - if let Ok(mut ground_detection) = ground_detectors - .get_mut(ground_sensor.ground_detection_entity) + .get_mut(ground_sensor.ground_detection_entity) { - ground_detection.on_ground = ground_sensor - .intersecting_ground_entities - .len() - > 0; + ground_detection.on_ground = intersection; } } -} + +} \ No newline at end of file