Cocos2d-x开发实例介绍特效演示
下面我们通过一个实例介绍几个特效的使用,这个实例下图所示,下图是一个操作菜单场景,选择菜单可以进入到下图动作场景,在下图动作场景中点击Go按钮可以执行我们选择的特性动作,点击Back按钮可以返回到菜单场景。
下面我们再看看具体的程序代码,首先看一下看HelloWorldScene.h文件,它的代码如下:
- #ifndef __HELLOWORLD_SCENE_H__
- #define __HELLOWORLD_SCENE_H__
- #include "cocos2d.h"
- #include "MyActionScene.h" ①
- typedef enum { ②
- kFlipX3D = 101,
- kPageTurn3D,
- kLens3D,
- kShaky3D,
- kWaves3D,
- kJumpTiles3D,
- kShakyTiles3D,
- kWavesTiles3D
- } ActionTypes; ③
- class HelloWorld : public cocos2d::Layer
- {
- public:
- static cocos2d::Scene* createScene();
- virtual bool init();
- void OnClickMenu(cocos2d::Ref* pSender); ④
- CREATE_FUNC(HelloWorld);
- };
- #endif // __HELLOWORLD_SCENE_H__
上述代码第①行是引入头文件MyActionScene.h。第②~③是定义个枚举类型ActionTypes,枚举类型ActionTypes中定义了8个常量,这8个常量对应8个菜单项。第④行声明了一个函数,用来在选择不同菜单时候的回调。
- 下一个场景MyActionScene的 MyActionScene.h文件的代码如下:
- #ifndef __MYACTION_SCENE_H__
- #define __MYACTION_SCENE_H__
- #include "cocos2d.h"
- #include "HelloWorldScene.h"
- class MyAction : public cocos2d::Layer
- {
- cocos2d::Sprite *sprite; ①
- cocos2d::NodeGrid* gridNodeTarget; ②
- public:
- staticcocos2d::Scene* createScene();
- virtual bool init();
- CREATE_FUNC(MyAction);
- void goMenu(cocos2d::Ref* pSender);
- void backMenu(cocos2d::Ref* pSender);
- };
- #endif // __MYACTION_SCENE_H__
上述代码第①行是声明Sprite类型成员变量sprite。第②行是声明NodeGrid类型成员变量gridNodeTarget,NodeGrid是网格动作管理类,它的类图如下图所示。
MyActionScene.ccp中的MyAction::init()主要代码如下:
- bool MyAction::init()
- {
- if ( !Layer::init() )
- {
- return false;
- }
- Size visibleSize = Director::getInstance()->getVisibleSize();
- gridNodeTarget= NodeGrid::create(); ①
- addChild(gridNodeTarget); ②
- auto bg = Sprite::create("background.png");
- bg->setPosition(Point(visibleSize.width/2,visibleSize.height /2));
- gridNodeTarget->addChild(bg); ③
- sprite = Sprite::create("hero.png");
- sprite->setPosition(Point(visibleSize.width / 2, visibleSize.height /2));
- gridNodeTarget->addChild(sprite); ④
- autobackMenuItem =MenuItemImage::create("back-up.png","back-down.png",
- CC_CALLBACK_1(MyAction::backMenu,this));
- backMenuItem->setPosition(Director::getInstance()->convertToGL(Point(140,65)));
- autogoMenuItem = MenuItemImage::create("go-up.png","go-down.png",
- CC_CALLBACK_1(MyAction::goMenu,this));
- goMenuItem->setPosition(Director::getInstance()->convertToGL(Point(920,540)));
- Menu* mn = Menu::create(backMenuItem, goMenuItem, NULL);
- mn->setPosition(Point::ZERO);
- this->addChild(mn); ⑤
- return true;
- }
上述代码第①行代码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)主要代码如下:
- void MyAction::goMenu(cocos2d::Ref*pSender)
- {
- SizevisibleSize = Director::getInstance()->getVisibleSize();
- log("Tag = %i",this->getTag());
- switch (this->getTag()) {
- casekFlipX3D:
- gridNodeTarget->runAction(FlipX3D::create(3.0f)); ①
- break;
- casekPageTurn3D:
- gridNodeTarget->runAction(PageTurn3D::create(3.0f,Size(15,10))); ②
- break;
- casekLens3D:
- gridNodeTarget->runAction(Lens3D::create(3.0f, Size(15,10),
- Point(visibleSize.width/2,visibleSize.height/2),240)); ③
- break;
- casekShaky3D:
- gridNodeTarget->runAction(Shaky3D::create(3.0f, Size(15,10), 5,false)); ④
- break;
- casekWaves3D:
- gridNodeTarget->runAction(Waves3D::create(3.0f, Size(15,10), 5, 40)); ⑤
- break;
- casekJumpTiles3D:
- gridNodeTarget->runAction(JumpTiles3D::create(3.0f, Size(15,10), 2,30)); ⑥
- break;
- casekShakyTiles3D:
- gridNodeTarget->runAction(ShakyTiles3D::create(3.0f, Size(16,12), 5,false)); ⑦
- break;
- casekWavesTiles3D:
- gridNodeTarget->runAction(CCWavesTiles3D::create(3.0f,Size(15,10), 4, 120)); ⑧
- break;
- }
- }
在上述代码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开发实例介绍帧动画使用
下面我们通过一个实例介绍一下帧动画的使用,这个实例如下图所示,点击Go按钮开始播放动画,这时候播放按钮标题变为Stop,点击Stop按钮可以停止播放动画. 下面我们再看看具体的程序代码,首先看一下看H ...
- Cocos2d-x Lua中实例:特效演示
下面我们通过一个实例介绍几个特效的使用,这个实例如下图所示,上图是一个操作菜单场景,选择菜单可以进入到下图动作场景,在下图动作场景中点击Go按钮可以执行我们选择的特性动作,点击Back按钮可以返回到菜 ...
- 《HTML 5网页开发实例具体解释》样章、内容简单介绍、前言
http://spu.jd.com/1167757597.html http://product.dangdang.com/23484942.html 样章 http://download.csdn. ...
- Django 小实例S1 简易学生选课管理系统 0 初步介绍与演示
Django 小实例S1 简易学生选课管理系统 第0章--初步介绍与演示 点击查看教程总目录 作者自我介绍:b站小UP主,时常直播编程+红警三,python1对1辅导老师. 1 初步介绍 先介绍下这个 ...
- STC8H开发(三): 基于FwLib_STC8的模数转换ADC介绍和演示用例说明
目录 STC8H开发(一): 在Keil5中配置和使用FwLib_STC8封装库(图文详解) STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解) ST ...
- 《HTML 5网页开发实例具体解释》文件夹
第一篇 从宏观上认识HTML 5 讲述了HTML 5引发的Web革命.HTML 5的总体特性.HTML 5相关概念和框架和开发环境搭建. 第1章 HTML 5引发的Web革命 1.1 你是不是真的 ...
- Cocos2d-x 3.X手游开发实例详解
Cocos2d-x 3.X手游开发实例详解(最新最简Cocos2d-x手机游戏开发学习方法,以热门游戏2048.卡牌为例,完整再现手游的开发过程,实例丰富,代码完备,Cocos2d-x作者之一林顺和泰 ...
- 免费的HTML5连载来了《HTML5网页开发实例详解》连载(五)图解通过Fiddler加速开发
Fiddler是Windows底下最强大的请求代理调试工具,监控任何浏览器的HTTP/HTTPS流量,窜改客户端请求和服务器响应,解密HTTPS Web会话,图4.44为Fiddler原理示意图. 图 ...
- android widget 开发实例 : 桌面便签程序的实现具体解释和源代码 (上)
如有错漏请不吝拍砖指正,转载请注明出处,很感谢 桌面便签软件是android上经常使用软件的一种,比方比較早的Sticky Note,就曾很流行, Sticky Note的介绍能够參见 http:// ...
随机推荐
- 简谈java的split
最近都在处理视频音频,今天在合成音频视频时为了给合成的新文件换个新名字,我打算获取了之前的视频名称,用split来分割出不带后缀的名字,再自己加上后缀. 众所周知split可以分割由某种字符分段的St ...
- 窗体 dialog 弹出时动画效果
1.先创建 anim中的 xml 动画文件 <?xml version="1.0" encoding="utf-8"? > <set x ...
- SAP BW 例程(Routine)【开始例程、关键值或特性的例程、结束例程】
定义 可以使用例程定义关键值或特性的复杂的转换规则. 例程是本地 ABAP 类,它们包括预定义的定义和实施范围.进站和出站参数的 TYPES及方法签名都存储在定义范围中.实际例程创建于实施范围中.使用 ...
- hdu 5586 Sum 最大子段和
Sum Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5586 Desc ...
- C# 利用范型与扩展方法重构代码
在一些C#代码中常常可以看到 //An Simple Example By Ray Linn class CarCollection :ICollection { IList list; public ...
- Meteor 加入账户系统
Meteor 加入账户系统 我们给meteor加入一个账户系统 导入包 meteor add ian:accounts-ui-bootstrap-3 meteor add accounts-passw ...
- Open gl 的不规则图形的4联通种子递归填充和扫描线种子递归填充算法实现
实验题目:不规则区域的填充算法 实验目的:验证不规则区域的填充算法 实验内容:利用VC与OpenGL,实现不规则区域的填充算法. 1.必做:实现简单递归的不规则区域填充算法. 2.选做:针对简单递归算 ...
- iOS开发——UI_swift篇&TableView实现页眉和页脚
TableView实现页眉和页脚 在UItableView中header和footer是很常见的,而且他能让你实现很复杂的功能,我们见过最多的就是下拉刷新和上啦加载更多,当然你还可以在上面添加一个 ...
- mysql --The MEMORY Storage Engine--官方文档
原文地址:http://dev.mysql.com/doc/refman/5.7/en/memory-storage-engine.html The MEMORY storage engine (fo ...
- Eclipse常用快捷键集合
一.通用快捷键 [ALT+/] 此快捷键为用户编辑的神级好帮手,能为用户提供内容的辅助,不要为记不全方法和属性名称犯愁下 [Ctrl+T] 搜索当前接口的实现类 [Ctrl+O] 显示类中方法和 ...