Cocos Creator开发中的按钮节点的事件处理方法
Cocos Creator开发中的按钮节点的事件处理方法Cocos Creator基于Cocos2d-x(C++方案),提出全新的编程理念。Cocos Creator是以内容创作为核心的游戏开发工具,在Cocos2d-x基础上实现了彻底脚本化(可以使用Javascript、Typescript或者Coffeescript)、组件化和数据驱动等特点。 试验目的通过为按钮组件设置一个点击事件来实现在控制台输出一段文本。 试验步骤在场景中Canvas节点上添加一个UI节点Button并选择此节点,注意到其事件有关属性如图所示:
为此,我们需要专门写一个相应的脚本,不妨命名为MyComponent.js(注意这里的文件名是区别大小写的,因为它还代表组件的类名),内容如下。 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对底层的Cocos2d-x事件机制根据其自身的组件编程及事件驱动思想作了进一步封装,但是仅就其实现过程来看,仍然是比较麻烦的——其脚本代码并不短小。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |