奎特尔星球上有一件绝世神兵,就像是一把雷神之锤,在它的号令之下指挥着节点、组件和触摸事件,从而大量减少冗余代码与编辑器上的设置,他就是uikiller。uikiller指挥着英雄与魔灵杀敌无数,他的前身曾经在cocos2d-js星球上服役,名为UILoader。经过我潜心的改进,来到了奎特尔星球。

一、雷神之锤


uikiller只有一行需要要被主动调用的函数:uikiller.bindComponent,他就像一把雷神之锤,为组件下所有的节点和组件注入了魔力。

cc.Class({...onLoad() {/*绑定当前组件节点以及基下所有以“_”开头的节点*/uikiller.bindComponent(this); }
});    

二、 杀、杀、杀—体验UI编程的快感

节点killer

在编辑器中以下划线“_”开头的节点,在雷神之锤的作用下,将会被自动绑定成当前组件实例的属性。

例如节点名:_labelName、_buttonOk

uikiller.bindComponent(this);  //使用bindComponent后即可访问子节点
this._labelName.active = true; //隐藏控件
this._buttonOk. x += 10; //设置 x 坐标

有没有一种很爽快的感觉,省去了定义和设置节点属性的动作,就上面三行代码来说,据我目测至少可以为你减少20个字节、两次的节点拖拽、30~60秒工作时间。

组件killer

在节点访问的基础上,使用“$” + “组件名”访问节点上挂载的组件对象。

例如节点名:_labelName 、_buttonOk

...
this._labelName.$Label.string = 'xxx'; //设置 Label的文本
this._buttonOk.$Button.interactable = false; //禁用按钮

访问组件属性同样很轻松,原来使用的getComponent(cc.Label)$Label所取代,再次为你省去5秒钟时间,代码量减少22个字节。

触摸事件killer

以下划线“_”开头的节点可以自动关联触摸事件

目前支持五个触摸事件:

TouchStart、TouchMove、TouchEnd、TouchCancel、TouchLong

命名规则

_on + 节点名(去下划线,首字母大写) + 触摸事件名
例如节点:_labelName
事件函数:_on***LabelName***TouchEnd

