pub struct Collider {
pub user_data: u128,
/* private fields */
}
Expand description
A geometric entity that can be attached to a body so it can be affected by contacts and proximity queries.
To build a new collider, use the ColliderBuilder
structure.
Fields§
§user_data: u128
User-defined data associated to this collider.
Implementations§
Source§impl Collider
impl Collider
Sourcepub fn internal_broad_phase_proxy_index(&self) -> u32
pub fn internal_broad_phase_proxy_index(&self) -> u32
An internal index associated to this collider by the broad-phase algorithm.
Sourcepub fn set_internal_broad_phase_proxy_index(&mut self, id: u32)
pub fn set_internal_broad_phase_proxy_index(&mut self, id: u32)
Sets the internal index associated to this collider by the broad-phase algorithm.
This must not be called, unless you are implementing your own custom broad-phase that require storing an index in the collider struct. Modifying that index outside of a custom broad-phase code will most certainly break the physics engine.
Sourcepub fn parent(&self) -> Option<RigidBodyHandle>
pub fn parent(&self) -> Option<RigidBodyHandle>
The rigid body this collider is attached to.
Sourcepub fn copy_from(&mut self, other: &Collider)
pub fn copy_from(&mut self, other: &Collider)
Copy all the characteristics from other
to self
.
If you have a mutable reference to a collider collider: &mut Collider
, attempting to
assign it a whole new collider instance, e.g., *collider = ColliderBuilder::ball(0.5).build()
,
will crash due to some internal indices being overwritten. Instead, use
collider.copy_from(&ColliderBuilder::ball(0.5).build())
.
This method will allow you to set most characteristics of this collider from another collider instance without causing any breakage.
This method cannot be used for reparenting a collider. Therefore, the parent of the
other
(if any), as well as its relative position to that parent will not be copied into
self
.
The pose of other
will only copied into self
if self
doesn’t have a parent (if it has
a parent, its position is directly controlled by the parent rigid-body).
Sourcepub fn active_hooks(&self) -> ActiveHooks
pub fn active_hooks(&self) -> ActiveHooks
The physics hooks enabled for this collider.
Sourcepub fn set_active_hooks(&mut self, active_hooks: ActiveHooks)
pub fn set_active_hooks(&mut self, active_hooks: ActiveHooks)
Sets the physics hooks enabled for this collider.
Sourcepub fn active_events(&self) -> ActiveEvents
pub fn active_events(&self) -> ActiveEvents
The events enabled for this collider.
Sourcepub fn set_active_events(&mut self, active_events: ActiveEvents)
pub fn set_active_events(&mut self, active_events: ActiveEvents)
Sets the events enabled for this collider.
Sourcepub fn active_collision_types(&self) -> ActiveCollisionTypes
pub fn active_collision_types(&self) -> ActiveCollisionTypes
The collision types enabled for this collider.
Sourcepub fn set_active_collision_types(
&mut self,
active_collision_types: ActiveCollisionTypes,
)
pub fn set_active_collision_types( &mut self, active_collision_types: ActiveCollisionTypes, )
Sets the collision types enabled for this collider.
Sourcepub fn contact_skin(&self) -> f32
pub fn contact_skin(&self) -> f32
The contact skin of this collider.
See the documentation of ColliderBuilder::contact_skin
for details.
Sourcepub fn set_contact_skin(&mut self, skin_thickness: f32)
pub fn set_contact_skin(&mut self, skin_thickness: f32)
Sets the contact skin of this collider.
See the documentation of ColliderBuilder::contact_skin
for details.
Sourcepub fn set_friction(&mut self, coefficient: f32)
pub fn set_friction(&mut self, coefficient: f32)
Sets the friction coefficient of this collider.
Sourcepub fn friction_combine_rule(&self) -> CoefficientCombineRule
pub fn friction_combine_rule(&self) -> CoefficientCombineRule
The combine rule used by this collider to combine its friction coefficient with the friction coefficient of the other collider it is in contact with.
Sourcepub fn set_friction_combine_rule(&mut self, rule: CoefficientCombineRule)
pub fn set_friction_combine_rule(&mut self, rule: CoefficientCombineRule)
Sets the combine rule used by this collider to combine its friction coefficient with the friction coefficient of the other collider it is in contact with.
Sourcepub fn restitution(&self) -> f32
pub fn restitution(&self) -> f32
The restitution coefficient of this collider.
Sourcepub fn set_restitution(&mut self, coefficient: f32)
pub fn set_restitution(&mut self, coefficient: f32)
Sets the restitution coefficient of this collider.
Sourcepub fn restitution_combine_rule(&self) -> CoefficientCombineRule
pub fn restitution_combine_rule(&self) -> CoefficientCombineRule
The combine rule used by this collider to combine its restitution coefficient with the restitution coefficient of the other collider it is in contact with.
Sourcepub fn set_restitution_combine_rule(&mut self, rule: CoefficientCombineRule)
pub fn set_restitution_combine_rule(&mut self, rule: CoefficientCombineRule)
Sets the combine rule used by this collider to combine its restitution coefficient with the restitution coefficient of the other collider it is in contact with.
Sourcepub fn set_contact_force_event_threshold(&mut self, threshold: f32)
pub fn set_contact_force_event_threshold(&mut self, threshold: f32)
Sets the total force magnitude beyond which a contact force event can be emitted.
Sourcepub fn set_sensor(&mut self, is_sensor: bool)
pub fn set_sensor(&mut self, is_sensor: bool)
Sets whether or not this is a sensor collider.
Sourcepub fn is_enabled(&self) -> bool
pub fn is_enabled(&self) -> bool
Is this collider enabled?
Sourcepub fn set_enabled(&mut self, enabled: bool)
pub fn set_enabled(&mut self, enabled: bool)
Sets whether or not this collider is enabled.
Sourcepub fn set_translation(&mut self, translation: Vector<f32>)
pub fn set_translation(&mut self, translation: Vector<f32>)
Sets the translational part of this collider’s position.
Sourcepub fn set_rotation(&mut self, rotation: Rotation<f32>)
pub fn set_rotation(&mut self, rotation: Rotation<f32>)
Sets the rotational part of this collider’s position.
Sourcepub fn set_position(&mut self, position: Isometry<f32>)
pub fn set_position(&mut self, position: Isometry<f32>)
Sets the position of this collider.
Sourcepub fn translation(&self) -> &Vector<f32>
pub fn translation(&self) -> &Vector<f32>
The translational part of this collider’s position.
Sourcepub fn position_wrt_parent(&self) -> Option<&Isometry<f32>>
pub fn position_wrt_parent(&self) -> Option<&Isometry<f32>>
The position of this collider with respect to the body it is attached to.
Sourcepub fn set_translation_wrt_parent(&mut self, translation: Vector<f32>)
pub fn set_translation_wrt_parent(&mut self, translation: Vector<f32>)
Sets the translational part of this collider’s translation relative to its parent rigid-body.
Sourcepub fn set_rotation_wrt_parent(&mut self, rotation: AngVector<f32>)
pub fn set_rotation_wrt_parent(&mut self, rotation: AngVector<f32>)
Sets the rotational part of this collider’s rotation relative to its parent rigid-body.
Sourcepub fn set_position_wrt_parent(&mut self, pos_wrt_parent: Isometry<f32>)
pub fn set_position_wrt_parent(&mut self, pos_wrt_parent: Isometry<f32>)
Sets the position of this collider with respect to its parent rigid-body.
Does nothing if the collider is not attached to a rigid-body.
Sourcepub fn collision_groups(&self) -> InteractionGroups
pub fn collision_groups(&self) -> InteractionGroups
The collision groups used by this collider.
Sourcepub fn set_collision_groups(&mut self, groups: InteractionGroups)
pub fn set_collision_groups(&mut self, groups: InteractionGroups)
Sets the collision groups of this collider.
Sourcepub fn solver_groups(&self) -> InteractionGroups
pub fn solver_groups(&self) -> InteractionGroups
The solver groups used by this collider.
Sourcepub fn set_solver_groups(&mut self, groups: InteractionGroups)
pub fn set_solver_groups(&mut self, groups: InteractionGroups)
Sets the solver groups of this collider.
Sourcepub fn material(&self) -> &ColliderMaterial
pub fn material(&self) -> &ColliderMaterial
The material (friction and restitution properties) of this collider.
Sourcepub fn set_density(&mut self, density: f32)
pub fn set_density(&mut self, density: f32)
Sets the uniform density of this collider.
This will override any previous mass-properties set by Self::set_density
,
Self::set_mass
, Self::set_mass_properties
, ColliderBuilder::density
,
ColliderBuilder::mass
, or ColliderBuilder::mass_properties
for this collider.
The mass and angular inertia of this collider will be computed automatically based on its shape.
Sourcepub fn set_mass(&mut self, mass: f32)
pub fn set_mass(&mut self, mass: f32)
Sets the mass of this collider.
This will override any previous mass-properties set by Self::set_density
,
Self::set_mass
, Self::set_mass_properties
, ColliderBuilder::density
,
ColliderBuilder::mass
, or ColliderBuilder::mass_properties
for this collider.
The angular inertia of this collider will be computed automatically based on its shape and this mass value.
Sourcepub fn set_mass_properties(&mut self, mass_properties: MassProperties)
pub fn set_mass_properties(&mut self, mass_properties: MassProperties)
Sets the mass properties of this collider.
This will override any previous mass-properties set by Self::set_density
,
Self::set_mass
, Self::set_mass_properties
, ColliderBuilder::density
,
ColliderBuilder::mass
, or ColliderBuilder::mass_properties
for this collider.
Sourcepub fn shape_mut(&mut self) -> &mut dyn Shape
pub fn shape_mut(&mut self) -> &mut dyn Shape
A mutable reference to the geometric shape of this collider.
If that shape is shared by multiple colliders, it will be
cloned first so that self
contains a unique copy of that
shape that you can modify.
Sourcepub fn set_shape(&mut self, shape: SharedShape)
pub fn set_shape(&mut self, shape: SharedShape)
Sets the shape of this collider.
Retrieve the SharedShape. Also see the shape()
function
Sourcepub fn compute_aabb(&self) -> Aabb
pub fn compute_aabb(&self) -> Aabb
Compute the axis-aligned bounding box of this collider.
This AABB doesn’t take into account the collider’s contact skin.
Collider::contact_skin
.
Sourcepub fn compute_collision_aabb(&self, prediction: f32) -> Aabb
pub fn compute_collision_aabb(&self, prediction: f32) -> Aabb
Compute the axis-aligned bounding box of this collider, taking into account the
Collider::contact_skin
and prediction distance.
Sourcepub fn compute_swept_aabb(&self, next_position: &Isometry<f32>) -> Aabb
pub fn compute_swept_aabb(&self, next_position: &Isometry<f32>) -> Aabb
Compute the axis-aligned bounding box of this collider moving from its current position
to the given next_position
Sourcepub fn mass_properties(&self) -> MassProperties
pub fn mass_properties(&self) -> MassProperties
Compute the local-space mass properties of this collider.
Sourcepub fn contact_force_event_threshold(&self) -> f32
pub fn contact_force_event_threshold(&self) -> f32
The total force magnitude beyond which a contact force event can be emitted.
Trait Implementations§
Source§impl From<ColliderBuilder> for Collider
impl From<ColliderBuilder> for Collider
Source§fn from(val: ColliderBuilder) -> Collider
fn from(val: ColliderBuilder) -> Collider
Auto Trait Implementations§
impl Freeze for Collider
impl !RefUnwindSafe for Collider
impl Send for Collider
impl Sync for Collider
impl Unpin for Collider
impl !UnwindSafe for Collider
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
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
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self
from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self
is actually part of its subset T
(and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset
but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self
to the equivalent element of its superset.