Rigidbody

Rigid bodies are the basic objects that make up the physics world and allow game objects to move in a physically controlled manner. For example, a rigid body can make a game object do free fall under the influence of gravity, or it can make a game object simulate real-world physics phenomena under the action of forces and torques.

Adding Rigid Body

Adding via Editor

Click Add Component -> Physics -> RigidBody under Inspector panel to add a rigid body component to the node.

add-rigidbody-in-inspector

Via Code

  1. import { RigidBody } from 'cc'
  2. const rigidbody = this.node.addComponent(RigidBody);
  3. const rigidBody = this.node.getComponent(RigidBody);

For more information, please refer to the RigidBody API.

When to Add Rigid Bodies

  1. Configure collision grouping and make it effective.
  2. The object needs to have kinematic or kinetic behavior.

Note: The object needs to have full physical properties provided the object has both rigid body and collider, and its center-of-mass position and collider shape are adjusted.

Rigidbody Properties

rigidbody

PropertiesDescription
GroupGroup of the Rigidbody
TypeType of the Rigidbody, could be the followins types:
DYNAMIC
STATIC
KINEMATIC
Please refer to the following section for details

The following properties only take effect when Type is set to DYNAMIC.

PropertiesDescription
MassThe mass of the rigid body, the value must be greater than 0
AllowSleepWhether to allow auto-sleep
LinearDampingLinear damping, used to attenuate linear velocity, the larger the value, the faster the attenuation
AngularDampingAngular damping, used to attenuate the angular velocity, the larger the value, the faster the attenuation
UseGravityWhether to use gravity
LinerFactorLinearity factor to scale the physics values (velocity and force) in each axis direction
AngularFactorAngular factor for scaling physical values in each axis direction (velocity and force)

Please refer to RigidBody API for rigid body component interface.

RigidBody Types

The current rigid body types include DYNAMIC, KINEMATIC and STATIC.

rigidbody-type

  • STATIC: static rigid body. Can be a game object with a manually set rigid body type, or a game object with a collider and no rigid body. If a node has only colliders and no rigid bodies added by default, then the node can be considered to be using STATIC by default. Static rigid bodies are used in most cases for game objects that always stay in one place and do not move easily, e.g. buildings. If the object needs to move continuously, it should be set to KINEMATIC type. Static rigid objects do not produce physical behavior when they collide with other objects and, therefore, do not move.
  • DYNAMIC: kinetic rigid body. Has colliding bodies and non-moving rigid bodies. Rigid body collisions are fully simulated by the physics engine and can be performed by FORCE on moving objects (need to guarantee mass greater than 0). For example: a snooker game where the mother ball rolls after hitting the ball and collides with other balls.
  • KINEMATIC: kinematic rigid body. Has a collider and a kinematic rigid body that can be directly transformed by moving the transformation properties of the rigid object, but does not respond to forces and collisions like a kinematic rigid body, and is usually used to represent objects with platform motion like elevators. It is similar to static rigid bodies, with the difference that moving kinematic rigid bodies exert frictional forces on other objects and wake up other rigid bodies on contact.

Example: A simple physics simulation to illustrate the performance that various types of rigid bodies have. The square below uses static rigid bodies in white, kinematic rigid bodies in blue, and kinetic rigid bodies in yellow. Both white and blue are manipulated transformation information, and it is obvious to see several manifestations.

  1. There is a penetration between white and blue.
  2. The white static object can also be in motion.
  3. Two yellow squares behave differently, the white above the stationary, blue above the will follow the movement.

physics-type

The reasons for the above phenomena are.

  1. Neither static rigid body nor kinematic rigid body will be subject to forces, so the penetration is produced, which is a normal phenomenon.
  2. Static objects can indeed move, static means that in spacetime, every moment is static and will not consider the state of other moments.
  3. Unlike static objects, kinematic objects will estimate the state of motion (such as speed) according to the nearby moments, and because of the role of friction, therefore driving the yellow square.

Rigid Body Center of Mass

By default, the center of mass of a rigid body coincides with the origin of the model.

The following figure demonstrates the change in the position of the center of mass when the model origin does not coincide.

Centroid

