diff options
| author | Sébastien Crozet <developer@crozet.re> | 2022-03-19 17:52:56 +0100 |
|---|---|---|
| committer | Sébastien Crozet <sebastien@crozet.re> | 2022-03-20 21:49:16 +0100 |
| commit | 063c638ec5906747e3ca85ee0c5f112c7775f797 (patch) | |
| tree | 498090f01c8cf8d69a35d03e123a1dfe006c54bf /src/pipeline | |
| parent | a9e3441ecd64d50b478ab5370fabe187ec9a5c39 (diff) | |
| download | rapier-063c638ec5906747e3ca85ee0c5f112c7775f797.tar.gz rapier-063c638ec5906747e3ca85ee0c5f112c7775f797.tar.bz2 rapier-063c638ec5906747e3ca85ee0c5f112c7775f797.zip | |
Combine contact events and intersection events into a single event type and flags
Diffstat (limited to 'src/pipeline')
| -rw-r--r-- | src/pipeline/event_handler.rs | 44 |
1 files changed, 18 insertions, 26 deletions
diff --git a/src/pipeline/event_handler.rs b/src/pipeline/event_handler.rs index c54acc2..5fa90c6 100644 --- a/src/pipeline/event_handler.rs +++ b/src/pipeline/event_handler.rs @@ -1,14 +1,13 @@ -use crate::geometry::{ContactEvent, ContactPair, IntersectionEvent}; +use crate::geometry::{CollisionEvent, ContactPair}; use crossbeam::channel::Sender; bitflags::bitflags! { #[cfg_attr(feature = "serde-serialize", derive(Serialize, Deserialize))] /// Flags affecting the events generated for this collider. pub struct ActiveEvents: u32 { - /// If set, Rapier will call `EventHandler::handle_intersection_event` whenever relevant for this collider. - const INTERSECTION_EVENTS = 0b0001; - /// If set, Rapier will call `PhysicsHooks::handle_contact_event` whenever relevant for this collider. - const CONTACT_EVENTS = 0b0010; + /// If set, Rapier will call `EventHandler::handle_intersection_event` and + /// `EventHandler::handle_contact_event` whenever relevant for this collider. + const COLLISION_EVENTS = 0b0001; } } @@ -22,47 +21,40 @@ impl Default for ActiveEvents { /// /// Implementors of this trait will typically collect these events for future processing. pub trait EventHandler: Send + Sync { - /// Handle an intersection event. + /// Handle a collision event. /// /// A intersection event is emitted when the state of intersection between two colliders changes. - fn handle_intersection_event(&self, event: IntersectionEvent); + fn handle_intersection_event(&self, event: CollisionEvent); /// Handle a contact event. /// /// A contact event is emitted when two collider start or stop touching, independently from the /// number of contact points involved. - fn handle_contact_event(&self, event: ContactEvent, contact_pair: &ContactPair); + fn handle_contact_event(&self, event: CollisionEvent, contact_pair: &ContactPair); } impl EventHandler for () { - fn handle_intersection_event(&self, _event: IntersectionEvent) {} - fn handle_contact_event(&self, _event: ContactEvent, _contact_pair: &ContactPair) {} + fn handle_intersection_event(&self, _event: CollisionEvent) {} + fn handle_contact_event(&self, _event: CollisionEvent, _contact_pair: &ContactPair) {} } -/// A physics event handler that collects events into a crossbeam channel. +/// A collision event handler that collects events into a crossbeam channel. pub struct ChannelEventCollector { - intersection_event_sender: Sender<IntersectionEvent>, - contact_event_sender: Sender<ContactEvent>, + event_sender: Sender<CollisionEvent>, } impl ChannelEventCollector { - /// Initialize a new physics event handler from crossbeam channel senders. - pub fn new( - intersection_event_sender: Sender<IntersectionEvent>, - contact_event_sender: Sender<ContactEvent>, - ) -> Self { - Self { - intersection_event_sender, - contact_event_sender, - } + /// Initialize a new collision event handler from crossbeam channel senders. + pub fn new(event_sender: Sender<CollisionEvent>) -> Self { + Self { event_sender } } } impl EventHandler for ChannelEventCollector { - fn handle_intersection_event(&self, event: IntersectionEvent) { - let _ = self.intersection_event_sender.send(event); + fn handle_intersection_event(&self, event: CollisionEvent) { + let _ = self.event_sender.send(event); } - fn handle_contact_event(&self, event: ContactEvent, _: &ContactPair) { - let _ = self.contact_event_sender.send(event); + fn handle_contact_event(&self, event: CollisionEvent, _: &ContactPair) { + let _ = self.event_sender.send(event); } } |