cc.Class({..._onLabelNameTouchStart(sender, eventTouch) {//sender 参数为发出事件的节点对象 cc.asset(this._labelName === sender); },_onButtonOkTouchEnd(sender, eventTouch) {//eventTouch 参数为触摸事件,可获取触摸坐标位置let location = eventTouch.getLocation(); },
});    

无需在编辑器上拖拽配置事件函数,也无需在代码中使用node.on注册事件监听。不论节点挂载的是Button还是Label或者其它组件,只要是节点使用上述方法都可以监听其触摸事件。

附赠很多人心仪以久的,触摸长按事件的支持

  onLoad() {...//控制长按触摸触发时间0.5秒,不要这句代码,默认1秒触发this._buttonOk.touchLongTime = 0.5; }_onButtonOkTouchLong(sender) {//在此响应长按事件}

如果同时监听了TouchEnd事件, 长按事件发生后,手指抬起,不会再触发TouchEnd事件。

轻轻睁开你的眼睛,看着自己书写的代码像一篇散文或似一首诗歌,闭上双眼,它又像一清新婀娜的少女,这时你就和你的作品恋爱了。

三、割草般的编程体验—无双乱舞

1. 三国无双

不知道大家玩过《三国无双》没有,相信很多人会说《三国无双》就是一个割草游戏。敌人像一片片的杂草数量众多,蜂拥而来,你一阵潇洒的连招下去杀死一大片,此刻无双能量暴满,一阵让自己都会陶醉的无双乱舞,只听见敌军一阵狼嚎,像爆米花一样在天空上起起落落,我想大多数人还是会很享受这种一骑当千的快感。

2. uikiller无双技

    // use this for initializationonLoad: function () {uikiller.bindComponent(this);//8连击,还带for循环的哦for(let i = 1; i <= 8; i++) {//节点名为"_image1~_image8"let name = '_image' + i; let node = this[name];/*节点下的num是一个Label用Name就可以直接访问*//*但是Label没“_”开头,不能用$访问节点下的组件*/node.num.getComponent(cc.Label).string = i;}},/***触发无双技能*_image1~_image8的事件响应函数,都会来这里*通过sender.$可以获取在编辑上的$后的字符串**/_onImageTouchEnd(sender) {cc.log(`你点击了${sender.$},他的节点名字为"${sender.name}"`);},

用上面的列子为你详解一下无双技要点:
1. 在节点名字中使用符号符号 符号之前为事件名:_image
符号之后为识别符:1 8(可以是任意数字、字母)2.访问节点:事件名+识别符(如果是字母开头首字母需大写)this.image1 this.image83.读取识别符:node.符号之后为识别符:1~8(可以是任意数字、字母) 2. 访问节点:事件名 + 识别符(如果是字母开头首字母需大写) this._image1 ~ this._image8 3. 读取识别符:node.
this._image1.$ === ‘1’,注意他是字符串哦!
4. 事件函数:_on + 事件名 + 触摸事件名
_onImageTouchStart
_onImageTouchMove
_onImageTouchEnd
_onImageTouchLong

3. 连锁闪电

细心的朋友可能已经发现,上面一阵无双乱舞中出现一行怪招

node.num.getComponent(cc.Label).string = i;

其中的num节点没有“_”开头,怎么也能直接访问呢?这里我是不小心触发了uikiller雷神之锤的连锁闪电的魔力,所有被雷神之锤(bindComponent)绑定后的UI节点,被闪电链接在了一起,节点下的节点可以像使用路径一样访问。
1. a节点下有个b节点,b节点下有个c节点,a、b、c节点都不带下划线
2. _a节点下有个b节点,b节点下有个c节点,b、c节点都不带下划线

发动连锁闪电
  this.node.a.b.c.name //注意a节点没有"_"开头,从node上开始闪电this._a.b.c.name //直接从"_"开头的节点开始闪电

连锁闪电是以节点路径方式传导,可以访问任意子节点,且节点不需要用“_”开头。

想像一下,每个人都手持雷神之锤,一起释放无双乱舞是何等的体验,让你在代码编写过程中也能体验到以一当千的快感,而且这不是在做梦!其实uikille早已是奎特尔星上人人必备的装备(回顾一下四周,囧,貌似奎特尔星球上目前还没几个居民),不然如何能坚持到现在,还在这里写教程。

四、写在最后

按一般常理来说从感受快感体验高潮,接下来多半会一泄千里,洗洗睡了,但在奎特尔星球上这想那是非常不正确的,好的体验不仅仅只是在文字上,更重要的是在体验本身,在此奉献上源码供大家把玩。

github: https://github.com/ShawnZhang2015/uikiller

下一次再跟大家分享奎特尔星球上的故事
- uikiller—乾坤大挪移功法

奎特尔星球|雷神之锤(上)相关推荐

  1. 奎特尔星球|雷神之锤(下)

    紧接上篇<奎特尔星球|雷神之锤(上)>,我给大家介绍了雷神之锤-uikiller的基本用法,有人说长按功能可以取名为蓄力攻击.重击,我觉得还真是可以的,但就是感觉招数名字不够大气.在这里还 ...

  2. 奎特尔星球|魔灵传说(上)

    前一篇<奎特尔星球-英雄与魔灵>,有朋友反应没看太懂,我在这里简单总结一下,核心要点: - Node是Node的容器. - Node是Component的容器. - Node是显示核心,C ...

  3. 奎特尔星球UI利器—uikiller

    注意:本文中包含程序代码,建议在手机上使用横屏阅读以获得更好的体验,在电脑上阅读可获得最佳体验 奎特尔星球上有一件绝世神兵,就像是一把雷神之锤,在它的号令之下指挥着节点.组件和触摸事件,从而大量减少冗 ...

  4. 奎特尔星球|英雄与魔灵

    这次换一种方式聊聊Creator的UI开发,目的是想让学习那么枯燥,如果你是一个爱玩游戏的朋友相信你会很有感觉. 一.奎特尔星球 在奎特尔星球上,有着无数的英雄,身怀绝世魔力,在创世之主的统之下维护着 ...

  5. 奎特尔星球上的白魔法

    我敢肯定你一定想想过,如果不用编写代码就能开发游戏就好了!看看奎特尔上的白魔法!

  6. 庆祝「奎特尔」800+勇士,集结!

    公众号从2017年09月24日推送第一篇教程以来,已经416天了. 截至今天已经集结812位Cocos Creator的勇士,在此感恩大家的关注与支持,是大家给了我分享的机会,是你们让我一路上不断坚持 ...

  7. 幼麟・闪影・奎特尔~2019不太冷!

    为了自己的第一个处女作<奎特尔数字大冒险>又封闭了近10天时间,给游戏增加金币和新角色,用了一个晚上研究微信云开发,感觉局限性太大又用了两天去搞腾讯的小游戏框架wafer-client-s ...

  8. 预告!奎特尔数字大冒险

    Shawn有一个星期没来发公众号了,自从开了GitChat写了一篇<集合类游戏模块化与热更新实践>感觉把存货都用光了... 不过Shawn并没有闲着,这几天一直都在折腾自己的一个微信小游戏 ...

  9. 遇见未知的自己,奎特尔成长之路!

    这篇文章是我上周在公众号「程序视界」的投稿,回顾了Shawn一段自娱自乐的历史,特别是在2018年能看到自己一点点的成长.战胜曾经的自己,内心升起一种难以言语的喜悦. 前言 有幸被安晓辉老师的「程序视 ...

最新文章

  1. UNICODE使用的一些知识和技巧
  2. 基于OpenCV实战:车牌检测
  3. Maven出现User setting file does not exist ...\.m2\setting.xml的问题解决(同时也解决用户.m2目录下无setting.xml文件)...
  4. 一次mysql数据库连接池泄露的解决经历
  5. 数据中台实战(八):如何打造可以支撑N条产品线的标签平台
  6. 基于simulink的SVC与SVG的性能比较
  7. 一键Ghost 脱机下载不再愁
  8. Java中带标签的break,continue
  9. Web的系统测试方法
  10. w3cschool oracle,AJAX 数据库 | w3cschool菜鸟教程
  11. 该怎么清缓存呢?fflush clear ignore
  12. python解决xml文件论文-实例Python处理XML文件的方法
  13. Linux脚本实战之SSH执行远端脚本
  14. 自从硬派网倒闭后,就没有什么好看的IT硬件网站了
  15. css 平移到某个位置_CSS3 对象平移translate()translatex()translatey()应用实例,包括水平垂直居中...
  16. SitePoint Podcast#37:社交媒体:坏事与丑陋
  17. 发布一个水管接通游戏的源代码
  18. python练习题(3)--字符串及正则表达式的应用
  19. 餐饮服务设备行业的互联网趋势
  20. 【眼见为实】数据库并发问题 封锁协议 隔离级别

热门文章

  1. (C语言)八大排序之:希尔排序
  2. 网络请求发生javax.net.ssl.SSLHandshakeException异常的情况
  3. Mysql中的 not null
  4. 万国数据在广州收购新的数据中心项目(广州三号) 加快数据中心战略部署
  5. java错误、_JAVA错误汇总
  6. 用Python+OpenCV+PIL构建猫脸识别器
  7. 3.14UiPath图片操作截图的介绍和使用
  8. 给PyQt5 exe程序设置自启动(Windows)
  9. 曝光和点击都挺高,亚马逊Listing转化率却很低!问题出在哪?
  10. mysql 主键值向后递增1_mysql中的主键递增