Here is an example to illustrate how to adjust the center of mass for a collision.

  • Create a new empty node Node and add the components shown in the following figure.

    add comp

  • Add a capsule under the child node of Node as shown below.

    add capsule

  • Adjust the Center of cc.CapsuleCollider to the following, so that the center of mass of the capsule is at the bottom of the capsule.

    result

The following figure shows how the motion behaves when the center of mass is inconsistent, with the center of mass of the capsule on the right at the bottom of the capsule and the center of mass of the capsule on the left at the center of the object.

result

Control Rigidbody

Making Rigidbody Move

For different types, there are different ways to make rigid bodies move.

  • For static rigid bodies(STATIC), the object should be kept as stationary as possible, but the position of the object can still be changed by transformations (position, rotation, etc.).
  • For kinematic rigid bodies(KINEMATIC), they should be made to move by changing transformations (position, rotation, etc.).

For dynamic rigid bodies(DYNAMIC), their velocity needs to be changed in several ways.

By Gravity

The rigid body component provides the UseGravity property, which needs to be set to true when using gravity.

By Applying Force

The rigid body component provides the applyForce interface, which allows you to apply a force to a point of the rigid body to change its original state according to Newton’s second law.

  1. import { math } from 'cc'
  2. rigidBody.applyForce(new math.Vec3(200, 0, 0));

By Torque

Forces and impulses can also affect only the axis of rotation, causing the rigid body to rotate, such forces are called torques.

The rigid body component provides the applyTorque interface through which torques can be applied to the rigid body without specifying a point of action, since they only affect the axis of rotation.

  1. rigidBody.applyTorque(new math.Vec3(200, 0, 0));

By Impulse

The rigid body component provides the applyImpulse interface to apply an impulse to a point on the rigid body, which will immediately change the linear velocity of the rigid body according to the conservation of momentum. If the impulse is applied to a point that is not the center of mass of the rigid body, then a torque is generated and affects the angular velocity of the rigid body.

  1. rigidBody.applyImpulse(new math.Vec3(5, 0, 0));

By Changing Velocity

The rigid body component provides the setLinearVelocity interface that can be used to change the linear velocity.

  1. rigidBody.setLinearVelocity(new math.Vec3(5, 0, 0));

Similarly, the rigid body component also provides the setAngularVelocity interface, which can be used to change the angular velocity.

  1. rigidBody.setAngularVelocity(new math.Vec3(5, 0, 0));

Limit the Motion

By Sleeping

When Sleeping a rigid body, it empties the rigid body of all its forces and velocities, bringing it to a stop.

  1. if (rigidBody.isAwake) {
  2. rigidBody.sleep();
  3. }

The rigid body’s force and speed will be restored when it is awakened.

  1. if (rigidBody.isSleeping) {
  2. rigidBody.wakeUp();
  3. }

Note: Executing parts of the interface, such as applying force or impulse, changing velocity, grouping and masking will attempt to wake up the rigid body.

Via Damping

The rigid body component provides linearDamping linear damping and angularDamping rotational damping properties, which can be obtained or set via the linearDamping and angularDamping methods.

The range of damping parameters is recommended to be between 0 and 1, 0 means no damping and 1 means full damping.

  1. if (rigidBody) {
  2. rigidBody.linearDamping = 0.5;
  3. let linearDamping = rigidBody.linearDamping;
  4. rigidBody.angularDamping = 0.5;
  5. let angularDamping = rigidBody.angularDamping;
  6. }

Factors

The rigid body component provides the linearFactor linear velocity factor and angularFactor angular velocity factor properties, which can be obtained or set via the linearFactor and angularFactor methods.

The factors are of type Vec3 and the values of the corresponding components are used to scale the velocity change in the corresponding axes. The default values are both 1, which means the scaling is 1 times, i.e. no scaling.

  1. if (rigidBody) {
  2. rigidBody.linearFactor = new math.Vec3(0, 0.5, 0);
  3. let linearFactor = rigidBody.linearFactor;
  4. rigidBody.angularFactor = new math.Vec3(0, 0.5, 0);
  5. let angularFactor = rigidBody.angularFactor;
  6. }

Note:

  1. Setting the value of a component of the factor to 0 fixes the movement or rotation of an axis.
  2. In the case of cannon.js or ammo.js physics engines, the factor acts on different physical quantities, using cannon.js for velocity, and ammo.js for force.