Skip to content

Latest commit

 

History

History
108 lines (73 loc) · 4.05 KB

physics-event.md

File metadata and controls

108 lines (73 loc) · 4.05 KB

Physics Events

The physics event system in Cocos Creator 3.0 are divided into trigger events and collision events, which are generated by Trigger and Collider respectively.

Trigger and Collider

When colliding, the collider will produce physical a behavior, however the trigger will not. Therefore, the trigger only performs collision detection. The collider performs both collision detection and physical simulation. The difference between them:

A Trigger is a Collider component whose Is Trigger property is true. When a collision occurs, the Trigger does not produce collision effect, so the Trigger is only used for collision detection.

The differences between Trigger and Collider are as follows:

  • Trigger do not perform finer detection with other triggers or colliders.
  • Collider do more detailed detection with other colliders, and will provide some additional data due to collisions, such as collision points, normals and so on.

Trigger Events and Collision Events

The differences between Trigger events and Collision events are as follows:

  • Trigger events are generated by triggers, and collision events are generated based on collision data.
  • The trigger event can be generated by the trigger with another trigger or another collider.
  • Collision events need to be generated by two colliders and at least one dynamic rigid body.

Trigger Events

There are three types of Trigger Events:

Events Description
onTriggerEnter Trigger start
onTriggerStay Trigger stay
onTriggerExit Trigger end

Where the collision pairs that can generate trigger events are:

Type Static rigid body Kinematic rigid body Dynamic rigid body
Static rigid body
Kinematic rigid body
Dynamic rigid body

Note: the prerequisite is that both must come with a collision component and at least one of them must be a trigger type.

Listen to trigger events

In order to add listeners to the trigger event, you need to add the corresponding callback by registering the event:

  1. Get Collider through this.getComponent(Collider)
  2. Register the callback of the corresponding event through the on or once method of Collider

Code example:

public start () {
    let collider = this.getComponent(Collider);
    collider.on('onTriggerStay', this.onTrigger, this);
}

private onTrigger (event: ITriggerEvent) {
    console.log(event.type, event);
}

Collision Events

Collision events are generated based on collision data. Collision data is not generated between rigid bodies of static types.

Collision events are divided into three types:

Events Description
onCollisionEnter Start of the collision
onCollisionStay Collision hold
onCollisionExit end of the collision

Where the collision pairs that can generate collision events are:

Type Static rigid body Kinematic rigid body Dynamic rigid body
Static rigid body
Kinematic rigid body
Dynamic rigid body

Note: the prerequisite is that both must come with a collision component and both must be of the collider type.

Listen to collision events

In order to add a listener to the collision event, you need to add the corresponding callback by registering the event:

  1. Get Collider through this.getComponent(Collider)
  2. Register the callback of the corresponding event through the on or once method of Collider

Code example:

public start () {
    let collider = this.getComponent(Collider);
    collider.on('onCollisionStay', this.onCollision, this);
}

private onCollision (event: ICollisionEvent) {
    console.log(event.type, event);
}

Notes:

  1. Collider is the parent class of all collision components.
  2. Collision events are in physical elements, and all collider components on this element will receive collision events.