今天看了cocos2d-html5里面的粒子系统相关的代码,首先看了代码中引用的两篇文章, 这两篇文章google上都可以搜到pdf的.

The Ocean Spray in Your Face [jeff lander]
Building an Advanced Particle System [John van der Burg]

基本概念

jeff lander的文章是一个很好的入门,讲述了基本的概念。

游戏里面的烟火,大雾,爆炸还有血液四溅的效果:(,都是用粒子系统来模拟的。一个粒子(particle)是3D空间中的一个点。基本属性,如位置,速度,方向,还有生命周期(就是这个粒子该画多少帧)等,发射器(emitter)负责 粒子的创建,还有particle pool这个主要是性能上的优化,降低粒子的alloc和free的开销。生成粒子的时候,直接从pool里面取,然后粒子销毁的时候,把粒子放回pool里面.

为了使粒子看起来有一定的随机性,有些属性会有方差variance这个值吧。这样emitter发射的时候,可以根据这个方差来生成具有一定随机值的粒子。 比如这样可以生成具有一定随机数个数的粒子:

particleCount = emitNumber + (emitVariance * RandomNum());

然后添加粒子初始化的时候,可以根据这个方差来设置粒子的属性,比如这个粒子的life.

particle.timeToLive = emitter._life + emitter._lifeVar * cc.RANDOM_MINUS1_1();

代码结构

John van der Burg讲的更详细一些, 更多的是代码结构上的,它将粒子系统分为三个层次, 基本上是一层管一层。。

Particle Manager --> Particle System --> Particle

Particle Manager负责particle system 的管理, 一个particle system由很多有公共属性的粒子组成吧,便于粒子的管理. 这里的ParticleSystem就相当于上面的emitter.

然后基本框架可以是这样,其中ParticleManager是单例的(个人觉得代码里面称得上是Manager的一般都是单例模式的), ParticleManager和ParticleSystem 还有add和remove这一类的方法.

class Game:
def run():
while(true)
{
//other codes
self.particle_manager.update(time)
//other codes
} class ParticleManager:
def update(self, time):
for s in self.active_systems:
if system.isDie(time):
self.active_systems.remove(s)
else:
s.update class ParticleSystem:
def update(self, time):
for p in self.active_particles:
if p.isDie(time):
game.particle_pool.add(p)
self.active_particles.remove(p)
else:
p.update(time)

从画图上来说,一个粒子系统有如下的属性

  • Texture, 粒子的贴图,出于性能上的考虑吧, 一个粒子系统里面所有的粒子用相同的贴图.
  • blendMode, 混合模式. 类似于opengl里面的混合模式。

cocos2d粒子

cocos2d里面的粒子实现和上面个的基本上一致吧:), 不过cocos2d里木有ParticleManager。因为ParticleSystem也是从Node这个直接派生过来的,ParticleSystem的管理基本上可以交給Node了。

particle

Particle的属性

pos, startpos, color, deltaColor, size, deletaSize, rotation, deltaRotaion,
timeToLieve, modeA, modeB, ischangeColor, drawPos

modeA是重力模式,modeB是circular movement(不知道咋翻译哈) deltaColor和deltaSize 这两个属性使得粒子在运动的时候可以改变颜色和大小。

particle system

一个particle system包含了particle的一些属性还有它的属性值的方差, 这样就可以用来生成不同的粒子了。particle system里面的继承关系如下:

CCParticleSystemQuad --> CCParticleSystem

CCParticleSystem是基类它负责粒子的创建,初始化还有update,在update的中去遍历所有的粒子,然后计算更新粒子的属性。

然后CCParticleSystemQuad这个把粒子画出来(用quad画出来)如果是webgl的画,会采用bacthmode来优化。它实现了draw和visit这俩个函数。

particle system editor

在CCParticleExample.js里面有一些比如fire, sun, galaxy, flow等一些粒子效果,这些只是设置下参数而已。话说应该有很多粒子效果编辑器吧。这些编辑器也就是调调这些参数,然后导出.plist文件(cocos2d里面可以直接用.plist来初始化一个particle system)既然都有cocos2d-html5了,可以做一个web版的粒子编辑器。

