collider_position
The position of a collider represents its location (translation) in 2D or 3D world-space as well as its orientation (rotation).
Transform
component.
Please read carefully the paragraph after the next example. It explains how the collider position (and the action of setting this position) behaves differently when it is attached to a rigid-body.
It is possible to set this position when the collider is created or after its creation:
- Example 2D
- Example 3D
/* Set the collider position when the collider is created. */
let collider = ColliderBuilder::ball(0.5)
.translation(vector![1.0, 2.0])
.rotation(0.4)
// Set both translation and rotation at once.
.position(Isometry::new(vector![1.0, 2.0], 0.4))
.build();
/* Set the collider position after the collider creation. */
let collider = collider_set.get_mut(collider_handle).unwrap();
collider.set_translation(vector![1.0, 2.0]);
collider.set_rotation(UnitComplex::new(0.4));
// Set both the translation and rotation at once.
collider.set_position(Isometry::new(vector![1.0, 2.0], 0.4));
assert_eq!(*collider.translation(), vector![1.0, 2.0]);
assert_eq!(collider.rotation().angle(), 0.4);
/* Set the collider position when the collider is created. */
let collider = ColliderBuilder::ball(0.5)
.translation(vector![1.0, 2.0, 3.0])
.rotation(vector![0.1, 0.2, 0.4])
// Set both translation and rotation at once.
.position(Isometry::new(
vector![1.0, 2.0, 3.0],
vector![0.1, 0.2, 0.4],
))
.build();
/* Set the collider position after the collider creation. */
let collider = collider_set.get_mut(collider_handle).unwrap();
collider.set_translation(vector![1.0, 2.0, 3.0]);
collider.set_rotation(Rotation::from_scaled_axis(vector![0.1, 0.2, 0.4]));
// Set both the translation and rotation at once.
collider.set_position(Isometry::new(
vector![1.0, 2.0, 3.0],
vector![0.1, 0.2, 0.4],
));
assert_eq!(*collider.translation(), vector![1.0, 2.0, 3.0]);
assert_eq!(collider.rotation().scaled_axis(), vector![0.1, 0.2, 0.4]);
- Example 2D
- Example 3D
/* Set the collider position when the collider is created. */
commands
.spawn(Collider::cuboid(0.5, 0.5))
.insert(TransformBundle::from(Transform::from_xyz(1.0, 2.0, 0.0)));
// Attach the collider to the rigid-body. The collider is attached as its
// children, so the collider’s `Transform` components sets its position
// relative to the parent rigid-body.
commands
.spawn((RigidBody::Dynamic, GlobalTransform::default()))
.with_children(|children| {
children
.spawn(Collider::cuboid(0.5, 0.5))
.insert(TransformBundle::from(Transform::from_xyz(1.0, 2.0, 0.0)));
});
/* Set the collider position when the collider is created. */
commands
.spawn(Collider::cuboid(0.5, 0.5, 0.5))
.insert(TransformBundle::from(Transform::from_xyz(1.0, 2.0, 3.0)));
/* Set the collider position inside of a system. */
fn modify_collider_position(mut positions: Query<&mut Transform, With<Collider>>) {
for mut position in positions.iter_mut() {
position.translation.x = 2.0;
}
}
- Example 2D
- Example 3D
/* Set the collider position when the collider is created. */
let colliderDesc = RAPIER.ColliderDesc.ball(0.5)
.setTranslation(1.0, 2.0)
.setRotation(0.4);
let collider = world.createCollider(colliderDesc);
/* Set the collider position after the collider creation. */
collider.setTranslation({ x: 1.0, y: 2.0 });
collider.setRotation(0.4);
/* Set the collider position when the collider is created. */
let colliderDesc = RAPIER.ColliderDesc.ball(0.5)
.setTranslation(1.0, 2.0, 3.0)
.setRotation({ w: 1.0, x: 0.0, y: 0.0, z: 0.0 });
let collider = world.createCollider(colliderDesc);
/* Set the collider position after the collider creation. */
collider.setTranslation({ x: 1.0, y: 2.0, z: 3.0 });
collider.setRotation({ w: 1.0, x: 0.0, y: 0.0, z: 0.0 });
If a collider is attached to a rigid-body, its position is automatically updated by the physics pipeline when a rigid-body is moved by the physics pipeline. If a change to the rigid-body position is made by the user then the collider position will be updated during the next timestep.
Transform
of a collider attached to a rigid-body will modify the position of the
collider relative to the rigid-body it is attached to:- Example 2D
- Example 3D
let rigid_body = RigidBodyBuilder::dynamic().build();
let rigid_body_handle = rigid_body_set.insert(rigid_body);
let collider = ColliderBuilder::ball(0.5)
.translation(vector![1.0, 2.0])
.build();
// Attach the collider to the rigid-body. The collider's position wrt. the rigid-body
// is automatically set to the collider current position when this method is called.
collider_set.insert_with_parent(collider, rigid_body_handle, &mut rigid_body_set);
/* Set the collider position wrt. its parent after the collider creation. */
let collider = collider_set.get_mut(collider_handle).unwrap();
collider.set_position_wrt_parent(Isometry::translation(1.0, 2.0));
assert_eq!(
collider.position_wrt_parent().unwrap().translation.vector,
vector![1.0, 2.0]
);
let rigid_body = RigidBodyBuilder::dynamic().build();
let rigid_body_handle = rigid_body_set.insert(rigid_body);
let collider = ColliderBuilder::ball(0.5)
.translation(vector![1.0, 2.0, 3.0])
.build();
// Attach the collider to the rigid-body. The collider's position wrt. the rigid-body
// is automatically set to the collider current position when this method is called.
collider_set.insert_with_parent(collider, rigid_body_handle, &mut rigid_body_set);
/* Set the collider position wrt. its parent after the collider creation. */
let collider = collider_set.get_mut(collider_handle).unwrap();
collider.set_position_wrt_parent(Isometry::translation(1.0, 2.0, 3.0));
assert_eq!(
collider.position_wrt_parent().unwrap().translation.vector,
vector![1.0, 2.0, 3.0]
);
- Example 2D
- Example 3D
/* Set the collider position inside of a system. */
fn modify_collider_position(mut positions: Query<&mut Transform, With<Collider>>) {
for mut position in positions.iter_mut() {
position.translation.x = 2.0;
}
}
// Attach the collider to the rigid-body. The collider is attached as its
// children, so the collider’s `Transform` components sets its position
// relative to the parent rigid-body.
commands
.spawn(RigidBody::Dynamic)
.with_children(|children| {
children
.spawn(Collider::cuboid(0.5, 0.5, 0.5))
.insert(TransformBundle::from(Transform::from_xyz(1.0, 2.0, 0.0)));
});
- Example 2D
- Example 3D
let rigidBodyDesc = RAPIER.RigidBodyDesc.dynamic();
let rigidBody = world.createRigidBody(rigidBodyDesc);
let colliderDesc = RAPIER.ColliderDesc.ball(0.5)
.setTranslation(1.0, 2.0);
// Attach the collider to the rigid-body. The collider's position wrt. the rigid-body
// is automatically set to the collider current position when this method is called.
let collider = world.createCollider(colliderDesc, rigidBody);
/* Set the collider position wrt. its parent after the collider creation. */
collider.setTranslationWrtParent({ x: 1.0, y: 2.0 });
let rigidBodyDesc = RAPIER.RigidBodyDesc.dynamic();
let rigidBody = world.createRigidBody(rigidBodyDesc);
let colliderDesc = RAPIER.ColliderDesc.ball(0.5)
.setTranslation(1.0, 2.0, 3.0);
// Attach the collider to the rigid-body. The collider's position wrt. the rigid-body
// is automatically set to the collider current position when this method is called.
let collider = world.createCollider(colliderDesc, rigidBody);
/* Set the collider position wrt. its parent after the collider creation. */
collider.setTranslationWrtParent({ x: 1.0, y: 2.0, z: 3.0 });