cocos creator-碰撞检测

碰撞检测文档

刚体自行选择,刚体正常设置分组、tag,tag用于区分是哪个物体被碰撞了

正常在一个node下挂载脚本就行

复制代码
注意:Builtin 2D 物理模块只会发送 BEGIN_CONTACT 和 END_CONTACT 回调消息。

@ccclass('TestContactCallBack')
export class TestContactCallBack extends Component {
    start () {
        // 注册单个碰撞体的回调函数
        let collider = this.getComponent(Collider2D);
        if (collider) {
            collider.on(Contact2DType.BEGIN_CONTACT, this.onBeginContact, this);
            collider.on(Contact2DType.END_CONTACT, this.onEndContact, this);
            collider.on(Contact2DType.PRE_SOLVE, this.onPreSolve, this);
            collider.on(Contact2DType.POST_SOLVE, this.onPostSolve, this);
        }

        // 注册全局碰撞回调函数
        if (PhysicsSystem2D.instance) {
            PhysicsSystem2D.instance.on(Contact2DType.BEGIN_CONTACT, this.onBeginContact, this);
            PhysicsSystem2D.instance.on(Contact2DType.END_CONTACT, this.onEndContact, this);
            PhysicsSystem2D.instance.on(Contact2DType.PRE_SOLVE, this.onPreSolve, this);
            PhysicsSystem2D.instance.on(Contact2DType.POST_SOLVE, this.onPostSolve, this);
        }
    }
    onBeginContact (selfCollider: Collider2D, otherCollider: Collider2D, contact: IPhysics2DContact | null) {
        // 只在两个碰撞体开始接触时被调用一次
        console.log('onBeginContact');
    }

1、需要注意的是 刚体不能两个都是static,否则不会触发碰撞回调

2、碰撞回调的时候不能直接进行node销毁,否则会奔溃

复制代码
    onBeginContact (selfCollider: Collider2D, otherCollider: Collider2D, contact: IPhysics2DContact | null) {
        // 只在两个碰撞体开始接触时被调用一次
        console.log('onBeginContact222'+otherCollider.name);
        console.log('onBeginContact222name:'+selfCollider.name);
        // console.log('onBeginContact222tag:'+selfCollider.tag);

        if(selfCollider.tag==10 && otherCollider.tag==20){
            setTimeout(()=> {
                if(this.node && this.node.isValid) {
                  selfCollider.node.destroy();
                  otherCollider.node.destroy();
                }
              }, 500);
        }
相关推荐
遂心_11 小时前
JavaScript 函数参数传递机制:一道经典面试题解析
前端·javascript
遂心_11 小时前
深入理解 React Hook:useEffect 完全指南
前端·javascript·react.js
前端Hardy12 小时前
HTML&CSS: 谁懂啊!用代码 “擦去”图片雾气
前端·javascript·css
前端Hardy12 小时前
HTML&CSS:好精致的导航栏
前端·javascript·css
一个不爱写代码的瘦子12 小时前
迭代器和生成器
前端·javascript
源猿人16 小时前
企业级文件浏览系统的Vue实现:架构设计与最佳实践
前端·javascript·数据可视化
RoyLin16 小时前
TypeScript设计模式:迭代器模式
javascript·后端·node.js
小桥风满袖18 小时前
极简三分钟ES6 - ES9中for await of
前端·javascript
编程贝多芬18 小时前
Promise 的场景和最佳实践
前端·javascript
Asort18 小时前
JavaScript 从零开始(四):基础语法详解——从变量声明到数据类型的完全指南
前端·javascript