下面我们通过一个实例介绍几个特效的使用,这个实例下图所示,下图是一个操作菜单场景,选择菜单可以进入到下图动作场景,在下图动作场景中点击Go按钮可以执行我们选择的特性动作,点击Back按钮可以返回到菜单场景。

下面我们再看看具体的程序代码,首先看一下看HelloWorldScene.h文件,它的代码如下:

  1. #ifndef __HELLOWORLD_SCENE_H__
  2. #define __HELLOWORLD_SCENE_H__
  3. #include "cocos2d.h"
  4. #include "MyActionScene.h"                                                                                                                ①
  5. typedef enum {                                                                                                                             ②
  6. kFlipX3D = 101,
  7. kPageTurn3D,
  8. kLens3D,
  9. kShaky3D,
  10. kWaves3D,
  11. kJumpTiles3D,
  12. kShakyTiles3D,
  13. kWavesTiles3D
  14. } ActionTypes;                                                                                                                             ③
  15. class HelloWorld : public cocos2d::Layer
  16. {
  17. public:
  18. static cocos2d::Scene* createScene();
  19. virtual bool init();
  20. void OnClickMenu(cocos2d::Ref* pSender);                                                                    ④
  21. CREATE_FUNC(HelloWorld);
  22. };
  23. #endif // __HELLOWORLD_SCENE_H__

上述代码第①行是引入头文件MyActionScene.h。第②~③是定义个枚举类型ActionTypes,枚举类型ActionTypes中定义了8个常量,这8个常量对应8个菜单项。第④行声明了一个函数,用来在选择不同菜单时候的回调。

  1. 下一个场景MyActionScene的 MyActionScene.h文件的代码如下:
  2. #ifndef __MYACTION_SCENE_H__
  3. #define __MYACTION_SCENE_H__
  4. #include "cocos2d.h"
  5. #include "HelloWorldScene.h"
  6. class MyAction : public cocos2d::Layer
  7. {
  8. cocos2d::Sprite *sprite;                                                                                                        ①
  9. cocos2d::NodeGrid* gridNodeTarget;                                                                                         ②
  10. public:
  11. staticcocos2d::Scene* createScene();
  12. virtual bool init();
  13. CREATE_FUNC(MyAction);
  14. void goMenu(cocos2d::Ref* pSender);
  15. void backMenu(cocos2d::Ref* pSender);
  16. };
  17. #endif // __MYACTION_SCENE_H__

上述代码第①行是声明Sprite类型成员变量sprite。第②行是声明NodeGrid类型成员变量gridNodeTarget,NodeGrid是网格动作管理类,它的类图如下图所示。

MyActionScene.ccp中的MyAction::init()主要代码如下:

  1. bool MyAction::init()
  2. {
  3. if ( !Layer::init() )
  4. {
  5. return false;
  6. }
  7. Size visibleSize = Director::getInstance()->getVisibleSize();
  8. gridNodeTarget= NodeGrid::create();                                                                              ①
  9. addChild(gridNodeTarget);                                                                                                 ②
  10. auto bg = Sprite::create("background.png");
  11. bg->setPosition(Point(visibleSize.width/2,visibleSize.height /2));
  12. gridNodeTarget->addChild(bg);                                                                                                     ③
  13. sprite = Sprite::create("hero.png");
  14. sprite->setPosition(Point(visibleSize.width / 2, visibleSize.height /2));
  15. gridNodeTarget->addChild(sprite);                                                                                             ④
  16. autobackMenuItem =MenuItemImage::create("back-up.png","back-down.png",
  17. CC_CALLBACK_1(MyAction::backMenu,this));
  18. backMenuItem->setPosition(Director::getInstance()->convertToGL(Point(140,65)));
  19. autogoMenuItem = MenuItemImage::create("go-up.png","go-down.png",
  20. CC_CALLBACK_1(MyAction::goMenu,this));
  21. goMenuItem->setPosition(Director::getInstance()->convertToGL(Point(920,540)));
  22. Menu* mn = Menu::create(backMenuItem, goMenuItem, NULL);
  23. mn->setPosition(Point::ZERO);
  24. this->addChild(mn);                                                                                                                       ⑤
  25. return true;
  26. }

上述代码第①行代码NodeGrid::create()创建NodeGrid对象,第②行代码需要将创建的NodeGrid对象gridNodeTarget添加到当前层中。第③行代码gridNodeTarget->addChild(bg)是将创建的bg背景精灵对象添加到gridNodeTarget,这样才能使得特效作用于背景精灵。第④行代码gridNodeTarget->addChild(sprite)也是将创建的精灵对象sprite添加到gridNodeTarget中,这样才能使得特效作用于精灵。

由于我们不想使特效作用于菜单,所以在第⑤行代码使用的this->addChild(mn),而不是gridNodeTarget->addChild(mn)。

MyActionScene.ccp中的MyAction::goMenu(cocos2d::Ref*pSender)主要代码如下:

  1. void MyAction::goMenu(cocos2d::Ref*pSender)
  2. {
  3. SizevisibleSize = Director::getInstance()->getVisibleSize();
  4. log("Tag = %i",this->getTag());
  5. switch (this->getTag()) {
  6. casekFlipX3D:
  7. gridNodeTarget->runAction(FlipX3D::create(3.0f));                                                      ①
  8. break;
  9. casekPageTurn3D:
  10. gridNodeTarget->runAction(PageTurn3D::create(3.0f,Size(15,10)));                          ②
  11. break;
  12. casekLens3D:
  13. gridNodeTarget->runAction(Lens3D::create(3.0f, Size(15,10),
  14. Point(visibleSize.width/2,visibleSize.height/2),240));                       ③
  15. break;
  16. casekShaky3D:
  17. gridNodeTarget->runAction(Shaky3D::create(3.0f, Size(15,10), 5,false));                  ④
  18. break;
  19. casekWaves3D:
  20. gridNodeTarget->runAction(Waves3D::create(3.0f, Size(15,10), 5, 40));            ⑤
  21. break;
  22. casekJumpTiles3D:
  23. gridNodeTarget->runAction(JumpTiles3D::create(3.0f, Size(15,10), 2,30));              ⑥
  24. break;
  25. casekShakyTiles3D:
  26. gridNodeTarget->runAction(ShakyTiles3D::create(3.0f, Size(16,12), 5,false));         ⑦
  27. break;
  28. casekWavesTiles3D:
  29. gridNodeTarget->runAction(CCWavesTiles3D::create(3.0f,Size(15,10), 4, 120));     ⑧
  30. break;
  31. }
  32. }

在上述代码goMenu函数中是运行特效动作,第①行是使用FlipX3D实现X轴3D翻转特效,create函数的参数是持续时间。

第②行是使用PageTurn3D实现翻页特效特效,create函数的第一个参数是持续时间,第二个参数是网格的大小。

第③行是使用Lens3D实现凸透镜特效,create函数第一个参数透镜中心点,第二个参数是透镜半径,第三个参数网格大小,第四个参数是持续时间。

第④行是使用Shaky3D实现晃动特效,create函数第一个参数是持续时间,第二个参数是网格的大小,第三个参数晃动的范围,第四个参数是否伴有Z轴晃动。

第⑤行是使用Waves3D实现3D波动特效,create函数第一个参数是持续时间,第二个参数是网格的大小,第三个参数波动次数,第四个参数是振幅。

第⑥行是使用JumpTiles3D实现晃动特效,3D瓦片跳动特效,create函数第一个参数是持续时间,第二个参数是网格的大小,第三个参数跳动次数,第四个参数是跳动幅度。

第⑦行是使用ShakyTiles3D实现3D瓦片晃动特效,create函数第一个参数是持续时间,第二个参数是网格的大小,第三个参数晃动的范围,第四个参数是否伴有Z轴晃动。

第⑧行是使用WavesTiles3D实现3D瓦片波动特效,create函数第一个参数是持续时间,第二个参数是网格的大小,第三个参数动次数,第四个参数是振幅。

更多内容请关注Cocos2d-x系列图书《Cocos2d-x实战(卷Ⅰ):C++开发》
本书交流讨论网站:http://www.cocoagame.net
欢迎加入cocos2d-x技术讨论群:257760386、327403678

