[cocos2dx]2.2到3.1(3.0)升级帮助

摘要: cocos2dx 是一款优秀的多平台,专为2D游戏设计的引擎. 在活跃的开源社区的推进下, 越发稳定和强大. 2.x -> 3.x的更新幅度很大, 性能的提升和功能的丰富也非常明显. 但在享受进步的同时,也要承受迁徙之苦. 本文主要是总结自己迁徙的经历, 以防大家走弯路.



    • 基础准备
    • 进入正题
      • 语法更新

        • obj-c式命名 ==> c++命名空间式命名
        • include文件变更
        • std::function作为监听函数
      • 功能更新
        • 中间层UILayer的去除
        • 键盘响应方式变更
        • Armature的陷阱
        • 更加优雅的anchorPoint
        • Sprite的默认GLProgram
        • stl::vector的不稳定排序导致的层级问题
        • umeng等第三方库的更新

基础准备

  1. 我一直把VS当作主开发环境, eclipse和xcode作为特定机型的调试环境. 所以, 偷个懒, 假设你也在用VS开发. 另外两个平台也也都有正则表达式替换功能, 大同小异.
  2. 在这里, 假设你已经搭好了3.x的VS开发环境, 能正常运行HelloWorld演示.
  3. 假设你有一定的正则表达式基础. 如果没有的话, 可参考这篇速成教程:正则表达式30分钟入门教程

进入正题

cocos2dx 3.1的简要feature更新介绍可参考这里, 详细的changelog可参考这里.在升级之前, 建议扫一遍changelog( 否则都不知道要做啥…).

接下来, 进入正题啦:

语法更新

本文将有非常多字符串替换的步骤, 都在vs2012中进行. vs2012中字符串替换窗口如下:

本文将上图代表的替换表示为:( 以后将不特殊说明 )

//regex-replace
\bUIImageView\b ==> ui::ImageView

obj-c式命名 ==> c++命名空间式命名

以下是常见的替换:

//regex-replace
//Widget:
\bUIWidget\b                                ==> ui::Widget
\bUIImageView\b                             ==> ui::ImageView
\bUIButton\b                                ==> ui::Button
...
\bUILayout\b                                ==> ui::Layout
\bUILabel\b                                 ==> ui::Text
\bUILayer\b                                 ==> Layer
\bCCObject\b                                ==> Ref
...

\baddTouchEventListener\s*\(\s*(.+)\s*,\s*toucheventselector\s*\((.*)\)\s*\)  ==> addTouchEventListener( CC_CALLBACK_2( $2, $1 ))
\bTouchEventType\b                          ==> ui::Widget::TouchEventType
\bTOUCH_EVENT_([A-Z]+)\b                    ==> ui::Widget::TouchEventType::$1
\baddWidget\b\s*\(                          ==> addChild(

注释: \b代表单词的分割符. ()代表被标记的内容, $1 代表原始字符串中被标记的内容中的第一段. 具体请参考在 Visual Studio 中使用正则表达式.

include文件变更

因为包结构的变化, 所以有些组件的定义会未被include.

主要用到的head文件有:

head 描述
cocos2d.h cocos2dx的基本数据类和Node类都包含在里面
ui/CocosGUI.h cocos2dx 绝大部分的UI类都包含在内. 2.x版本中, UI类都包含在cocos-ext.h中. 所以绝大部分原来引用cocos-ext.h的地方都需要引用此文件
cocostudio/CocoStudio.h cocostudio功能相关的类都包含在里面. 最主要的是各种读取json文件的Reader. 其次, 是Armature动画.
cocos-ext.h 相比2.x的cocos-ext.h, 此文件做了非常大的精简. 现在主要包括CCScrollView及其子类, 另外还有EditBox

std::function作为监听函数

虽然, 3.1 的版本仍然支持绝大多数老版本的回调函数方式, 比如: m_btnSubmit->addTouchEventListener (this,toucheventselector(RewardItemCell::onBtnSubmitClick));仍然能工作. 但是, 不能保证在将来的3.x版本中仍然如此. 所以, 尽量一次搞定吧. 在obj-c式命名 ==> c++命名空间式命名章节中, 有批量替换的正则表达式,可作为参考.

功能更新

中间层UILayer的去除

在2.x版本, Widget需要作为UILayer的孩子节点才能响应触摸事件; 而在3.x版本中取消了这个限制, Widget的响应机制变为跟Menu类似. 目前, 我也没有大量的去掉之前的UILayer层, 大部分功能仍然正常工作.

键盘响应方式变更

在2.x版本中, 键盘响应的监听是用CCDirector::sharedDirector()->getKeypadDispatcher()->addDelegate(this);实现的. 在3.x版本中是这样:

auto keyListener = EventListenerKeyboard::create();
keyListener->onKeyReleased = CC_CALLBACK_2(MainScene::keyBackClicked, this);
_eventDispatcher->addEventListenerWithSceneGraphPriority(keyListener, this);

监听的取消, 也要做响应的替换.

Armature的陷阱

在2.x版本中, 一般通过下面的方式来监听Armature的事件. 在监听到COMPLETE的时候, 可以将此Armature移出场景.

CCArmature* swf = CCArmature::create(swfName);
swf->getAnimation()->setMovementEventCallFunc(this, movementEvent_selector(OutCardEffectHelper::onAnimationEnd));

但是在3.x中, 我们不能在监听事件的回调函数中做任何可能会导致release此对象的操作. 否则, 会导野指针错误.

是不是有点鸡肋? 我们来看看这种情况是怎么发生的:

Created with Rapha?l 2.1.0SchedulerSchedulerArmatureArmatureArmatureAnimationArmatureAnimationthisthisBoneBoneupdate(t)update(t)告诉监听者假设此时触发了COMPLETE事件this->remove Armature, release Armatureupdate(t)set `_armatureTransformDirty = false`but now, Armature has been RELEASED!!!

我临时用定时器来移除Armature的. 具体过程如下:

1. 为ArmatureAnimation增加一个公开函数: virtual MovementData *getMovementData() const { return _movementData; }

2. 通过下面的方式来移除: (PS: Lmada 表达式真是好用啊啊啊啊啊 )

auto data = swf->getAnimation()->getMovementData();
float speed = data->scale;
float frames = data->duration;
float delay = frames/60/speed;
string id = FORMAT_TEXT( "%p", swf );
Director::getInstance()->getScheduler()->schedule( [swf](float t){swf->removeFromParent();},this,0,0,delay,false, id);

更加优雅的anchorPoint

如果你加载了cocostudio生成的ui json文件, 并改动过内部Widget的位置的话, 你会发现, 代码中x=20跟cocostudio ui编辑器中x=20效果是不一样的.

问题出在哪里呢?

简单来说, 2.x版本中的anchorPoint对自己在父亲节点的位置和孩子节点在自己中的位置都有影响; 3.x版本中的anchorPoint只对自己在父亲节点中的位置有影响.

举个例子. 假设A是父亲节点,B是A的孩子节点. A和B同为10*10的正方形.

A.anchorPoint = Point(0.5,0.5);
A.setSize(Size(10,10))
B.anchorPoint = Point(0.5,0.5);
B.setSize(Size(10,10))
B.setPosition( Point::ZERO );
A.addChild(B);

在2.x版本中: A和B的位置完全重合

在3.x版本中: B的中心点和A的左下角的点重合.

Sprite的默认GLProgram

什么?你没听过GLProgram, 那恭喜你, 可以跳过这小节了. 因为你肯定不会出现下面的恼人情况.

SHADER_NAME_POSITION_TEXTURE_COLOR是2.x版本中的默认GLProgram. 它对应的vect和frag分别是:ccPositionTextureColor_vertccPositionTextureColor_frag. vect用来确定位置,frag用来确定色彩.

然而, 在3.x版本中,默认的GLProgramSHADER_NAME_POSITION_TEXTURE_COLOR_NO_MVP, 对应的vect和frag分别是:ccPositionTextureColor_noMVP_vertccPositionTextureColor_noMVP_frag.

如果你恰好用过ccPositionTextureColor_vert的话, 建议改为ccPositionTextureColor_noMVP_vert. 否则会出现莫名的位置偏移问题.

stl::vector的不稳定排序导致的层级问题

2.x版本中, 如果没有对孩子设置过zOrder的话, 孩子节点的覆盖顺序为: 后加的节点在上层, 先加的节点在下层.

3.x版本中, win32环境下, 孩子节点的覆盖层级还能保续. 但是在android平台下, zOrder相同的孩子, 层级顺序是随机的. 关键在下面的代码:

void Node::sortAllChildren()
{
    if( _reorderChildDirty ) {
        std::sort( std::begin(_children), std::end(_children), nodeComparisonLess );
        _reorderChildDirty = false;
    }
}

win32和android平台对stl::sort()的实现不同, android下的排序算法不是稳定的. 解决方法:

  1. 修改上述代码, 实现稳定排序
  2. 添加孩子节点的时候手动设置zOrder来保证层级顺序.

umeng等第三方库的更新

第三方库, 也有很多跟cocos2dx版本相关. 注意升级, 否则会闪退.

Written with StackEdit.

[cocos2dx]2.2到3.1(3.0)升级帮助

时间: 2024-07-28 21:44:13

[cocos2dx]2.2到3.1(3.0)升级帮助的相关文章

关于cocos2dx 3.0升级崩溃报错(unable to load native library) 和(Fatal signal 11 (SIGSEGV) at 0x00000000)

最近一直在Windows平台开发cocos-2dx游戏,期间做了一次引擎升级,升级到了3.0正式版本.Windows平台上表现很正常,没有出现什么问题. 上周五准备发布一个安卓包,编译很轻松的就过了,没有花费多少时间,但是安装到手机后,发现运行就崩溃了.没办法只好用模拟机调试,再次吐槽Android的模拟器,真的太他妈慢了,不到万不得已我真的不想再去用它,google真的应该好好整一下了. 好不容易运行起来了,看到崩溃的时候logcat的报错是"unable to load native lib

day04_oracle版本升级--10.2.0.1.0升级到10.2.0.4.0

软件升级 1.oracle很少升级,除非你要用什么新的功能.因为升级要停库,好多和库相关的组件可能全要升级.升级前一定要开会研究很长时间. 2.一些大公司定期委托第三方公司做<系统安全防护评测>,扫描出一些漏洞时,会要求升级并打补丁[联通] 神州数码信息服务股份有限公司.绿盟科技 如下形式的漏洞: 漏洞详细信息 Oracle数据库Network Foundation组件远程拒绝服务漏洞 详细描述 本次扫描是通过版本进行的,可能发生误报. Oracle Network Foundation是 O

UiAutomator2.0升级填坑记

UiAutomator2.0升级填坑记 SkySeraph May. 28th 2017 Email:[email protected] 更多精彩请直接访问SkySeraph个人站点:www.skyseraph.com 啰嗦 Google Android Developers 在2015年3月就发布了UiAutomator 2.0版本(下文简称U2),而公司的核心产品中用到还是UiAutomator老版本(下文简称U1),业界用U2的也不是很多,虽然有诸多问题和不便(如高版本OS中不支持Remo

OkHttpUtils-2.0.0 升级后改名 OkGo,全新完美支持 RxJava,比 Retrofit 更简单易用。

okhttp-OkGo 项目地址:jeasonlzy/okhttp-OkGo 简介:OkHttpUtils-2.0.0 升级后改名 OkGo,全新完美支持 RxJava,比 Retrofit 更简单易用.该库是封装了 okhttp 的网络框架,支持大文件上传下载,上传进度回调,下载进度回调,表单上传(多文件和多参数一起上传),链式调用,可以自定义返回对象,支持 Https 和自签名证书,支持 cookie 的持久化和自动管理,支持四种缓存模式缓存网络数据,支持 301 和 302 重定向,扩展了

linux内核升级(ubuntu12.04从3.13.0升级到3.4.0 )

花了一天的时间,终于把ubuntu12.04 的linux内核版本从3.13.0升级到3.4.0 升级后,系统更加稳定. 具体步骤:# wget http://www.kernel.org/pub/linux/kernel/v3.x/linux-3.4.tar.gz# tar zxvf linux-3.4.tar.gz -C /usr/src# cd /usr/src/linux-3.4# make menuconfig# make# make modules_install# cp arch/

MetroUICSS 2.0到3.0升级细节记录

Metro UI CSS 是一套用来创建类似于Windows 8 Metro UI风格网站的样式 其官网地址:http://metroui.org.ua/ 中文地址:http://www.bootcss.com/p/metro-ui-css/ 源码地址: https://github.com/olton/Metro-UI-CSS 这种前端框架没有Bootstrap.YUI流行,网上资料也不多.现在项目中用的这框架要从2.0升级到3.0,我在这里记录下各种细节. js包的替换,url的替换 but

Oracle升级_oracle 10g版本由 10.2.0.4.0升级为10.2.0.4.4(即PSU升级)

***************************************************************************************************** 续借上篇:Oracle升级_oracle 10g版本由 10.2.0.1.0升级为10.2.0.4.0(即CPU升级) ***********************************************声明***************************************

jackson2.5.0升级到2.7.0

开发环境:spring-mvc4.1.7.jackson2.7.0 问题描述:项目中将原来的jackson2.5.0升级到2.7.0,导致服务调用出错. mvc相关的配置文件如下: <?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.

精彩分享 ------ 将&quot;女朋友7.0&quot;升级到&quot;老婆1.0&quot;的Bug

亲爱的技术部: 我急需您的帮助.我最近将"女朋友7.0"升级到"妻子1.0",发现这个新程序意外地启动了孩子生产程序,而且占用了大量的空间和珍贵的资源.这在产品的 使用手册中没有提到.         此外"妻子1.0"自动将自己安装到其他的所有的程序中,它随系统同时启动,监控整个系统的状态."男人夜店2.5"和"迪吧5.3"无法再运行,一旦运行该程 序系统即行崩溃.试图运行"通宵麻将6.3&qu