#[repr(transparent)]pub struct SpringJoint {
pub data: GenericJoint,
}Expand description
A spring joint that pulls/pushes two bodies toward a target distance (like a spring or shock absorber).
Springs apply force based on:
- Stiffness: How strong the spring force is (higher = stiffer spring)
- Damping: Resistance to motion (higher = less bouncy, settles faster)
- Rest length: The distance the spring “wants” to be
Use for:
- Suspension systems (vehicles, furniture)
- Bouncy connections
- Soft constraints between objects
- Procedural animation (following targets softly)
Technical note: Springs use implicit integration which adds some numerical damping. This means even zero-damping springs will eventually settle (more iterations = less damping).
Fields§
§data: GenericJointThe underlying joint data.
Implementations§
Source§impl SpringJoint
impl SpringJoint
Sourcepub fn new(rest_length: f32, stiffness: f32, damping: f32) -> Self
pub fn new(rest_length: f32, stiffness: f32, damping: f32) -> Self
Creates a new spring joint limiting the max distance between two bodies.
The max_dist must be strictly greater than 0.0.
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 set_spring_model(&mut self, model: MotorModel) -> &mut Self
pub fn set_spring_model(&mut self, model: MotorModel) -> &mut Self
Sets whether spring constants are mass-dependent or mass-independent.
MotorModel::ForceBased(default): Stiffness/damping are absolute values. Heavier objects will respond differently to the same spring constants.MotorModel::AccelerationBased: Spring constants auto-scale with mass. Objects of different masses behave more similarly.
Most users can ignore this and use the default.
Trait Implementations§
Source§impl Clone for SpringJoint
impl Clone for SpringJoint
Source§fn clone(&self) -> SpringJoint
fn clone(&self) -> SpringJoint
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for SpringJoint
impl Debug for SpringJoint
Source§impl<'de> Deserialize<'de> for SpringJoint
impl<'de> Deserialize<'de> for SpringJoint
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<SpringJoint> for GenericJoint
impl From<SpringJoint> for GenericJoint
Source§fn from(val: SpringJoint) -> GenericJoint
fn from(val: SpringJoint) -> GenericJoint
Source§impl PartialEq for SpringJoint
impl PartialEq for SpringJoint
Source§impl Serialize for SpringJoint
impl Serialize for SpringJoint
impl Copy for SpringJoint
impl StructuralPartialEq for SpringJoint
Auto Trait Implementations§
impl Freeze for SpringJoint
impl RefUnwindSafe for SpringJoint
impl Send for SpringJoint
impl Sync for SpringJoint
impl Unpin for SpringJoint
impl UnwindSafe for SpringJoint
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.