Joint - stingray.Joint object reference - Stingray Lua API Reference

stingray.Joint object reference

Description

Interface to a physics joint.

A joint is a physical coupling between two actors or between an actor and the world.

For more background information about the concepts involved in physics joints, see also the PhysX documentation.

Enumerations

Enumerates the degrees of freedom for a D6 joint.
Enumerates drive modes for D6 joints.
Enumerates the different modes available for each degree of freedom in a D6 joint.
Flags that enable limits for DISTANCE joints.
Flags that enable limits for REVOLUTE joints.
Joint types.

Functions

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

drive :

stingray.Joint.D6Drive

The degree of freedom for which the drive parameters should be retrieved. Is one of the D6Drive enum values: X, Y, Z, TWIST, SWING or SLERP.

Returns

number

The drive stiffness.

number

The drive damping.

number

The drive force limit.

boolean

Specify if the drive is an acceleration or a force/torque.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

stingray.Quaternion

The orientation the drive is currently targeting for the second actor's frame, defined relative to the first actor's frame.

stingray.Vector3

The position the drive is currently targeting for the center of the second actor's frame, defined relative to the first actor's frame.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

stingray.Vector3

The drive target linear velocity.

stingray.Vector3

The drive target angular velocity.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

table?

Returns the linear limit for this D6 joint. D6 joints linear limits are configured with lower and upper limit values in meters. Like all other joint types, this table may also have the following shared parameters: restitution, bounceThreshold, stiffness, damping and contactDistance.

The ? notation indicates that this type is optional: there may be zero or one instances of it.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

d6axis :

stingray.Joint.D6Axis

The D6Axis (degree of freedom) for which the motion flag should be retrieved.

Returns

D6Motion

The D6Motion mode currently set for the specified DoF.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

table?

Returns the swing limit parameter for this D6 joint. D6 joints swing limits are configured with yAngle and zAngle limit values in radians. Like all other joint types, this table may also have the following shared parameters: restitution, bounceThreshold, stiffness, damping and contactDistance.

The ? notation indicates that this type is optional: there may be zero or one instances of it.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The current D6 joint Y swing value, in radians.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The current D6 joint Z swing value, in radians.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The current D6 joint twist value, in radians.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

table?

Returns the twist limit parameters for this D6 joint. D6 joints twist limits are configured with lower and upper limit values in radians. Like all other joint types, this table may also have the following shared parameters: restitution, bounceThreshold, stiffness, damping and contactDistance.

The ? notation indicates that this type is optional: there may be zero or one instances of it.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The current joint distance, in meters.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The combination of DistanceFlag enum values that are currently raised.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

flag :

stingray.Joint.DistanceFlag

One of the DistanceFlag enum values: MAX_DISTANCE_ENABLED, MIN_DISTANCE_ENABLED or SPRING_ENABLED.

Returns

boolean

The current status of the specified flag for this joint.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

table?

Returns the limit parameters for the joint.

The ? notation indicates that this type is optional: there may be zero or one instances of it.

Can be used for all joint types except D6 -- for D6 joints, use the d6_xxx_limit_config(...) functions.

The parameters in the returned table depend on the Joint type. See setup_limit() for details.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

boolean

The current limit activation status for this joint.

Suitable only for SPHERICAL, REVOLUTE & PRISMATIC joints. For D6 joints use d6_motion(), and for DISTANCE joints use [distance_joint_flag()].

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The current PRISMATIC Joint distance along the X axis, in meters.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The current PRISMATIC Joint velocity along the X axis, in meters per second.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The current REVOLUTE Joint angle value, in radians.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The drive force limit for this revolute joint.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The current drive gear ratio for this revolute joint.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The target velocity currently set for the drive on this revolute joint.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The combination of RevoluteFlag enum values which are currently raised.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

flag :

stingray.Joint.RevoluteFlag

One of the RevoluteFlag enum values: LIMIT_ENABLED, DRIVE_ENABLED or DRIVE_FREESPIN.

Returns

boolean

The current status of the specified flag for this joint.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.
Returns

number

The current REVOLUTE Joint angular velocity value, in radians per second.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

parameters :

table

A (key, value) lua table defining the limit parameters.

Returns
This function does not return any values.

