uikiller再度进化支持Cocos Creator 2.0

Wesley13
• 阅读 797

1. 前言

早在8月24日,公众号收到网友Vincent的留言,提醒我uikiller库在Cocos Creator 2.0上有错!惊出一身冷汗,怎么忘记这个事了。晚上回到家,迅速启动Cocos Creator 2.0打开uikiller工程,确实是有问题,还好问题不严重,立马做了修改并推送到github仓库增加了v2分支,在此感谢Vincent提醒!

虽然uikiller的使用者并不多,但是也有朋友已经将uikiller应用到了自己的项目,一旦有问题,我也是有责任的!在这里肯请大家,如果发现我的问题,希望能即时向我指出。

2. Cocos Creator 2.0升级遇到的问题

uikiller在Cocos Creator 2.0上的问题,主要是Cocos Creator有部分API发生了变化和调整,目前Shawn还没有使用Cocos Creator 2.0做项目,有些后知后觉!我将在uikiller中发现的API调整做一个简单分享:

(1) 使用rect.contains替换cc.rectContainsPoint

uikiller再度进化支持Cocos Creator 2.0

(2) cc.pXXX系列函数被废弃,使用cc.Vec2成员函数

uikiller再度进化支持Cocos Creator 2.0

cc.pAdd需改为p.add,cc.pMult改为p.mul

uikiller再度进化支持Cocos Creator 2.0

两个点的距离计算cc.pDistance改为p1.sub(p2).mag()。

(3) cc.audioEngine.play不建议使用url参数

uikiller再度进化支持Cocos Creator 2.0

cc.audioEngine.play(url)使用下面方法代替:

cc.loader.loadRes(url, cc.AudioClip, (error, audioClip) => {
    cc.audioEngine.play(audioClip);
})
(4) 更多参见Cocos Creator2.0升级指南

Shawn这里讲的都非常简单,更多引擎升级问题请参考官方文档Cocos Creator v2.0 升级文档: 

http://docs.cocos.com/creator/manual/zh/release-notes/upgrade-guide-v2.0.html

3. uikiller进化之路

将界面逻辑与业务逻辑都编写在组件脚本中是否合适?如何将MVC模型应用于Cocos Creator游戏开发之中?Shawn经过对PureMVC的项目实践经验,结合Cocos Creator组件化开发,总结出了一套更加简化的MVC模型,不过目前只提供了控制器的简单应用。

uikiller再度进化支持Cocos Creator 2.0

如果你也感兴趣,可以参考uikiller源码测试场景:test3、test10可以看到具体使用方法和效果。

一个预制体,两个脚本(组件脚本与控件器脚本),这让我联想到《斗罗大陆》唐三的双生武魂,左手蓝银草主控制,右手昊天锤主攻击,请看下图:

uikiller再度进化支持Cocos Creator 2.0

不吹那么多了,多年心得尽在uikiller,源码地址奉上:https://github.com/ShawnZhang2015/uikiller

4. 小结

在此欢迎大家来「奎特尔星球」投稿,我们一起学习共同成长,将自己的经验用文字记录下来,整理成行之有效的方法论,使之能被迭代、复制。

不论你是程序员、策划、美术,只要你的经验能帮助大家,都非常欢迎。帮助他人,也是帮助自己!相信自己,如果你坚持做下去,一定会看到一个不一样的自己!


欢迎关注「奎特尔星球」微信公众号,更期待你向公众号投稿,来我们一起成长!

uikiller再度进化支持Cocos Creator 2.0

热门文章TOP10,邀你遨游「奎特尔星球」

  1. Cococ Creator基础教程—meta的秘密(3)

  2. 庆祝「奎特尔」500勇士,诞生!

  3. 当creator遇上protobufjs—感谢有你,再战2.0

  4. Cocos Creator基础教程(7)—场景切换

  5. Cocos Creator基础教程(9)—优化代码编辑器

  6. Cocos Creator基础教程(4)—color属性的妙用

  7. Cocos Creator基础教程(1)—从zIndex开始

  8. Cocos Creator基础教程(2)—聊聊scale与size属性

  9. Creator模块介绍—领略模块化的力量

  10. 探索CocosH5正确的开发姿势

本文分享自微信公众号 - Creator星球游戏开发社区(creator-star)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Android蓝牙连接汽车OBD设备
//设备连接public class BluetoothConnect implements Runnable {    private static final UUID CONNECT_UUID  UUID.fromString("0000110100001000800000805F9B34FB");
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这