Cocos2d-JS内置粒子系统

从类图中我们可以看到,Cocos2d-JS中有内置的11种粒子,这些粒子的属性都是预先定义好的,我们也可以在程序代码中单独修改某些属性,我们在上一节的实例中都已经实现了这些属性的设置。
内置粒子系统
内置的11种粒子系统说明如下: 
ParticleExplosion。爆炸粒子效果,属于半径模式。
ParticleFire。火焰粒子效果,属于重力径模式。
ParticleFireworks。烟花粒子效果,属于重力模式。
ParticleFlower。花粒子效果,属于重力模式。
ParticleGalaxy。星系粒子效果,属于半径模式。
ParticleMeteor。流星粒子效果,属于重力模式。
ParticleSpiral。漩涡粒子效果,属于半径模式。
ParticleSnow。雪粒子效果,属于重力模式。
ParticleSmoke。烟粒子效果,属于重力模式。
ParticleSun。太阳粒子效果,属于重力模式。
ParticleRain。雨粒子效果,属于重力模式。
这11种粒子的属性,根据它的发射模式不同,效果不同。
实例:内置粒子系统
下面我们通过一个实例演示一下这11种内置粒子系统。这个实例如图所示,左图是一个操作菜单场景,选择菜单可以进入到上图动作场景,在下图动作场景中演示选择的粒子系统效果,点击右下角返回按钮可以返回到菜单场景。

内置粒子系统实例

下面我们重点介绍一下场景MyActionScene,它的MyActionScene.js代码如下:

[html] view plaincopy

  1. var MyActionLayer = cc.Layer.extend({
  2. flagTag: 0,                         // 操作标志
  3. pLabel: null,                                                       ①
  4. ctor: function (flagTag) {
  5. this._super();
  6. this.flagTag = flagTag;
  7. cc.log("MyActionLayer init flagTag " + this.flagTag);
  8. var size = cc.director.getWinSize();
  9. var backMenuItem = new cc.LabelBMFont("<Back", res.fnt_fnt);
  10. var backMenuItem = new cc.MenuItemLabel(backMenuItem, this.backMenu, this);
  11. backMenuItem.x = size.width - 100;
  12. backMenuItem.y = 100;
  13. var mn = cc.Menu.create(backMenuItem);
  14. mn.x = 0;
  15. mn.y = 0;
  16. mn.anchorX = 0.5;
  17. mn.anchorY = 0.5;
  18. this.addChild(mn);
  19. this.pLabel =  new cc.LabelBMFont("", res.fnt_fnt);
  20. this.pLabel.x = size.width /2;
  21. this.pLabel.y = size.height  - 50;
  22. this.addChild(this.pLabel, 3);
  23. return true;
  24. },
  25. backMenu: function (sender) {
  26. cc.director.popScene();
  27. },
  28. onEnterTransitionDidFinish: function () {
  29. cc.log("Tag = " + this.flagTag);
  30. var sprite = this.getChildByTag(SP_TAG);
  31. var size = cc.director.getWinSize();
  32. var system;
  33. switch (this.flagTag) {                                         ②
  34. case ActionTypes.kExplosion:
  35. system = new cc.ParticleExplosion();
  36. this.pLabel.setString("Explosion");
  37. break;
  38. case ActionTypes.kFire:
  39. system = new cc.ParticleFire();
  40. system.texture = cc.textureCache.addImage(res.s_fire);              ③
  41. this.pLabel.setString("Fire");
  42. break;
  43. case ActionTypes.kFireworks:
  44. system = new cc.ParticleFireworks();
  45. this.pLabel.setString("Fireworks");
  46. break;
  47. case ActionTypes.kFlower:
  48. system = new cc.ParticleFlower();
  49. this.pLabel.setString("Flower");
  50. break;
  51. case ActionTypes.kGalaxy:
  52. system = new cc.ParticleGalaxy();
  53. this.pLabel.setString("Galaxy");
  54. break;
  55. case ActionTypes.kMeteor:
  56. system = new cc.ParticleMeteor();
  57. this.pLabel.setString("Meteor");
  58. break;
  59. case ActionTypes.kRain:
  60. system = new cc.ParticleRain();
  61. this.pLabel.setString("Rain");
  62. break;
  63. case ActionTypes.kSmoke:
  64. system = new cc.ParticleSmoke();
  65. this.pLabel.setString("Smoke");
  66. break;
  67. case ActionTypes.kSnow:
  68. system = new cc.ParticleSnow();
  69. this.pLabel.setString("Snow");
  70. break;
  71. case ActionTypes.kSpiral:
  72. system = new cc.ParticleSpiral();
  73. this.pLabel.setString("Spiral");
  74. break;
  75. case ActionTypes.kSun:
  76. system = new cc.ParticleSun();
  77. this.pLabel.setString("Sun");
  78. break;                                                  ④
  79. }
  80. system.x = size.width /2;
  81. system.y = size.height /2;
  82. this.addChild(system);
  83. }
  84. });
  85. var MyActionScene = cc.Scene.extend({
  86. onEnter: function () {
  87. this._super();
  88. }
  89. });

