本系列学习教程使用的是cocos2d-x-2.1.4(最新版为3.0alpha0-pre) ,PC开发环境Windows7,C++开发环境VS2010
在这一期中,我们将会学习到一些引擎中非常炫的动作类,它们可不再仅仅是局限在2D画面的动作了,而是一
些3D动作。网格动作类类似于特效,可以实现翻转、抖动、震荡、水波纹等效果。
一、网格动作类
在Cocos2D-X中,网格类的基类CCGridBase有两个子类,即CCGrid3D和CCTiledGrid3D。这两个类的共同点
是,网格的每个子块都可以分离出来。CCGridBase的继承关系如下图所示。
网格没有什么直接应用的场合,只要明白CCGrid3D和CCTiledGrid3D,并且网格动作是基于网格的即可。运行
网格动作的节点好像被分成了大小相同的很多矩形,通过这些矩形的动作形成整体动作,这些矩形就好像形成了一个
矩阵。16 x 12的网格将会运行得非常快,但是效果并不是非常好。32 x 24的网格看起来会非常棒,但是在有些时候
运行起来不会太快。
二、网格动作类的使用
使用网格之前需要取消OpenGL的深度检测,调用如下语句:
CCDirector::sharedDirector()->setDepthTest(false);
网格动作的使用和普通动作一样,可以使用runAction来运行动作,具体动作如下图所示。
注意:在使用网格时,网格动作结束后需要把网格清空,如下代码所示。
void HelloWorld::checkAnim(float dt)
{
CCNode* s2 = getChildByTag(1);
if (s2->numberOfRunningActions() == 0 && s2->getGrid() != NULL)
s2->setGrid(NULL);;
}
三、项目示例
由于网格动作的效果比较多,这里我就以一个比较典型的翻页网格效果进行实战演练。
1、首先新建Cocos2D-X项目,取名为“MyCCGridAction”,然后在HelloWorldScene.h文件中声明成员函数。
void checkAnim(float dt);
2、在HelloWorldScene.cpp文件中的init函数中添加如下所示代码。
bool HelloWorld::init()
{
bool bRet = false;
do
{
CC_BREAK_IF(! CCLayer::init());
//取消深度检测
CCDirector::sharedDirector()->setDepthTest(false);
//获得尺寸大小
CCSize s = CCDirector::sharedDirector()->getWinSize();
//初始化图层的颜色
initWithColor( ccc4(32,128,32,255) );
//建立节点
CCNode* node = CCNode::create();
//开启深度检测
CCDirector::sharedDirector()->setDepthTest(true);
//建立翻页动作
CCActionInterval* pEffect = CCPageTurn3D::create(3, CCSizeMake(15,10));
//执行动作
node->runAction(pEffect);
//添加节点
addChild(node, 0, 1);
//建立背景精灵图片
CCSprite *bg = CCSprite::create("background3.png");
node->addChild(bg, 0);
bg->setPosition(ccp(s.width/2, s.height/2));
//建立人物精灵图片并执行缩放动作
CCSprite* grossini = CCSprite::create("grossinis_sister2.png");
node->addChild(grossini, 1);
grossini->setPosition(ccp(s.width/4, s.height/2));
CCActionInterval* sc = CCScaleBy::create(2, 5);
CCActionInterval* sc_back = sc->reverse();
grossini->runAction( CCRepeatForever::create(CCSequence::create(sc, sc_back, NULL)));
//建立人物精灵图片并执行缩放动作
CCSprite* tamara = CCSprite::create("grossinis_sister1.png");
node->addChild(tamara, 1);
tamara->setPosition(ccp(3 * s.width/4, s.height/2));
CCActionInterval* sc2 = CCScaleBy::create(2, 5);
CCActionInterval* sc2_back = sc2->reverse();
tamara->runAction( CCRepeatForever::create(CCSequence::create(sc2, sc2_back, NULL)) );
//定时更新
schedule(schedule_selector(HelloWorld::checkAnim) );
bRet = true;
} while (0);
return bRet;
}
3、最后在HelloWorldScene.cpp文件中添加checkAnim函数,该函数用于定时清除网格。
void HelloWorld::checkAnim(float dt)
{
CCNode* s2 = getChildByTag(1);
if (s2->numberOfRunningActions() == 0 && s2->getGrid() != NULL)
s2->setGrid(NULL);;
}
四、示例效果图
翻页动作效果图。
源码下载地址
分享到:
相关推荐
资源名称:Cocos2d-x实战:JS卷——Cocos2d-JS开发内容简介:本书是介绍Cocos2d-x游戏编程和开发技术书籍,介绍了使用Cocos2d-JS中核心类、瓦片地图、物理引擎、音乐音效、数据持久化、网络通信、性能优化、多平台...
Cocos2D-X开发学习笔记-动作类之基础动作的使用示例(下) 教程地址:http://blog.csdn.net/yangyu20121224/article/details/9840757
Cocos2D-X开发学习笔记-网格动作类的使用示例 教程地址:http://blog.csdn.net/yangyu20121224/article/details/10011991
Cocos2D-X开发学习笔记-按键事件使用示例 教程地址:http://blog.csdn.net/yangyu20121224/article/details/10040985
《Cocos2D-X游戏开发技术精解》详细介绍如何使用Cocos2D-X引擎开发自己的移动平台游戏。全书共15章,主要内容包括:Cocos2D-X引擎简介;如 资源太大,传百度网盘了,链接在附件中,有需要的同学自取。
Cocos2D-X开发学习笔记-触屏事件使用示例 教程地址:http://blog.csdn.net/yangyu20121224/article/details/10029143
Cocos2D-X开发学习笔记-游戏数据存储项目实例 教程地址:http://blog.csdn.net/yangyu20121224/article/details/10857813
Cocos2D-X开发学习笔记-音乐和音效的使用示例 教程地址:http://blog.csdn.net/yangyu20121224/article/details/10228941
Cocos2d-x是移动跨平台开发最流行的游戏引擎,而本书是一本很全面的、比较‘接地气’的游戏开发教程。书中汇聚了热门手机游戏《捕鱼达人》开发的实战经验,作者从最基础的内容开始,逐步深入地介绍了Cocos2d-x的相关...
Cocos2D-X开发学习笔记-动作管理类的使用示例 教程地址:http://blog.csdn.net/yangyu20121224/article/details/10007849
自己记录的Cocos2d-x学习笔记,希望能够帮助新手,快速入门,掌握cocos2d-x的开发
Cocos2D-X开发学习笔记-时间调度schedule函数的使用 教程地址:http://blog.csdn.net/yangyu20121224/article/details/9749457
Cocos2D-X开发学习笔记-游戏数据存储项目实例(下) 教程地址:http://blog.csdn.net/yangyu20121224/article/details/10946695
在使用cocos2d-x开发游戏的过程中,为了实现逻辑和显示相分离。 在下通宵了一个晚上,写出了该事件类。 谨记,该事件只能用于cocos2d-x中。 事件发送者需要继承EventDispatcher类 事件接收者需要继承EventHandle类...
资源名称:大富翁手机游戏开发实战基于Cocos2d-x3.2引擎内容简介:李德国编著的《大富翁手机游戏开发实战(基于 Cocos2d-x3.2引擎)》使用Cocos2d-x游戏引擎技术,带领读者一步一步从零开始进行大富翁移动游戏的开发...
Cocos2D-X开发学习笔记-动作类之摄像机动作和基本样条动作的使用示例 教程地址:http://blog.csdn.net/yangyu20121224/article/details/9851099
精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发 精通COCOS2D-X游戏开发
Cocos2D-X开发学习笔记-渲染框架之图形的绘制 教程地址:http://blog.csdn.net/yangyu20121224/article/details/9748001
Cocos2D-X开发学习笔记-渲染框架之布景层类的使用示例 教程地址:http://blog.csdn.net/yangyu20121224/article/details/9397075
cocos2d-x-2.1.5