Cocos Creator开发中的按钮节点的事件处理方法

简介:

Cocos Creator开发中的按钮节点的事件处理方法

Cocos Creator基于Cocos2d-x(C++方案),提出全新的编程理念。Cocos Creator是以内容创作为核心的游戏开发工具,在Cocos2d-x基础上实现了彻底脚本化(可以使用Javascript、Typescript或者Coffeescript)、组件化和数据驱动等特点。
但是,在事件处理机制上并不显得简单,至少是新手初学阶段如此。下面我们通过场景制作中按钮组件的事件处理机制来说明这个问题。

试验目的

通过为按钮组件设置一个点击事件来实现在控制台输出一段文本。

试验步骤

在场景中Canvas节点上添加一个UI节点Button并选择此节点,注意到其事件有关属性如图所示:

Cocos Creator开发中的按钮节点的事件处理方法
也就是说,Click Events属性是列表类型,默认为空,用户添加的每一个事件由节点引用,组件名称,一个响应函数及定制事件参数组件组成。
只有当我们把Click Events事件属性列表结点个数修改成大于或者等于1时,对应的事件参数才显示出来,各个参数含义如下:
Cocos Creator开发中的按钮节点的事件处理方法
图形效果展示如下:

Cocos Creator开发中的按钮节点的事件处理方法
上图是把Click Events事件属性列表结点个数改成1的样子。
接下来,上面几个参数的填写需要按照上面的解释进行。

为此,我们需要专门写一个相应的脚本,不妨命名为MyComponent.js(注意这里的文件名是区别大小写的,因为它还代表组件的类名),内容如下。
cc.Class({
extends: cc.Component,
properties: {},

onLoad: function () {
    var clickEventHandler = new cc.Component.EventHandler();
    clickEventHandler.target = this.node; //这个node节点是你的事件处理代码组件所属的节点
    clickEventHandler.component = "MyComponent";//这个是代码文件名
    clickEventHandler.handler = "callback";
    clickEventHandler.customEventData = "foobar";

    var button = this.node.getComponent(cc.Button);
    button.clickEvents.push(clickEventHandler);
},

callback: function (event, customEventData) {
    //这里 event 是一个 Touch Event 对象,你可以通过 event.target 取到事件的发送节点
    var node = event.target;
    var button = node.getComponent(cc.Button);
    //这里的 customEventData 参数就等于你之前设置的 "foobar"
    console.log("para is: ",customEventData);
}

});
保存上面的脚本后,通过点击场景中按钮节点对应“属性检查器”窗口中下部的“添加组件”按钮为此按钮节点添加一个“用户脚本组件”并选择上面刚刚创建的脚本。

然后,拖动层级管理器中的按钮节点到按钮事件属性对应的第一个参数处,并以此为基础,依次选择第二个已经绑定到该按钮节点上的脚本组件以及第三个回调参数(上面脚本中已经定义了,是callback)。结果如下所示:
Cocos Creator开发中的按钮节点的事件处理方法

至此, 我们达到了本文开始时提出的目的,即点击按钮使在控制台上输出一段文本的效果。

小结

尽管Cocos Creator对底层的Cocos2d-x事件机制根据其自身的组件编程及事件驱动思想作了进一步封装,但是仅就其实现过程来看,仍然是比较麻烦的——其脚本代码并不短小。

















本文转自朱先忠老师51CTO博客,原文链接: http://blog.51cto.com/zhuxianzhong/2059626,如需转载请自行联系原作者



相关文章
|
9天前
【Qt 学习笔记】按钮实现helloworld | 信号与槽概述
【Qt 学习笔记】按钮实现helloworld | 信号与槽概述
19 0
|
6月前
|
Python
PyQt5-基本控件| 主窗口的类型、创建以及代码如何实现?
PyQt5-基本控件| 主窗口的类型、创建以及代码如何实现?
37 1
|
6月前
Cocos Creator3.8 项目实战(二)cocos creator编辑器中绑定事件引发的bug解决
Cocos Creator3.8 项目实战(二)cocos creator编辑器中绑定事件引发的bug解决
|
11月前
|
C++
Qt按钮对象和一些函数
Qt按钮对象和一些函数
165 0
|
索引
PyQt5 技术篇-QComboBox下拉框绑定监听事件实例演示
PyQt5 技术篇-QComboBox下拉框绑定监听事件实例演示
1000 0
|
索引 Windows
VB编程:Timer控件实例幼儿识字卡片-35
VB编程:Timer控件实例幼儿识字卡片-35
|
Dart API 开发者
【Flutter】Hero 动画 ( Hero 动画使用流程 | 创建 Hero 动画核心组件 | 创建源页面 | 创建目的页面 | 页面跳转 )
【Flutter】Hero 动画 ( Hero 动画使用流程 | 创建 Hero 动画核心组件 | 创建源页面 | 创建目的页面 | 页面跳转 )
183 0
【Flutter】Hero 动画 ( Hero 动画使用流程 | 创建 Hero 动画核心组件 | 创建源页面 | 创建目的页面 | 页面跳转 )
Qt-第一个QML程序-4-自定义按钮类,动画,状态
上篇中,我们写到了自己定义了一个按钮,但是呢,按照这样的写法,要写一个程序出来,那要累死了,所以,qml给我的感觉就是各种随便调用,所以了,可以自己写一个自己Button的qml,这样在以后用到了,就可以直接使用了。
360 0
Qt-第一个QML程序-4-自定义按钮类,动画,状态
Qt-第一个QML程序-3-自定义一个按钮
项目基本信息前两个已经说了,这里直接放下运行截图,
156 0
Qt-第一个QML程序-3-自定义一个按钮