`

Cocos2d-JS特效

阅读更多

Cocos2d-JS提供了很多特效,这些特效事实上属于间隔动作,特效类cc.GridAction类,也称为网格动作,它的类图如下图所示。

网格动作类图

网格动作
cc.GridAction它有两个主要的子类cc.Grid3DAction和cc.TiledGrid3DAction,cc.TiledGrid3DAction系列的子类中会有瓦片效果,如下图所示是Waves3D特效(cc.Grid3DAction子类),如后图所示是WavesTiles3D特效(cc.TiledGrid3DAction子类),比较这两个效果我们会看到瓦片效果的特别之处是界面被分割成多个方格。

Waves3D特效

 

WavesTiles3D特效


网格动作都是采用3D效果给用户的体验是非常震撼和绚丽,但是也给内存和CPU造成了巨大的压力和负担,如果不启用Open GL的深度缓冲,3D效果就会失真,但是启用的话对于显示性能会造成负面影响。
实例:特效演示
下面我们通过一个实例介绍几个特效的使用,这个实例如下图所示,上图是一个操作菜单场景,选择菜单可以进入到下图动作场景,在下图动作场景中点击Go按钮可以执行我们选择的特性动作,点击Back按钮可以返回到菜单场景。

特效实例

MyActionScene.js中的ctor构造函数代码如下: 
  

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. ctor: function (flagTag) {  
  2.        this._super();  
  3.        this.flagTag = flagTag;  
  4.        this.gridNodeTarget = cc.NodeGrid.create();                              ①  
  5.        this.addChild(this.gridNodeTarget);  
  6.   
  7.   
  8.        cc.log("MyActionLayer init flagTag " + this.flagTag);  
  9.   
  10.   
  11.        var size = cc.director.getWinSize();  
  12.   
  13.   
  14.        var bg = new cc.Sprite(res.Background_png);  
  15.        bg.x = size.width / 2;  
  16.        bg.y = size.height / 2;  
  17.        this.gridNodeTarget.addChild(bg);  
  18.   
  19.   
  20.        var sprite = new cc.Sprite(res.hero_png);  
  21.        sprite.x = size.width / 2;  
  22.        sprite.y = size.height / 2;  
  23.        this.gridNodeTarget.addChild(sprite, 1, SP_TAG);  
  24.   
  25.   
  26.        var backMenuItem = new cc.MenuItemImage(res.Back_up_png, res.Back_down_png,  
  27.            function () {  
  28.                cc.director.popScene();  
  29.            }, this);  
  30.        backMenuItem.x = 140;  
  31.        backMenuItem.y = size.height - 65;  
  32.   
  33.   
  34.        var goMenuItem = new cc.MenuItemImage(res.Go_up_png, res.Go_down_png,  
  35.            this.onMenuCallback, this);  
  36.        goMenuItem.x = 820;  
  37.        goMenuItem.y = size.height - 540;  
  38.   
  39.   
  40.        var mn = new cc.Menu(backMenuItem, goMenuItem);  
  41.        this.gridNodeTarget.addChild(mn, 1);  
  42.        mn.x = 0;  
  43.        mn.y = 0;  
  44.        mn.anchorX = 0.5;  
  45.        mn.anchorY = 0.5;  
  46.   
  47.   
  48.        return true;  
  49.    }  

上述代码第①行是创建NodeGrid类型成员变量gridNodeTarget,NodeGrid是网格动作管理类。MyActionScene.js中的onMenuCallback函数代码如下: 
   

[html] view plaincopy在CODE上查看代码片派生到我的代码片
 
  1. onMenuCallback: function (sender) {  
  2.        cc.log("Tag = " + this.flagTag);  
  3.        var size = cc.director.getWinSize();  
  4.   
  5.   
  6.        switch (this.flagTag) {  
  7.            case ActionTypes.kFlipX3D:  
  8.                this.gridNodeTarget.runAction(cc.flipX3D(3.0));                  ①  
  9.                break;  
  10.            case ActionTypes.kPageTurn3D:  
  11.                this.gridNodeTarget.runAction(cc.pageTurn3D(3.0, cc.size(15, 10)));      ②  
  12.                break;  
  13.            case ActionTypes.kLens3D:  
  14.                this.gridNodeTarget.runAction(cc.lens3D(3.0, cc.size(15, 10),   
  15.                                         cc.p(size.width / 2, size.height / 2), 240));       ③  
  16.                break;  
  17.            case ActionTypes.kShaky3D:  
  18.                this.gridNodeTarget.runAction(cc.shaky3D(3.0, cc.size(15, 10), 5, false));   ④  
  19.                break;  
  20.            case ActionTypes.kWaves3D:  
  21.                this.gridNodeTarget.runAction(cc.waves3D(3.0, cc.size(15, 10), 5, 40));  ⑤  
  22.                break;  
  23.            case ActionTypes.kJumpTiles3D:  
  24.                this.gridNodeTarget.runAction(cc.jumpTiles3D(3.0, cc.size(15, 10), 2, 30));  ⑥  
  25.                break;  
  26.            case ActionTypes.kShakyTiles3D:  
  27.                this.gridNodeTarget.runAction(cc.shakyTiles3D(3.0, cc.size(16, 12), 5, false));⑦  
  28.                break;  
  29.            case ActionTypes.kWavesTiles3D:  
  30.                this.gridNodeTarget.runAction(cc.wavesTiles3D(3.0, cc.size(15, 10), 4, 120));    ⑧  
  31.                break;  
  32.        }  
  33.    }  



上述代码onMenuCallback函数中是运行特效动作,第①行是使用FlipX3D实现X轴3D翻转特效,cc.flipX3D函数的参数是持续时间。
第②行是使用PageTurn3D实现翻页特效特效,cc.pageTurn3D函数的第一个参数是持续时间,第二个参数是网格的大小。
第③行是使用Lens3D实现凸透镜特效,cc.lens3D函数第一个参数是持续时间,第二个参数是网格大小,第三个参数网透镜中心点,第四个参数是透镜半径。
第④行是使用Shaky3D实现晃动特效,cc.shaky3D函数第一个参数是持续时间,第二个参数是网格的大小,第三个参数晃动的范围,第四个参数是否伴有Z轴晃动。
第⑤行是使用Waves3D实现3D波动特效,cc.waves3D函数第一个参数是持续时间,第二个参数是网格的大小,第三个参数波动次数,第四个参数是振幅。
第⑥行是使用JumpTiles3D实现晃动特效,3D瓦片跳动特效,cc.jumpTiles3D函数第一个参数是持续时间,第二个参数是网格的大小,第三个参数跳动次数,第四个参数是跳动幅度。
第⑦行是使用ShakyTiles3D实现3D瓦片晃动特效,cc.shakyTiles3D函数第一个参数是持续时间,第二个参数是网格的大小,第三个参数晃动的范围,第四个参数是否伴有Z轴晃动。

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

 

 

更多内容请关注最新Cocos图书《Cocos2d-x实战:JS卷——Cocos2d-JS开发

本书交流讨论网站:http://www.cocoagame.net

欢迎加入Cocos2d-x技术讨论群:257760386

更多精彩视频课程请关注智捷课堂Cocos课程:http://v.51work6.com

 

《Cocos2d-x实战 JS卷》现已上线,各大商店均已开售:

京东:http://item.jd.com/11659698.html

欢迎关注智捷iOS课堂微信公共平台,了解最新技术文章、图书、教程信息

分享到:
评论

相关推荐

    Cocos2d-JS游戏开发

    Cocos2d-JS是一款强大的2D游戏开发框架,它结合了JavaScript的灵活性与Cocos2d-x的高效性能,让开发者能够轻松地创建跨平台的游戏。本篇将深入探讨Cocos2d-JS的游戏开发知识,从基础到进阶,帮助你掌握这一利器。 ...

    Cocos2d-JS开发之旅 从HTML 5到原生手机游戏 PDF 带书签目录 完整版

    书中的内容可能涵盖了Cocos2d-JS的安装配置、基本语法、游戏对象的创建与管理、物理引擎的应用、动画与特效的实现、用户输入处理、网络通信、存储机制以及性能优化等方面。此外,还会讲解如何打包发布游戏,如何调试...

    Cocos2d-js项目教程和Cocos2d-JS开发之旅 从HTML 5到原生手机游戏 PDF 带书签目录 完整版

    Cocos2d-js的核心特性包括一个强大的场景管理器、动画系统、物理引擎支持、粒子系统、动作和特效、触摸事件处理、以及性能优化工具等。这些特性使得开发者能够构建功能丰富的游戏和交互式应用。在HTML5环境下,Cocos...

    cocos2d-x-3.1.zip

    2. **C++基础**:Cocos2d-x主要采用C++作为编程语言,同时也支持Lua和JavaScript,但3.1版本主要集中在C++上,这需要开发者具备一定的C++基础。 3. **渲染引擎**:Cocos2d-x 3.1包含了强大的2D渲染引擎,能够处理...

    cocos2d-x-3.13.1.zip

    《cocos2d-x 3.13.1:深入解析与应用》 cocos2d-x 是一个开源的游戏开发框架,广泛应用于跨平台2D游戏的开发,支持iOS、Android、Windows等操作系统。它的3.13.1版本是一个重要的里程碑,提供了诸多改进和优化,...

    cocos2d-x 案例开发大全 第二章(源码)

    7. **脚本支持**:除了C++,cocos2d-x还支持JavaScript和Lua脚本语言,提供更灵活的开发方式。在源码中,你可以看到如何通过脚本控制游戏逻辑。 8. **事件处理(Event Handling)**:cocos2d-x的事件模型允许开发者...

    Cocos2d-JS中使用Cocos Studio资源05:帧动画

    - Cocos2d-JS 是一个跨平台的游戏开发框架,它结合了Cocos2d-x的性能和JavaScript的易用性,支持Web、iOS和Android等多个平台。 - Cocos Studio是Cocos2d系列的一个图形化编辑工具,提供了一整套UI设计、资源管理...

    Cocos2d-Android架包

    7. **粒子系统**: Cocos2d-Android内置的粒子系统允许开发者创建各种视觉特效,如火焰、烟雾、爆炸等,增加游戏的视觉吸引力。 8. **动画系统**: 引擎提供动画处理工具,可以创建角色行走、攻击、死亡等动作,使...

    仿_放开那三国cocos2d-x源码.zip

    《放开那三国》是一款深受玩家喜爱的三国题材卡牌手游,其基于Cocos2d-x游戏引擎进行开发。Cocos2d-x是一个开源的游戏开发框架,广泛用于2D游戏、教育应用、演示程序等,支持多平台,包括iOS、Android、Windows ...

    Cocos2d-x游戏引擎实战开发炸弹超人

    5. **动画制作**:创建角色和特效的动画序列,利用Cocos2d-x的动画系统。 6. **游戏状态管理**:实现游戏的开始、暂停、结束等状态切换,以及存档和读档功能。 通过这个实战项目,你不仅可以掌握Cocos2d-x的基本...

    cocos2d-x权威指南源代码

    cocos2d-x是基于cocos2d的扩展,它用C++编写,同时提供了Lua和JavaScript的绑定,使得开发者可以选择自己熟悉的语言进行游戏逻辑的编写。cocos2d-x的核心功能包括精灵(Sprite)管理、场景(Scene)切换、动作...

    精通COCOS2D-X游戏开发进阶卷

    5. **动作和特效**:Cocos2d-x提供了一系列的动作和特效类,如旋转、缩放、透明度变化等,可以方便地创建出丰富的游戏动态效果。 6. **事件处理**:游戏中的触摸事件、键盘事件和物理碰撞事件都可以通过Cocos2d-x的...

    Cocos2d-x win7 + vs2010 配置图文详解

    - 同样方式测试内置的“test”项目,体验Cocos2d-x提供的各种特效和功能。 #### 四、安装VC模板 1. **安装模板:** - 打开解压文件夹中的“template”文件夹,找到“InstallWizardForVS2010.js”文件(适用于VS2010)...

    cocos2d-js离线API

    Cocos2d-js的ParticleSystem类提供了一种创建粒子效果的方法,如火焰、烟雾、雪花等,可以轻松调整粒子的生命周期、速度、颜色等属性,创建出各种视觉特效。 六、音频与音乐 Cocos2d-js支持音频播放,包括背景音乐...

    Cocos2d-x 三消游戏源码

    9. **脚本系统(Lua或JS Bindings)**:虽然源码是C++实现,但Cocos2d-x支持Lua和JavaScript绑定,方便快速开发和调试。 10. **数据结构与算法**:三消游戏的核心在于匹配算法,如何高效地查找并消除同色元素,这...

    cocos2d-x游戏源码横版游戏源码仙落凡尘

    游戏源码中包含了大量的图像资源,这些图片资源是构建游戏场景、角色、特效等视觉元素的基础,通过解析这些资源,我们可以了解如何在cocos2d-x中加载和管理图片资源,以及如何实现动态动画效果。 在cocos2d-x中,...

    cocos2d-android-1资源:API文档

    Cocos2d基于Python,但也有多个语言版本,如cocos2d-x支持C++,cocos2d-js支持JavaScript,以及cocos2d-java针对Android平台。它提供了丰富的功能,包括场景管理、动作与特效、物理引擎、精灵与图块地图、触摸事件...

    Cocos2d-Android-1游戏开发

    Cocos2d-x是一个开源、跨平台的游戏开发库,它基于C++,同时提供了Lua和JavaScript的绑定,使得开发者可以使用这三种语言进行游戏开发。Cocos2d-x的强大之处在于其丰富的功能集、高效的性能以及广泛的社区支持。 在...

    Cocos2D-X游戏开发技术精解学习

    Cocos2D-X引擎基于C++,同时支持Lua和JavaScript脚本语言,提供了丰富的图形绘制、动画制作、物理模拟、音频处理等功能。其跨平台特性使得开发者可以一次编写,多平台运行,包括iOS、Android、Windows等主流操作系统...

Global site tag (gtag.js) - Google Analytics