在头文件中第①行代码定义了LabelBMFont类型的成员变量pLabel,用来在场景中显示粒子系统的名称。
我们在MyActionLayer的onEnterTransitionDidFinish函数中创建粒子系统对象,而不是在MyActionLayer的onEnter函数创建,这是因为MyActionLayer的onEnter函数调用时,场景还没有显示,如果在该函数中创建爆炸等显示一次的粒子系统,等到场景显示的时候,爆炸已经结束了,我们会看不到效果。
代码第②~④行创建了11种粒子系统,这里创建粒子系统时候都采用了它们的默认属性值。其中this.pLabel.setString("XXX")函数是为场景中标签设置内容,这样在进入场景后可以看到粒子系统的名称。

另外,如果在Web浏览器中运行还需要为粒子系统添加纹理,我们只在代码第③行添加了火粒子纹理,其它的粒子纹理添加类似。

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

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

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

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

智捷课堂现推出Cocos会员,敬请关注:http://v.51work6.com/courseInfoRedirect.do?action=netDetialInfo&courseId=844465&amp;categoryId=0

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

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

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

时间: 2024-11-08 18:23:22

Cocos2d-JS内置粒子系统的相关文章

Cocos2d-x内置粒子系统

从类图中我们可以看到,Cocos2d-x中有内置的11粒子,这些粒子的属性都是预先定义好的,我们也可以在程序代码中单独修改某些属性,我们在上一节的实例中都已经实现了这些属性的设置. 内置粒子系统 内置的11粒子系统说明如下: ParticleExplosion.爆炸粒子效果,属于半径模式. ParticleFire.火焰粒子效果,属于重力径模式. ParticleFireworks.烟花粒子效果,属于重力模式. ParticleFlower.花粒子效果,属于重力模式. ParticleGalax

JS内置对象-String对象、Date日期对象、Array数组对象、Math对象

一.JavaScript中的所有事物都是对象:字符串.数组.数值.函数... 1.每个对象带有属性和方法 JavaScript允许自定义对象 2.自定义对象 a.定义并创建对象实例 b.使用函数来定义对象,然后创建新的对象实例 二.JS内置对象-String 1.string对象 string对象用于处理已有的字符串 字符串可以使用单引号或者双引号 2.indexOf( )  在字符串中查找字符串,如果匹配成功返回首字母所在的位置,否则返回-1 3.match() 匹配成功,返回匹配成功的数组,

5月15日上课笔记-js中 location对象的属性、document对象、js内置对象、Date事件对象、

location的属性: host: 返回当前主机名和端口号 定时函数: setTimeout( ) setInterval() 二.document对象 getElementById(); 根据ID值获取一个DOM对象 getElementsByName(); 根据name属性值获取多个Dom对象 getElementsByTagName(); 根据标签获取多个DOM对象 获取标签体内容 innerHTML 获取input的value值 value 获取下拉框选中的值 value this 代

JS 内置对象 String对象

JS内置对象   String对象:字符串对象,提供了对字符串进行操作的属性和方法.   Array对象:数组对象,提供了数组操作方面的属性和方法.   Date对象:日期时间对象,可以获取系统的日期时间信息.   Boolean对象:布尔对象,一个布尔变量就是一个布尔对象.(没有可用的属性和方法)   Number对象:数值对象.一个数值变量就是一个数值对象.   Math对象:数学对象,提供了数学运算方面的属性和方法. String对象的属性和方法   length:获取字符串的长度.如:v

JS内置对象的原型不能重定义?只能动态添加属性或方法?

昨天马上就快下班了,坐在我对面的同事突然问我一个问题,我说“爱过”,哈哈,开个玩笑.情况是这样的,他发现JS的内置对象的原型好像不能通过字面量对象的形式进行覆盖, 只能动态的为内置对象的原型添加属性或方法,下面那个具体的例子说明: var arr=[]; Array.prototype={ push:function(){ alert("1"); } }; arr.push(); //没有任何输出 有人可能会说了“你先定义的arr,后来又修改了Array.prototype,这时Arr

4月8日--课堂笔记--JS内置对象

JavaScript Day8 一.    JS内置对象 字符串String a) 属性length:字符数量,不管是ASCII还是Unicode,都算1个字符 b) 查询方法: i.           charAt:根据索引位置查找字符,可以用[索引]代替(除了旧版IE) ii.           charCodeAt:根据索引位置查找字符编码 iii.           indexOf:根据字符(串)查找首次出现位置,如果找不到则返回-1:不指定第二个起始位置时从头开始查找,如果指定则

js内置对象总结

在js里,一切皆为或者皆可以被用作对象.可通过new一个对象或者直接以字面量形式创建变量(如var i="aaa"),所有变量都有对象的性质. 注意:通过字面量创建的对象在调用属性和方法时会被对象包装器暂时包装成一个对象,具有对象的性质.如 var str="我不是一个真的对象"; alert(str.length);     //str被暂时包装成一个String对象,可调用该对象的属性和方法 不过这并不意味着它就是一个对象了,typeof(i)的值为仍Strin

js内置对象处理-打印学生成绩单

效果图: 任务: 1.通过js的内置对象得到当前日期 var date=new Date(); var year=date.toString().slice(11,15); document.write(year.toString()+"年"); var month=date.getMonth(); month=month+1; if(month<10){ document.write("0"+month+"月"); }else{ docu

巧用JS内置对象Function

在做练习的时候也好,做项目的时候也好,我经常会碰到想要的到一个字符串“”里面的东西的这样的需求. 注意,“”里面的东西可以是任何东西[],number等等 于是有了个大神教我一个绝招: 于是世界圆满了... 其实Function就是js的一个内置对象. 这里有个文章讲的挺好的 http://www.cnitblog.com/yemoo/archive/2007/09/25/34017.html