D6 joints linear limits are configured with lower and upper limit values in meters. Like all other joint types, you can also set up the following shared parameters: restitution, bounceThreshold, stiffness, damping and contactDistance.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

parameters :

table

A (key, value) lua table defining the limit parameters.

Returns
This function does not return any values.

D6 joints swing limits are configured with yAngle and zAngle limit values in radians. Like all other joint types, you can also set up the following shared parameters: restitution, bounceThreshold, stiffness, damping and contactDistance.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

parameters :

table

A (key, value) lua table defining the limit parameters.

Returns
This function does not return any values.

D6 joints twist limits are configured with lower and upper limit values in radians. Like all other joint types, you can also set up the following shared parameters: restitution, bounceThreshold, stiffness, damping and contactDistance.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

parameters :

table

A (key, value) lua table defining the limit parameters.

Returns
This function does not return any values.

This function is suitable for all joint types except D6 -- set up D6 joints using the set_d6_xxx_limit(...) functions.

The parameter set depends on the Joint type you are configuring.

  • Linear limits for PRISMATIC joints are configured with lower and upper limit values in meters.
  • Angular limits for REVOLUTE joints are configured with lower and upper limit values in radians.
  • Cone limits for SPHERICAL joints are configured with yAngle and zAngle limit values in radians.
  • Distance limits for DISTANCE joints are configured with minDistance and maxDistance limit values in meters.

All joint types also support the following shared parameters: restitution, bounceThreshold, stiffness, damping and contactDistance.

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

force :

number

Force required to break the joint.

torque :

number

Torque required to break the joint.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

drive :

stingray.Joint.D6Drive

The degree of freedom on which the drive should be configured. Is one of the D6Drive enum values: X, Y, Z, TWIST, SWING or SLERP.

stiffness :

number

The drive stiffness.

damping :

number

The drive damping.

force_limit :

number

The drive force limit.

is_acceleration :

boolean?

Optional. Specify if the drive is an acceleration or a force/torque. Default is false, i.e. using force/torque.

The ? notation indicates that this type is optional: there may be zero or one instances of it.
Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

q :

stingray.Quaternion

The orientation to be targeted by the drives for the second actor's frame, defined relative to the first actor's frame.

p :

stingray.Vector3

The position to be targeted by the drives for the center of the second actor's frame, defined relative to the first actor's frame.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

linear :

stingray.Vector3

The linear velocity target for drives.

angular :

stingray.Vector3

The angular velocity target for drives.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

d6axis :

stingray.Joint.D6Axis

The D6Axis (degree of freedom) on which the motion flag should be set.

motion :

stingray.Joint.D6Motion

The D6Motion mode to apply on the specified DoF.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

flags :

number

Any combination of DistanceFlag enum values: MAX_DISTANCE_ENABLED, IN_DISTANCE_ENABLED and SPRING_ENABLED.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

flag :

stingray.Joint.DistanceFlag

One of the DistanceFlag enum values: MAX_DISTANCE_ENABLED, MIN_DISTANCE_ENABLED or SPRING_ENABLED.

do_enable :

boolean

true to raise the flag, false to turn it down.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

do_enable :

boolean

Use true to enable the limit for this Joint, or false to disable it.

Returns
This function does not return any values.

Suitable only for SPHERICAL, REVOLUTE & PRISMATIC joints. For D6 joints use set_d6_motion(), and for DISTANCE joints use [set_distance_joint_flag()].

Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

limit :

number

The drive force limit for this revolute joint.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

ratio :

number

The drive gear ratio for this revolute joint.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

velocity :

number

The drive velocity target for this revolute joint.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

flags :

number

Any combination of RevoluteFlag enum values: LIMIT_ENABLED, DRIVE_ENABLED and DRIVE_FREESPIN.

Returns
This function does not return any values.
Parameters

self :

stingray.Joint

Specifies the object instance that this function will act on.

You must always provide this self parameter when you call this function. You must use the dot . calling syntax, not the object-oriented colon : calling syntax.For more information, see Object lifetimes and userdata binding, or this page in the Lua documentation.

flag :

stingray.Joint.RevoluteFlag

The flag to be raised or turn off. Must be one of the RevoluteFlag enum values: LIMIT_ENABLED, DRIVE_ENABLED or DRIVE_FREESPIN.

do_enable :

boolean

true to raise the flag, false to turn it down.

Returns
This function does not return any values.