Cocos2d-x开发实例介绍特效演示的更多相关文章

  1. Cocos2d-x开发实例介绍帧动画使用

    下面我们通过一个实例介绍一下帧动画的使用,这个实例如下图所示,点击Go按钮开始播放动画,这时候播放按钮标题变为Stop,点击Stop按钮可以停止播放动画. 下面我们再看看具体的程序代码,首先看一下看H ...

  2. Cocos2d-x Lua中实例:特效演示

    下面我们通过一个实例介绍几个特效的使用,这个实例如下图所示,上图是一个操作菜单场景,选择菜单可以进入到下图动作场景,在下图动作场景中点击Go按钮可以执行我们选择的特性动作,点击Back按钮可以返回到菜 ...

  3. 《HTML 5网页开发实例具体解释》样章、内容简单介绍、前言

    http://spu.jd.com/1167757597.html http://product.dangdang.com/23484942.html 样章 http://download.csdn. ...

  4. Django 小实例S1 简易学生选课管理系统 0 初步介绍与演示

    Django 小实例S1 简易学生选课管理系统 第0章--初步介绍与演示 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 1 初步介绍 先介绍下这个 ...

  5. STC8H开发(三): 基于FwLib_STC8的模数转换ADC介绍和演示用例说明

    目录 STC8H开发(一): 在Keil5中配置和使用FwLib_STC8封装库(图文详解) STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解) ST ...

  6. 《HTML 5网页开发实例具体解释》文件夹

    第一篇  从宏观上认识HTML 5 讲述了HTML 5引发的Web革命.HTML 5的总体特性.HTML 5相关概念和框架和开发环境搭建. 第1章 HTML 5引发的Web革命 1.1  你是不是真的 ...

  7. Cocos2d-x 3.X手游开发实例详解

    Cocos2d-x 3.X手游开发实例详解(最新最简Cocos2d-x手机游戏开发学习方法,以热门游戏2048.卡牌为例,完整再现手游的开发过程,实例丰富,代码完备,Cocos2d-x作者之一林顺和泰 ...

  8. 免费的HTML5连载来了《HTML5网页开发实例详解》连载(五)图解通过Fiddler加速开发

    Fiddler是Windows底下最强大的请求代理调试工具,监控任何浏览器的HTTP/HTTPS流量,窜改客户端请求和服务器响应,解密HTTPS Web会话,图4.44为Fiddler原理示意图. 图 ...

  9. android widget 开发实例 : 桌面便签程序的实现具体解释和源代码 (上)

    如有错漏请不吝拍砖指正,转载请注明出处,很感谢 桌面便签软件是android上经常使用软件的一种,比方比較早的Sticky Note,就曾很流行, Sticky Note的介绍能够參见 http:// ...

随机推荐

  1. PL/pgSQL的RETURN QUERY例子

    我的例子: 数据准备: create table custinfo(custid integer,callingcnt integer); ,),(,),(,); 函数生成: CREATE OR RE ...

  2. 【M8】了解各种不同意义的new和delete

    1.首先考虑new operator,new operator 可以认为做了三件事情:a.调用operator new分配一块内存:b.在这块内存上调用构造方法构造对象:返回指针. 2.operato ...

  3. php openssl 生成公私钥,根据网上文章整理的

    linux下没有问题,win下有报错 <?php$configargs = array("config" => "/usr/local/php/ext/ope ...

  4. Cache选型的一些思考

    Cache对于减轻DB负载有非常关键的数据.以下对经常使用的memcached和redis做个总结,便于技术选型. 1 memcached  (1) 支持的操作有限,支持经常使用的set,get,de ...

  5. C++中的inline函数

    内联函数: () 内联函数定义和作用: 将一个函数声明为inline,那么函数就成为内联函数.内联函数通常就是它在程序中每个调用点上“内联地”展开.从定义上看,内联函数跟一般函数不一样,一般函数调用的 ...

  6. Xtrabackup每周增量备份脚本程序

    Xtrabackup每周增量备份脚本程序(含附件)   程序描述 本程序是一个对percona xtrabackup使用的脚本,它完成了MySQL每周的备份. 程序结构 此程序包含了4个目录(bin. ...

  7. centosx64位寄存器

    [root@monitor ~]# uname -aLinux monitor 2.6.32-431.23.3.el6.x86_64 #1 SMP Thu Jul 31 17:20:51 UTC 20 ...

  8. php技术概要汇总

    php搜索-> sphinx     coreseek : 中文分词.中文搜索     samba  :把linux服务器端目录映射的本地. 视频截图插件.音频视频转换(ffmpeg): 1)w ...

  9. win7引导项顺序

    转载:http://jingyan.baidu.com/article/72ee561aa1d123e16138df81.html 问题描述: 个人在宿舍使用的比较多的是Window 7,而它的启动项 ...

  10. visual studio 2013 c++ 打开code map 功能

    属性->c++ -> Browse Infomation -> Enable Browse Infomation设为true http://msdn.microsoft.com/li ...