#[repr(transparent)]pub struct RevoluteJoint {
pub data: GenericJoint,
}Expand description
A hinge joint that allows rotation around one axis (like a door hinge or wheel axle).
Revolute joints lock all movement except rotation around a single axis. Use for:
- Door hinges
- Wheels and gears
- Joints in robotic arms
- Pendulums
- Any rotating connection
You can optionally add:
- Limits: Restrict rotation to a range (e.g., door that only opens 90°)
- Motor: Powered rotation with target velocity or position
In 2D there’s only one rotation axis (Z). In 3D you specify which axis (X, Y, or Z).
Fields§
§data: GenericJointThe underlying joint data.
Implementations§
Source§impl RevoluteJoint
impl RevoluteJoint
Sourcepub fn new(axis: UnitVector<f32>) -> Self
pub fn new(axis: UnitVector<f32>) -> Self
Creates a new revolute joint allowing only relative rotations along the specified axis.
This axis is expressed in the local-space of both rigid-bodies.
Sourcepub fn data(&self) -> &GenericJoint
pub fn data(&self) -> &GenericJoint
The underlying generic joint.
Sourcepub fn contacts_enabled(&self) -> bool
pub fn contacts_enabled(&self) -> bool
Are contacts between the attached rigid-bodies enabled?
Sourcepub fn set_contacts_enabled(&mut self, enabled: bool) -> &mut Self
pub fn set_contacts_enabled(&mut self, enabled: bool) -> &mut Self
Sets whether contacts between the attached rigid-bodies are enabled.
Sourcepub fn local_anchor1(&self) -> Point<f32>
pub fn local_anchor1(&self) -> Point<f32>
The joint’s anchor, expressed in the local-space of the first rigid-body.
Sourcepub fn set_local_anchor1(&mut self, anchor1: Point<f32>) -> &mut Self
pub fn set_local_anchor1(&mut self, anchor1: Point<f32>) -> &mut Self
Sets the joint’s anchor, expressed in the local-space of the first rigid-body.
Sourcepub fn local_anchor2(&self) -> Point<f32>
pub fn local_anchor2(&self) -> Point<f32>
The joint’s anchor, expressed in the local-space of the second rigid-body.
Sourcepub fn set_local_anchor2(&mut self, anchor2: Point<f32>) -> &mut Self
pub fn set_local_anchor2(&mut self, anchor2: Point<f32>) -> &mut Self
Sets the joint’s anchor, expressed in the local-space of the second rigid-body.
Sourcepub fn angle(&self, rb_rot1: &Rotation<f32>, rb_rot2: &Rotation<f32>) -> f32
pub fn angle(&self, rb_rot1: &Rotation<f32>, rb_rot2: &Rotation<f32>) -> f32
The angle along the free degree of freedom of this revolute joint in [-π, π].
§Parameters
rb_rot1: the rotation of the first rigid-body attached to this revolute joint.rb_rot2: the rotation of the second rigid-body attached to this revolute joint.
Sourcepub fn motor(&self) -> Option<&JointMotor>
pub fn motor(&self) -> Option<&JointMotor>
The motor affecting the joint’s rotational degree of freedom.
Sourcepub fn set_motor_model(&mut self, model: MotorModel) -> &mut Self
pub fn set_motor_model(&mut self, model: MotorModel) -> &mut Self
Set the spring-like model used by the motor to reach the desired target velocity and position.
Sourcepub fn set_motor_velocity(&mut self, target_vel: f32, factor: f32) -> &mut Self
pub fn set_motor_velocity(&mut self, target_vel: f32, factor: f32) -> &mut Self
Sets the motor’s target rotation speed.
Makes the joint spin at a desired velocity (like a powered motor or wheel).
§Parameters
target_vel- Desired angular velocity in radians/secondfactor- Motor strength (higher = stronger, approaches target faster)
Sourcepub fn set_motor_position(
&mut self,
target_pos: f32,
stiffness: f32,
damping: f32,
) -> &mut Self
pub fn set_motor_position( &mut self, target_pos: f32, stiffness: f32, damping: f32, ) -> &mut Self
Sets the motor’s target angle (position control).
Makes the joint rotate toward a specific angle using spring-like behavior.
§Parameters
target_pos- Desired angle in radiansstiffness- How strongly to pull toward target (spring constant)damping- Resistance to motion (higher = less oscillation)
Sourcepub fn set_motor(
&mut self,
target_pos: f32,
target_vel: f32,
stiffness: f32,
damping: f32,
) -> &mut Self
pub fn set_motor( &mut self, target_pos: f32, target_vel: f32, stiffness: f32, damping: f32, ) -> &mut Self
Configures both target angle and target velocity for the motor.
Combines position and velocity control for precise motor behavior.
Sourcepub fn set_motor_max_force(&mut self, max_force: f32) -> &mut Self
pub fn set_motor_max_force(&mut self, max_force: f32) -> &mut Self
Sets the maximum torque the motor can apply.
Limits how strong the motor is. Without this, motors can apply infinite force.
Sourcepub fn limits(&self) -> Option<&JointLimits<f32>>
pub fn limits(&self) -> Option<&JointLimits<f32>>
The rotation limits of this joint, if any.
Returns None if no limits are set (unlimited rotation).
Sourcepub fn set_limits(&mut self, limits: [f32; 2]) -> &mut Self
pub fn set_limits(&mut self, limits: [f32; 2]) -> &mut Self
Sourcepub fn softness(&self) -> SpringCoefficients<f32>
pub fn softness(&self) -> SpringCoefficients<f32>
Gets the softness of this joint’s locked degrees of freedom.
Sourcepub fn set_softness(&mut self, softness: SpringCoefficients<f32>) -> &mut Self
pub fn set_softness(&mut self, softness: SpringCoefficients<f32>) -> &mut Self
Sets the softness of this joint’s locked degrees of freedom.
Trait Implementations§
Source§impl Clone for RevoluteJoint
impl Clone for RevoluteJoint
Source§fn clone(&self) -> RevoluteJoint
fn clone(&self) -> RevoluteJoint
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for RevoluteJoint
impl Debug for RevoluteJoint
Source§impl<'de> Deserialize<'de> for RevoluteJoint
impl<'de> Deserialize<'de> for RevoluteJoint
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl From<RevoluteJoint> for GenericJoint
impl From<RevoluteJoint> for GenericJoint
Source§fn from(val: RevoluteJoint) -> GenericJoint
fn from(val: RevoluteJoint) -> GenericJoint
Source§impl PartialEq for RevoluteJoint
impl PartialEq for RevoluteJoint
Source§impl Serialize for RevoluteJoint
impl Serialize for RevoluteJoint
impl Copy for RevoluteJoint
impl StructuralPartialEq for RevoluteJoint
Auto Trait Implementations§
impl Freeze for RevoluteJoint
impl RefUnwindSafe for RevoluteJoint
impl Send for RevoluteJoint
impl Sync for RevoluteJoint
impl Unpin for RevoluteJoint
impl UnwindSafe for RevoluteJoint
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>, which can then be
downcast into Box<dyn 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>, which 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> DowncastSend for T
impl<T> DowncastSend for T
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.