您的位置:首页 > 移动开发 > Cocos引擎

地球人己阻止不了程序猿们学习cocos2d-x了-学习笔记01

2012-10-10 09:14 369 查看
地球人己阻止不了程序猿们学习cocos2d-x了是一个很不错的系列教程(其实我还没看完= =),但是我基础不好,作者基础太雄厚,他很多觉得简单的东西都没有解释,所以我看了又忘,忘了就...又看。

于是我还是决定要记录下来,方便忘记的时候查看。

地球人己阻止不了程序猿们学习cocos2d-x了 (第一篇)

——木头学习笔记

1. 关于单例类


Cocos2d-x(以后简称cs-x)有不少单例类,比如获取导演类:

CCSize size = CCDirector::sharedDirector()->getWinSize();
上面的语句是获取屏幕大小的对象,因为屏幕是受导演控制的,所以通过导演来获取屏幕大小。而获取导演的方式是sharedDirector,在cs-x中,通常都是通过shared***方法来获取某个类的单例。

2. 创建最简单的精灵

cs-x中要创建一个精灵,很简单(别人帮你封装好了,你当然简单,噗~)

CCSprite* pSprite = CCSprite::spriteWithFile("Background.png");
顺便一提,spriteWithFile是静态方法。

spriteWithFile,顾名思义,就是直接通过一张图片来创建一个精灵。

噗,再顺便一提,这个精灵不会动(只有一张图片,于是当然不会动= =)

3. 使用TexturePacker组合图片,节省空间和内存

TexturePacker可以为cs-x生成两个文件:*.plist和*.png,cs-x已经写了专门的类去处理了。

看看下面的代码:

CCSpriteFrameCache *cache = CCSpriteFrameCache::sharedSpriteFrameCache();
cache->addSpriteFramesWithFile("images.plist", "images.png");
看看,shared*函数又出现了,证明了CCSpriteFrameCache是一个单例类,就我现在所知,它是CCSpriteFrame缓存池,至于CCSpriteFrame是什么,我现在还不太清楚。

然后用addSpriteFramesWithFile方法把images.png图片里的所有小图片生成对应的

CCSpriteFrame对象,存放到缓存池里。

4. 从CCSpriteFrameCache缓存池里取得CCSpriteFrame创建精灵对象

CCSprite* pSprite = CCSprite::spriteWithSpriteFrameName("Background.png");
之前的spriteWithFile改成了spriteWithSpriteFrameName,顾名思义,这次是通过CCSpriteFrame对象来创建一个CCSprite精灵对象。

通过小图片的名称在CCSpriteFrameCache缓存池里取得CCSpriteFrame对象,再把这个CCSpriteFrame对象赋给CCSprite。

5. CCSpriteBatchNode,减少glDrawArray的次数(批次渲染)

文中说,“我们已经逹到了节省内存减少纹理切换,
最後一个我们想做的优化是减少 glDrawArray
的次数
,
而我们所运用的技巧,
就是批次渲染(Batch Rendering),
cocos2d 提供了CCSpriteBatchNode
来方便大家做有关的处理, CCSpriteBatchNode
里的CCSprite
都是要用同一个纹理的,
所以我们在建立一个 CCSpriteBatchNode
是要给它一个纹理,
再把它加到 Layer
里”。

批次渲染是什么东西?好像是3D里面的知识,百度了一会,我现在还无法理解。

使用批次渲染很简单,先利用组合的图片去生成一个CCTexture2D对象,再利用这个

Texture2D对象生成CCSpriteBatchNode对象:

CCTexture2D *texture = CCTextureCache::sharedTextureCache()->textureForKey("images.png");
CCSpriteBatchNode *spriteBatch = CCSpriteBatchNode::batchNodeWithTexture(texture);
addChild(spriteBatch);
然后还是用spriteWithSpriteFrameName方法生成CCSprite对象,但是,要注意,

CCSpriteBatchNode对象已经添加到场景中了,所以对使用同一个纹理(我也不知道什么

是使用同一个纹理,总之,在同一张大图里的小图片就是同一个纹理了)的精灵对象,直接添加到CCSpriteBatchNode对象中,而不是添加到场景中。

更完整的流程:

CCTexture2D *texture = CCTextureCache::sharedTextureCache()->textureForKey("images.png");
CCSpriteBatchNode *spriteBatch = CCSpriteBatchNode::batchNodeWithTexture(texture);
addChild(spriteBatch);
CCSprite* pSprite = CCSprite::spriteWithSpriteFrameName("Background.png");
spriteBatch->addChild(pSprite, 0);
OK,第一篇的主要学习内容就是这样了,真心感谢原文的作者,作者太强了,我的基础不够,所以很多地方看不懂,只好看一点记录一点,哪天忘了,也好回忆起来。

原文详细教程地址:

http://cn.cocos2d-x.org/bbs/forum.php?mod=viewthread&tid=775&fromuid=5297
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: