cocos2d-x v2 和 v3 对照手册
2015-05-04 更新: 加入 OpenGL 和 MenuItem 的相关变化。
本文的内容来自于对其它几篇文章的翻译、修改和合成,同时,我也会不断增加自己的内容。
下面这部分内容来自对这篇文章的翻译:cocos2d-x v2 to v3 mapping guide
但这篇文章有一些老了,还有一些内容已经在 cocos2d-x 3.3 中过时。因此,我并没有进行完全对照翻译。对原文中的错误,我也进行了一些修改。
我的新项目开始使用 cocos2d-x v3 。cocos2d-x v3 和 v2 相比有非常大的改变。我把踩过的坑列在下面,以方便后来之人。
cocos2d-x 常用类名改变
下面的表格中的类名的转换方式主要是直接删除了 CC 前缀。
# | v2 | v3 |
---|---|---|
1 | CCAction | Action |
2 | CCPoint | Point |
3 | CCAnimation | Animation |
4 | CCSprite | Sprite |
5 | CCLabel | Label |
6 | CCMenu | Menu |
7 | CCObject | Ref |
8 | CCNode | Node |
9 | CCScene | Scene |
10 | CCLayer | Layer |
11 | CCSpriteBatchNoe | SpriteBatchNode |
12 | CCTMXTiledMap | TMXTiledMap |
cocos2d-x 类名改变
下面表格中的类名的转换就比较大了。
# | v2 | v3 |
---|---|---|
1 | CCDictionary | ValueMap |
2 | CCArray | ValueVector |
3 | CCString | Value |
CCString 用法改变
之前:
:::C++
CCString* str = CCString::createWithFormat("%s.png","picture");
现在:
:::C++
std::string str = StringUtils::format("%s.png","picture");
CCDictinoary 用法改变
之前:
:::C++
CCDictionary* dict = CCDictionary::createWithContentsOfFile("name.plist");
CCArray* arr = (CCArray*) data->objectForKey("Levels");
现在:
:::C++
std::string path = FileUtils::getInstance()->fullPathForFilename("name.plist");
ValueMap dict = FileUtils::getInstance()->getValueMapFromFile(path);
ValueVector arrLevels = data.at("Levels").asValueVector();
CCArray 用法改变
这里就是 C++ vector 容器的标准用法了。
# | v2 | v3 |
---|---|---|
1 | CCArray* sprites; | Vector<Sprint*> sprites; |
2 | sprites->addObject(sprite); | sprites.pushBack(sprite); |
3 | sprites->removeObject(sprite); | sprites.eraseObject(sprite); |
4 | sprites->removeObjectAtIndex(i); | sprites.erase(i); |
5 | sprites->objectAtIndex(i); | sprites.at(i); |
6 | sprites->count(); | sprites.size(); |
下面这部分内容来自 这里 。
触摸用法改变
# | v2 | v3 |
---|---|---|
1 | ccTouchBegan | onTouchBegan |
2 | ccTouchMoved | onTouchMoved |
3 | ccTouchEnded | onTouchEnded |
单例类用法改变
# | v2 | v3 |
---|---|---|
1 | CCEGLView::sharedOpenGLView(); | Director::getInstance()->getOpenGLView(); |
2 | CCTextureCache::sharedTextureCache(); | Director::getInstance()->getTextureCache(); |
3 | CCNotificationCenter::sharedNotificationCenter(); | Director::getInstance()->getEventDispatcher(); |
CCTime 用法改变
CCTime cocos2d-x v3 中已经被删除了。
# | v2 | v3 |
---|---|---|
1 | cc_timeval | timeval |
2 | CCTime::gettimeofdayCocos2d | gettimeofday |
3 | CCTime::timesubCocos2d | getTimeDiffenceMS |
范例:
:::C++
static inline float getTimeDifferenceMS(timeval& start, timeval& end)
{
return ((((end.tv_sec - start.tv_sec)*1000.0f + end.tv_usec) - start.tv_usec) / 1000.0f);
}
下面的内容为 zrong 原创。
OpenGL 的用法变化
# | v2 | v3 |
---|---|---|
1 | CCGLProgram | GLProgram |
3 | kCCUniformPMatrix_s | GLProgram::UNIFORM_NAME_P_MATRIX |
4 | kCCUniformMVMatrix_s | GLProgram::UNIFORM_NAME_MV_MATRIX |
5 | kCCUniformMVPMatrix_s | GLProgram::UNIFORM_NAME_MVP_MATRIX |
6 | kCCUniformTime_s | GLProgram::UNIFORM_NAME_TIME |
7 | kCCUniformSinTime_s | GLProgram::UNIFORM_NAME_SIN_TIME |
8 | kCCUniformCosTime_s | GLProgram::UNIFORM_NAME_COS_TIME |
9 | kCCUniformRandom01_s | GLProgram::UNIFORM_NAME_RANDOM01 |
10 | kCCUniformSampler_s | GLProgram::UNIFORM_NAME_SAMPLER0 |
11 | kCCUniformAlphaTestValue | GLProgram::UNIFORM_NAME_ALPHA_TEST_VALUE |
12 | kCCAttributeNameColor | GLProgram::ATTRIBUTE_NAME_COLOR |
13 | kCCAttributeNamePosition | GLProgram::ATTRIBUTE_NAME_POSITION |
14 | kCCAttributeNameTexCoord | GLProgram::ATTRIBUTE_NAME_TEX_COORD |
MenuItem 的用法变化
以前我写过一篇 Cocos2d-x中的事件调用方式汇总 ,其中介绍了 cocos2d-x 中的回调函数。而在 v3 版本中,这些回调函数已经完全废弃了。
在 cocos2d-x v3 中,使用的是 C++11 提供的标准的 std::bind 功能来实现回调。
让我们看看 base/ccMacros.h
中的几个宏:
1// new callbacks based on C++11
2#define CC_CALLBACK_0(__selector__,__target__, ...) std::bind(&__selector__,__target__, ##__VA_ARGS__)
3#define CC_CALLBACK_1(__selector__,__target__, ...) std::bind(&__selector__,__target__, std::placeholders::_1, ##__VA_ARGS__)
4#define CC_CALLBACK_2(__selector__,__target__, ...) std::bind(&__selector__,__target__, std::placeholders::_1, std::placeholders::_2, ##__VA_ARGS__)
5#define CC_CALLBACK_3(__selector__,__target__, ...) std::bind(&__selector__,__target__, std::placeholders::_1, std::placeholders::_2, std::placeholders::_3, ##__VA_ARGS__)
所以,对于 cocos2d-x v2 中这样的调用:
1CMenuItemImage *item1 = CCMenuItemImage::create(s_pPathB1, s_pPathB2, this, menu_selector(ActionsDemo::backCallback));
在 cocos2d-x v3 中应该是这样的:
1MenuItemImage *item1 = MenuItemImage::create(s_pPathB1, s_pPathB2, CC_CALLBACK_1(ActionsDemo::backCallback, this));
- 文章ID:2193
- 原文作者:zrong
- 原文链接:https://blog.zengrong.net/post/cocos2d-x-v2-to-v3-mapping-guide/
- 版权声明:本作品采用 署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0) 进行许可,非商业转载请注明出处(原文作者,原文链接),商业转载请联系作者获得授权。