Struct heron::rapier_plugin::rapier::geometry::NarrowPhase [−]
pub struct NarrowPhase { /* fields omitted */ }
The narrow-phase responsible for computing precise contact information between colliders.
Implementations
impl NarrowPhase
pub fn new() -> NarrowPhase
Creates a new empty narrow-phase.
pub fn with_query_dispatcher<D>(d: D) -> NarrowPhase where
D: 'static + PersistentQueryDispatcher<ContactManifoldData, ContactData>,
D: 'static + PersistentQueryDispatcher<ContactManifoldData, ContactData>,
Creates a new empty narrow-phase with a custom query dispatcher.
pub fn query_dispatcher(
&self
) -> &dyn PersistentQueryDispatcher<ContactManifoldData, ContactData>
&self
) -> &dyn PersistentQueryDispatcher<ContactManifoldData, ContactData>
The query dispatcher used by this narrow-phase to select the right collision-detection algorithms depending of the shape types.
pub fn contact_graph(&self) -> &InteractionGraph<ColliderHandle, ContactPair>
The contact graph containing all contact pairs and their contact information.
pub fn intersection_graph(&self) -> &InteractionGraph<ColliderHandle, bool>
The intersection graph containing all intersection pairs and their intersection information.
pub fn contacts_with(
&self,
collider: ColliderHandle
) -> Option<impl Iterator<Item = (ColliderHandle, ColliderHandle, &ContactPair)>>
&self,
collider: ColliderHandle
) -> Option<impl Iterator<Item = (ColliderHandle, ColliderHandle, &ContactPair)>>
All the contacts involving the given collider.
pub fn intersections_with(
&self,
collider: ColliderHandle
) -> Option<impl Iterator<Item = (ColliderHandle, ColliderHandle, bool)>>
&self,
collider: ColliderHandle
) -> Option<impl Iterator<Item = (ColliderHandle, ColliderHandle, bool)>>
All the intersections involving the given collider.
pub fn contact_pair(
&self,
collider1: ColliderHandle,
collider2: ColliderHandle
) -> Option<&ContactPair>
&self,
collider1: ColliderHandle,
collider2: ColliderHandle
) -> Option<&ContactPair>
The contact pair involving two specific colliders.
If this returns None
, there is no contact between the two colliders.
If this returns Some
, then there may be a contact between the two colliders. Check the
result [ContactPair::has_any_active_collider
] method to see if there is an actual contact.
pub fn intersection_pair(
&self,
collider1: ColliderHandle,
collider2: ColliderHandle
) -> Option<bool>
&self,
collider1: ColliderHandle,
collider2: ColliderHandle
) -> Option<bool>
The intersection pair involving two specific colliders.
If this returns None
or Some(false)
, then there is no intersection between the two colliders.
If this returns Some(true)
, then there may be an intersection between the two colliders.
pub fn contact_pairs(&self) -> impl Iterator<Item = &ContactPair>
All the contact pairs maintained by this narrow-phase.
pub fn intersection_pairs(
&self
) -> impl Iterator<Item = (ColliderHandle, ColliderHandle, bool)>
&self
) -> impl Iterator<Item = (ColliderHandle, ColliderHandle, bool)>
All the intersection pairs maintained by this narrow-phase.
pub fn handle_user_changes(
&mut self,
colliders: &mut ColliderSet,
bodies: &mut RigidBodySet,
events: &dyn EventHandler
)
&mut self,
colliders: &mut ColliderSet,
bodies: &mut RigidBodySet,
events: &dyn EventHandler
)
Maintain the narrow-phase internal state by taking collider removal into account.
Trait Implementations
impl Clone for NarrowPhase
pub fn clone(&self) -> NarrowPhase
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
Auto Trait Implementations
impl !RefUnwindSafe for NarrowPhase
impl Send for NarrowPhase
impl Sync for NarrowPhase
impl Unpin for NarrowPhase
impl !UnwindSafe for NarrowPhase
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Any for T where
T: Any,
T: Any,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> CloneAny for T where
T: Any + Clone,
T: Any + Clone,
impl<T> Component for T where
T: 'static + Send + Sync,
T: 'static + Send + Sync,
impl<T> Downcast for T where
T: Any,
T: Any,
pub fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
pub fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
pub fn as_any(&self) -> &(dyn Any + 'static)
pub fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
impl<T> Downcast<T> for T
impl<T> DowncastSync for T where
T: Any + Send + Sync,
T: Any + Send + Sync,
impl<T> From<T> for T
[src]
impl<T> Instrument for T
[src]
pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Pointable for T
pub const ALIGN: usize
type Init = T
The type for initializers.
pub unsafe fn init(init: <T as Pointable>::Init) -> usize
pub unsafe fn deref<'a>(ptr: usize) -> &'a T
pub unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T
pub unsafe fn drop(ptr: usize)
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<SS, SP> SupersetOf<SS> for SP where
SS: SubsetOf<SP>,
SS: SubsetOf<SP>,
pub fn to_subset(&self) -> Option<SS>
pub fn is_in_subset(&self) -> bool
pub fn to_subset_unchecked(&self) -> SS
pub fn from_subset(element: &SS) -> SP
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T> TypeData for T where
T: 'static + Send + Sync + Clone,
T: 'static + Send + Sync + Clone,
pub fn clone_type_data(&self) -> Box<dyn TypeData + 'static, Global>
impl<T> Upcast<T> for T
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,