Cocos2d-html5 笔记4: 粒子的更多相关文章

  1. Cocos2d html5 笔记 1: overview

    昨天接触到了cocos2d-html5的的东东了, 第一次看其源代码一头雾水,幸好samples目录下面有几个例子,可以从这个入手. MoonWarriors是一个射击类的游戏, 有点像以前玩的雷电, ...

  2. HTML5笔记3——Web Storage和本地数据库

    上一篇:HTML5笔记2——HTML5音/视频标签详解 Web Storage概述 在HTML5中,除了Canvas元素之外,另一个新增的非常重要的功能是可以再客户端本地保存数据的Web Storag ...

  3. WebGL three.js学习笔记 使用粒子系统模拟时空隧道(虫洞)

    WebGL three.js学习笔记 使用粒子系统模拟时空隧道 本例的运行结果如图: 时空隧道demo演示 Demo地址:https://nsytsqdtn.github.io/demo/sprite ...

  4. Cocos2D v3.4.9粒子效果不能显示的原因分析及解决办法

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 在游戏App中为了衬托气氛我们往往使用一些特殊的图形效果,粒子 ...

  5. 基于HTML5 Canvas生成粒子效果的人物头像

    前面我们分享过一个HTML5 Canvas实现的图像马赛克模糊效果,HTML5处理图片真的非常简单.今天我们要再利用HTML5 Canvas实现一个粒子效果的人物头像,你可以任意选择一张头像图片,接下 ...

  6. css3 和 html5 笔记

    1.css3 ie下大部分不兼容 ie9以下 浏览器低版本不兼容 需要写 -webket-transition:1s -moz-transition: 1s -o-transition:1s tran ...

  7. COCOS2D 学习笔记

    cc.Node.scheduleUpdate:function () * schedules the "update" method.                       ...

  8. Html5笔记 表格 布局

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. HTML5笔记2——HTML5音/视频标签详解

    音视频的发展史 早期:<embed>+<object>+文件 问题:不是所有浏览器都支持,而且embed不是标准. 现状:Realplay.window media.Quick ...

随机推荐

  1. MVC dropdownlist使用

    View中代码 @{ ViewBag.Title = "dropdownlist"; } <h2>dropdownlist</h2> @using (Htm ...

  2. 第三百四十九、五十天 how can I 坚持

    昨天是忘写博客了,今天下班才突然意思到,搞框架搞了好晚.今天重新下了个好了. 昨天,把存储过程交给同事写了,啥都不会,又一堆问题,折腾了一天. 今天相对轻松些,不过事情还没完..明天又周五了. 还有昨 ...

  3. fdquery update

    fdquery  update this->FDQuery1->CachedUpdates; this->FDQuery1->UpdateOptions->KeyFiel ...

  4. 网上关于sort结构体排序都不完整,我来写一个完整版的 2014-08-09 16:50 60人阅读 评论(0) 收藏

    主要参考sort函数_百度文库, 但是那篇有错误 2.结构体排序,a升,b降,c降 平板视图 打印? 01 #include <iostream> 02 #include <algo ...

  5. HD1064Financial Management

    Problem Description Larry graduated this year and finally has a job. He's making a lot of money, but ...

  6. 要后台控制前台的的CSS样式,我们可以加入ASP.NET Literal 控件

    ASP.NET Literal 控件,用于在页面上显示文本.此文本是可编程的. 我用它来制作了 ) { this.LtdMemberPromotion7.Text = "<style ...

  7. AJAX的工作原理及其优缺点

    1.什么是AJAX?AJAX全称为“Asynchronous JavaScript and XML”(异步JavaScript和XML),是一种创建交互式网页应用的网页开发技术.它使用:使用XHTML ...

  8. HDU 4599 Dice (概率DP+数学+快速幂)

    题意:给定三个表达式,问你求出最小的m1,m2,满足G(m1) >= F(n), G(m2) >= G(n). 析:这个题是一个概率DP,但是并没有那么简单,运算过程很麻烦. 先分析F(n ...

  9. chrome emulator use-agent 设置 chrom模拟手机客户端

    谷歌升级以后,发现找不到use-agent设置了 在Element 下点击ESC 出现console,再点击Emulation就出现了

  10. Lotus 迁移到Exchange 2010 POC 之在Exchange 2007安装Transport Suite!

    我们登录到Exchange 2007服务器,下载Transport 组件,下载地址如下,我们由于安装在Exchange 服务器上,所以需要安装64位版本: