pub struct CollisionWorld<N, T>where
    N: RealField + Copy,{
    pub objects: CollisionObjectSlab<N, T>,
    pub broad_phase: Box<dyn BroadPhase<N, AABB<N>, CollisionObjectSlabHandle>, Global>,
    pub narrow_phase: NarrowPhase<N, CollisionObjectSlabHandle>,
    pub toi_dispatcher: Box<dyn TOIDispatcher<N>, Global>,
    pub interactions: InteractionGraph<N, CollisionObjectSlabHandle>,
    pub pair_filters: Option<Box<dyn BroadPhasePairFilter<N, CollisionObjectSlab<N, T>>, Global>>,
}
Expand description

A world that handles collision objects.

Fields§

§objects: CollisionObjectSlab<N, T>

The set of objects on this collision world.

§broad_phase: Box<dyn BroadPhase<N, AABB<N>, CollisionObjectSlabHandle>, Global>

The broad phase used by this collision world.

§narrow_phase: NarrowPhase<N, CollisionObjectSlabHandle>

The narrow-phase used by this collision world.

§toi_dispatcher: Box<dyn TOIDispatcher<N>, Global>

The Time of Impact dispatcher used.

§interactions: InteractionGraph<N, CollisionObjectSlabHandle>

The graph of interactions detected so far.

§pair_filters: Option<Box<dyn BroadPhasePairFilter<N, CollisionObjectSlab<N, T>>, Global>>

A user-defined broad-phase pair filter.

Implementations§

source§

impl<N, T> CollisionWorld<N, T>where N: RealField + Copy,

source

pub fn new(margin: N) -> CollisionWorld<N, T>

Creates a new collision world.

source

pub fn add( &mut self, position: Isometry<N, Unit<Complex<N>>, 2>, shape: ShapeHandle<N>, collision_groups: CollisionGroups, query_type: GeometricQueryType<N>, data: T ) -> (CollisionObjectSlabHandle, &mut CollisionObject<N, T>)

Adds a collision object to the world.

source

pub fn update(&mut self)

Updates the collision world.

This executes the whole collision detection pipeline:

  1. Clears the event pools.
  2. Executes the broad phase first.
  3. Executes the narrow phase.
source

pub fn clear_events(&mut self)

Empty the contact and proximity event pools.

source

pub fn remove(&mut self, handles: &[CollisionObjectSlabHandle])

Removed the specified set of collision objects from the world.

Panics of any handle is invalid, or if the list contains duplicates.

source

pub fn set_position( &mut self, handle: CollisionObjectSlabHandle, pos: Isometry<N, Unit<Complex<N>>, 2> )

👎Deprecated: Call directly the method .set_position on the collision object.

Sets the position of the collision object attached to the specified object.

source

pub fn set_query_type( &mut self, handle: CollisionObjectSlabHandle, query_type: GeometricQueryType<N> )

👎Deprecated: Call directly the method .set_query_type on the collision object.

Sets the GeometricQueryType of the collision object.

source

pub fn set_shape( &mut self, handle: CollisionObjectSlabHandle, shape: ShapeHandle<N> )

👎Deprecated: Call directly the method .set_shape on the collision object.

Sets the shape of the given collision object.

source

pub fn set_deformations( &mut self, handle: CollisionObjectSlabHandle, coords: &[N] )

👎Deprecated: Call directly the method .set_deformations on the collision object.

Apply the given deformations to the specified object.

source

pub fn set_broad_phase_pair_filter<F>(&mut self, filter: Option<F>)where F: BroadPhasePairFilter<N, CollisionObjectSlab<N, T>> + 'static,

Sets the user-defined filter that tells if a potential collision pair should be ignored or not.

The proximity filter returns false for a given pair of collision objects if they should be ignored by the narrow phase. Keep in mind that modifying the proximity filter will have a non-trivial overhead during the next update as it will force re-detection of all collision pairs.

source

pub fn perform_broad_phase(&mut self)

Executes the broad phase of the collision detection pipeline.

source

pub fn perform_narrow_phase(&mut self)

Executes the narrow phase of the collision detection pipeline.

source

pub fn broad_phase_aabb( &self, handle: CollisionObjectSlabHandle ) -> Option<&AABB<N>>

The broad-phase aabb for the given collision object.

source

pub fn collision_objects(&self) -> CollisionObjects<'_, N, T>

Iterates through all collision objects.

source

pub fn collision_object( &self, handle: CollisionObjectSlabHandle ) -> Option<&CollisionObject<N, T>>

Returns a reference to the collision object identified by its handle.

source

pub fn get_mut( &mut self, handle: CollisionObjectSlabHandle ) -> Option<&mut CollisionObject<N, T>>

Returns a mutable reference to the collision object identified by its handle.

source

pub fn collision_object_pair_mut( &mut self, handle1: CollisionObjectSlabHandle, handle2: CollisionObjectSlabHandle ) -> (Option<&mut CollisionObject<N, T>>, Option<&mut CollisionObject<N, T>>)

Returns a mutable reference to a pair collision object identified by their handles.

Panics if both handles are equal.

source

pub fn set_collision_groups( &mut self, handle: CollisionObjectSlabHandle, groups: CollisionGroups )

👎Deprecated: Call directly the method .set_collision_groups on the collision object.

Sets the collision groups of the given collision object.

source

pub fn sweep_test<'a>( &'a self, shape: &'a (dyn Shape<N> + 'static), isometry: &'a Isometry<N, Unit<Complex<N>>, 2>, direction: &'a Unit<Matrix<N, Const<nalgebra::::base::dimension::U2::{constant#0}>, Const<1>, ArrayStorage<N, 2, 1>>>, maximum_distance: N, groups: &'a CollisionGroups ) -> impl Iterator<Item = (CollisionObjectSlabHandle, TOI<N>)> + 'a

Returns all objects in the collision world that intersect with the shape transformed by isometry along direction until maximum_distance is reached. The objects are not returned in any particular order. You may use the toi returned for each object to determine the closest object.

source

pub fn interferences_with_ray<'a, 'b>( &'a self, ray: &'b Ray<N>, max_toi: N, groups: &'b CollisionGroups ) -> InterferencesWithRay<'a, 'b, N, CollisionObjectSlab<N, T>>

Computes the interferences between every rigid bodies on this world and a ray.

source

pub fn first_interference_with_ray<'a, 'b>( &'a self, ray: &'b Ray<N>, max_toi: N, groups: &'b CollisionGroups ) -> Option<FirstInterferenceWithRay<'a, N, CollisionObjectSlab<N, T>>>

Computes the first interference with ray and

source

pub fn interferences_with_point<'a, 'b>( &'a self, point: &'b OPoint<N, Const<2>>, groups: &'b CollisionGroups ) -> InterferencesWithPoint<'a, 'b, N, CollisionObjectSlab<N, T>>

Computes the interferences between every rigid bodies of a given broad phase, and a point.

source

pub fn interferences_with_aabb<'a, 'b>( &'a self, aabb: &'b AABB<N>, groups: &'b CollisionGroups ) -> InterferencesWithAABB<'a, 'b, N, CollisionObjectSlab<N, T>>

Computes the interferences between every rigid bodies of a given broad phase, and a aabb.

source

pub fn set_narrow_phase( &mut self, narrow_phase: NarrowPhase<N, CollisionObjectSlabHandle> )

Customize the selection of narrowphase collision detection algorithms

source

pub fn interaction_pairs( &self, effective_only: bool ) -> impl Iterator<Item = (CollisionObjectSlabHandle, CollisionObjectSlabHandle, &Interaction<N>)>

All the potential interactions pairs.

Refer to the official user guide for details.

source

pub fn contact_pairs( &self, effective_only: bool ) -> impl Iterator<Item = (CollisionObjectSlabHandle, CollisionObjectSlabHandle, &Box<dyn ContactManifoldGenerator<N>, Global>, &ContactManifold<N>)>

All the potential contact pairs.

Refer to the official user guide for details.

source

pub fn proximity_pairs( &self, effective_only: bool ) -> impl Iterator<Item = (CollisionObjectSlabHandle, CollisionObjectSlabHandle, &(dyn ProximityDetector<N> + 'static), Proximity)>

All the potential proximity pairs.

Refer to the official user guide for details.

source

pub fn interaction_pair( &self, handle1: CollisionObjectSlabHandle, handle2: CollisionObjectSlabHandle, effective_only: bool ) -> Option<(CollisionObjectSlabHandle, CollisionObjectSlabHandle, &Interaction<N>)>

The potential interaction pair between the two specified collision objects.

Refer to the official user guide for details.

source

pub fn contact_pair( &self, handle1: CollisionObjectSlabHandle, handle2: CollisionObjectSlabHandle, effective_only: bool ) -> Option<(CollisionObjectSlabHandle, CollisionObjectSlabHandle, &Box<dyn ContactManifoldGenerator<N>, Global>, &ContactManifold<N>)>

The potential contact pair between the two specified collision objects.

Refer to the official user guide for details.

source

pub fn proximity_pair( &self, handle1: CollisionObjectSlabHandle, handle2: CollisionObjectSlabHandle, effective_only: bool ) -> Option<(CollisionObjectSlabHandle, CollisionObjectSlabHandle, &(dyn ProximityDetector<N> + 'static), Proximity)>

The potential proximity pair between the two specified collision objects.

Refer to the official user guide for details.

source

pub fn interactions_with( &self, handle: CollisionObjectSlabHandle, effective_only: bool ) -> Option<impl Iterator<Item = (CollisionObjectSlabHandle, CollisionObjectSlabHandle, &Interaction<N>)>>

All the interaction pairs involving the specified collision object.

Refer to the official user guide for details.

source

pub fn interactions_with_mut( &mut self, handle: CollisionObjectSlabHandle ) -> Option<(&mut NarrowPhase<N, CollisionObjectSlabHandle>, impl Iterator<Item = (CollisionObjectSlabHandle, CollisionObjectSlabHandle, EdgeIndex<usize>, &mut Interaction<N>)>)>

All the mutable interactions pairs involving the specified collision object.

This also returns a mutable reference to the narrow-phase which is necessary for updating the interaction if needed. For interactions between a collision object and itself, only one mutable reference to the collision object is returned.

source

pub fn proximities_with( &self, handle: CollisionObjectSlabHandle, effective_only: bool ) -> Option<impl Iterator<Item = (CollisionObjectSlabHandle, CollisionObjectSlabHandle, &(dyn ProximityDetector<N> + 'static), Proximity)>>

All the proximity pairs involving the specified collision object.

Refer to the official user guide for details.

source

pub fn contacts_with( &self, handle: CollisionObjectSlabHandle, effective_only: bool ) -> Option<impl Iterator<Item = (CollisionObjectSlabHandle, CollisionObjectSlabHandle, &Box<dyn ContactManifoldGenerator<N>, Global>, &ContactManifold<N>)>>

All the contact pairs involving the specified collision object.

Refer to the official user guide for details.

source

pub fn collision_objects_interacting_with<'a>( &'a self, handle: CollisionObjectSlabHandle ) -> Option<impl Iterator<Item = CollisionObjectSlabHandle> + 'a>

All the collision object handles of collision objects interacting with the specified collision object.

Refer to the official user guide for details.

source

pub fn collision_objects_in_contact_with<'a>( &'a self, handle: CollisionObjectSlabHandle ) -> Option<impl Iterator<Item = CollisionObjectSlabHandle> + 'a>

All the collision object handles of collision objects in potential contact with the specified collision object.

Refer to the official user guide for details.

source

pub fn collision_objects_in_proximity_of<'a>( &'a self, handle: CollisionObjectSlabHandle ) -> Option<impl Iterator<Item = CollisionObjectSlabHandle> + 'a>

All the collision object handles of collision objects in potential proximity of with the specified collision object.

Refer to the official user guide for details.

source

pub fn contact_events( &self ) -> &EventPool<ContactEvent<CollisionObjectSlabHandle>>

The contact events pool.

source

pub fn proximity_events( &self ) -> &EventPool<ProximityEvent<CollisionObjectSlabHandle>>

The proximity events pool.

Auto Trait Implementations§

§

impl<N, T> !RefUnwindSafe for CollisionWorld<N, T>

§

impl<N, T> Send for CollisionWorld<N, T>where T: Send,

§

impl<N, T> Sync for CollisionWorld<N, T>where T: Sync,

§

impl<N, T> Unpin for CollisionWorld<N, T>where N: Unpin, T: Unpin,

§

impl<N, T> !UnwindSafe for CollisionWorld<N, T>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> Downcast for Twhere T: Any,

§

fn into_any(self: Box<T, Global>) -> Box<dyn Any, Global>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

fn into_any_rc(self: Rc<T, Global>) -> Rc<dyn Any, Global>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for Twhere T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T, Global>) -> Arc<dyn Any + Send + Sync, Global>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
§

impl<T> Finalize for T

§

unsafe fn finalize_raw(data: *mut ())

Safety Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
§

impl<SS, SP> SupersetOf<SS> for SPwhere SS: SubsetOf<SP>,

§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<T> Component for Twhere T: Send + Sync + 'static,