Cocos2d-x 2.0 粒子系统深入分析三部曲(三)

长平狐 发表于 2013-3-19 18:39 9个月前, 0回/1184阅

开源中国诚邀您参加 Cloud Foundry 中国群英会!(北京、上海、杭州、成都、深圳)

[Cocos2d-x相关教程来源于红孩儿的游戏编程之路CSDN博客地址:http://blog.csdn.net/honghaier]

红孩儿Cocos2d-X学习园地QQ2群:44208467加群写:Cocos2d-x
                           红孩儿Cocos2d-X学习园地QQ群:249941957加群写:Cocos2d-x

Cocos2d-x2.0 粒子系统深入分析三部曲(三)

另:本章所用Cocos2d-x版本为:

cocos2d-2.0-x-2.0.2@ Aug 30 2012

http://cn.cocos2d-x.org/download

前面两节我们分析了Cocos2d-x中粒子系统的的基类,了解了粒子系统的构成与原理,本节我们来看一下在Cocos2d-x中如何具体展示粒子系统。

我们打开libcocos2d工程下的particle_nodes目录,可以看到:

这个目录是粒子系统相关的一些源码的列表,很明显,我们还有一个CCParticleExample.h/cpp没有学习。那么,这一节,我们将会从这两个文件开始。

CCParticleSystem.h:

源码打印?
  1. #ifndef __CCPARTICLE_EXAMPLE_H__
  2. #define __CCPARTICLE_EXAMPLE_H__
  3. //包含粒子系统基类头文件
  4. #include "CCParticleSystemQuad.h"
  5. //使用Cocos2d命名空间
  6. NS_CC_BEGIN
  7. //由粒子系统基类派生出CCParticleFire,表现的是火焰
  8. class CC_DLL CCParticleFire : public CCParticleSystemQuad
  9. {
  10. public:
  11. //构造
  12. CCParticleFire(){}
  13. //析构
  14. virtual ~CCParticleFire(){}
  15. //初始化,创建250个粒子。
  16. bool init(){ return initWithTotalParticles(250); }
  17. //创建相应数量的粒子。
  18. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  19. //创建一个当前实例对象,内部调用create实现。
  20. static CCParticleFire * node()
  21. {
  22. return create();
  23. }
  24. //上面的create实现。
  25. static CCParticleFire * create()
  26. {
  27. //创建一个新的实例,初始化后交由内存管理器进行管理,返回实例指针。
  28. CCParticleFire *pRet = new CCParticleFire();
  29. if (pRet->init())
  30. {
  31. pRet->autorelease();
  32. return pRet;
  33. }
  34. //如果失败释放置空并返回NULL。
  35. CC_SAFE_DELETE(pRet);
  36. return NULL;
  37. }
  38. };

对应的CPP实现:

源码打印?
  1. //创建相应数量的粒子。
  2. bool CCParticleFire::initWithTotalParticles(unsigned int numberOfParticles)
  3. {
  4. //调用基类的初始化函数。
  5. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  6. {
  7. // 设置为一直不断的发射。
  8. m_fDuration = kCCParticleDurationInfinity;
  9. // 设置为重力加速模式。
  10. this->m_nEmitterMode = kCCParticleModeGravity;
  11. // 设置重力加速度的值。
  12. this->modeA.gravity = ccp(0,0);
  13. // 设置半径变化值及其用于随机初始化的范围值。
  14. this->modeA.radialAccel = 0;
  15. this->modeA.radialAccelVar = 0;
  16. // 设置速度及其用于随机初始化的范围值。
  17. this->modeA.speed = 60;
  18. this->modeA.speedVar = 20;
  19. // 设置起始角度及其用于随机初始化的范围值。
  20. m_fAngle = 90;
  21. m_fAngleVar = 10;
  22. // 设置发射器的位置及其用于随机初始化的范围值。
  23. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  24. this->setPosition(ccp(winSize.width/2, 60));
  25. this->m_tPosVar = ccp(40, 20);
  26. // 粒子的生命值及其用于随机初始化的范围值。
  27. m_fLife = 3;
  28. m_fLifeVar = 0.25f;
  29. //起始大小及其用于随机初始化的范围值。终止大小为枚举值,在粒子系统基类的update里有处理,即大小在更新时不变化。
  30. m_fStartSize = 54.0f;
  31. m_fStartSizeVar = 10.0f;
  32. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  33. // 发射器的发射速率。
  34. m_fEmissionRate = m_uTotalParticles/m_fLife;
  35. // 起始和结束的粒子颜色。
  36. m_tStartColor.r = 0.76f;
  37. m_tStartColor.g = 0.25f;
  38. m_tStartColor.b = 0.12f;
  39. m_tStartColor.a = 1.0f;
  40. m_tStartColorVar.r = 0.0f;
  41. m_tStartColorVar.g = 0.0f;
  42. m_tStartColorVar.b = 0.0f;
  43. m_tStartColorVar.a = 0.0f;
  44. m_tEndColor.r = 0.0f;
  45. m_tEndColor.g = 0.0f;
  46. m_tEndColor.b = 0.0f;
  47. m_tEndColor.a = 1.0f;
  48. m_tEndColorVar.r = 0.0f;
  49. m_tEndColorVar.g = 0.0f;
  50. m_tEndColorVar.b = 0.0f;
  51. m_tEndColorVar.a = 0.0f;
  52. // 设置为加亮模式。
  53. this->setBlendAdditive(true);
  54. return true;
  55. }
  56. return false;
  57. }
源码打印?
  1. //由粒子系统基类派生出CCParticleFire,表现的是焰火
  2. class CC_DLL CCParticleFireworks : public CCParticleSystemQuad
  3. {
  4. public:
  5. //构造
  6. CCParticleFireworks(){}
  7. //析构
  8. virtual ~CCParticleFireworks(){}
  9. //初始化,创建1500个粒子。
  10. bool init(){ return initWithTotalParticles(1500); }
  11. //创建相应数量的粒子。
  12. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  13. //创建一个当前实例对象,内部调用create实现。
  14. static CCParticleFireworks * node()
  15. {
  16. return create();
  17. }
  18. //上面的create实现。
  19. static CCParticleFireworks * create()
  20. {
  21. //创建一个新的实例,初始化后交由内存管理器进行管理,返回实例指针。
  22. CCParticleFireworks *pRet = new CCParticleFireworks();
  23. if (pRet->init())
  24. {
  25. pRet->autorelease();
  26. return pRet;
  27. }
  28. //如果失败释放置空并返回NULL。
  29. CC_SAFE_DELETE(pRet);
  30. return NULL;
  31. }
  32. };
  33. 对应CPP实现:
  34. //创建相应数量的粒子。
  35. bool CCParticleFireworks::initWithTotalParticles(unsigned int numberOfParticles)
  36. {
  37. //先调用基类的相应函数。
  38. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  39. {
  40. // 设置为一直不断的发射。
  41. m_fDuration = kCCParticleDurationInfinity;
  42. // 设置为重力加速模式。
  43. this->m_nEmitterMode = kCCParticleModeGravity;
  44. // 设置重力加速度值。
  45. this->modeA.gravity = ccp(0,-90);
  46. // 设置半径变化值及其用于随机初始化的范围值。
  47. this->modeA.radialAccel = 0;
  48. this->modeA.radialAccelVar = 0;
  49. // 设置速度及其用于随机初始化的范围值。
  50. this->modeA.speed = 180;
  51. this->modeA.speedVar = 50;
  52. //设置发射器的位置。
  53. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  54. this->setPosition(ccp(winSize.width/2, winSize.height/2));
  55. //设置起始角度及其用于随机初始化的范围值。
  56. this->m_fAngle= 90;
  57. this->m_fAngleVar = 20;
  58. // 粒子的生命值及其用于随机初始化的范围值。
  59. this->m_fLife = 3.5f;
  60. this->m_fLifeVar = 1;
  61. // 发射器的发射速率。
  62. this->m_fEmissionRate = m_uTotalParticles/m_fLife;
  63. // 起始和结束的粒子颜色。
  64. m_tStartColor.r = 0.5f;
  65. m_tStartColor.g = 0.5f;
  66. m_tStartColor.b = 0.5f;
  67. m_tStartColor.a = 1.0f;
  68. m_tStartColorVar.r = 0.5f;
  69. m_tStartColorVar.g = 0.5f;
  70. m_tStartColorVar.b = 0.5f;
  71. m_tStartColorVar.a = 0.1f;
  72. m_tEndColor.r = 0.1f;
  73. m_tEndColor.g = 0.1f;
  74. m_tEndColor.b = 0.1f;
  75. m_tEndColor.a = 0.2f;
  76. m_tEndColorVar.r = 0.1f;
  77. m_tEndColorVar.g = 0.1f;
  78. m_tEndColorVar.b = 0.1f;
  79. m_tEndColorVar.a = 0.2f;
  80. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  81. m_fStartSize = 8.0f;
  82. m_fStartSizeVar = 2.0f;
  83. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  84. //不使用加亮模式。
  85. this->setBlendAdditive(false);
  86. return true;
  87. }
  88. return false;
  89. }
源码打印?
  1. //由粒子系统基类派生出CCParticleSun,表现的是太阳
  2. class CC_DLL CCParticleSun : public CCParticleSystemQuad
  3. {
  4. public:
  5. //构造
  6. CCParticleSun(){}
  7. //析构
  8. virtual ~CCParticleSun(){}
  9. //初始化,创建350个粒子。
  10. bool init(){ return initWithTotalParticles(350); }
  11. //创建相应数量的粒子。
  12. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  13. //创建一个当前实例,内部调用create实现。
  14. static CCParticleSun * node()
  15. {
  16. return create();
  17. }
  18. //上面的create实现。
  19. static CCParticleSun * create()
  20. {
  21. CCParticleSun *pRet = new CCParticleSun();
  22. if (pRet->init())
  23. {
  24. pRet->autorelease();
  25. return pRet;
  26. }
  27. CC_SAFE_DELETE(pRet);
  28. return NULL;
  29. }
  30. };
  31. 对应的CPP实现:
  32. //创建相应数量的粒子。
  33. bool CCParticleSun::initWithTotalParticles(unsigned int numberOfParticles)
  34. {
  35. //先调用基类的相应函数。if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  36. {
  37. // 设置使用加亮模式。
  38. this->setBlendAdditive(true);
  39. // 设置为一直不断的发射。
  40. m_fDuration = kCCParticleDurationInfinity;
  41. // 设置为重力加速模式。
  42. m_nEmitterMode = kCCParticleModeGravity;
  43. // 设置重力加速度值。
  44. modeA.gravity = ccp(0,0);
  45. // 设置半径变化值及其用于随机初始化的范围值。
  46. modeA.radialAccel = 0;
  47. modeA.radialAccelVar = 0;
  48. // 设置速度及其用于随机初始化的范围值。
  49. modeA.speed = 20;
  50. modeA.speedVar = 5;
  51. //设置起始角度及其用于随机初始化的范围值。
  52. m_fAngle = 90;
  53. m_fAngleVar = 360;
  54. //设置发射器的位置及其用于随机初始化的范围值。
  55. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  56. this->setPosition(ccp(winSize.width/2, winSize.height/2));
  57. m_tPosVar = CCPointZero;
  58. // 粒子的生命值及其用于随机初始化的范围值。
  59. m_fLife = 1;
  60. m_fLifeVar = 0.5f;
  61. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  62. m_fStartSize = 30.0f;
  63. m_fStartSizeVar = 10.0f;
  64. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  65. // 发射器的发射速率。
  66. m_fEmissionRate = m_uTotalParticles/m_fLife;
  67. // 起始和结束的粒子颜色。
  68. m_tStartColor.r = 0.76f;
  69. m_tStartColor.g = 0.25f;
  70. m_tStartColor.b = 0.12f;
  71. m_tStartColor.a = 1.0f;
  72. m_tStartColorVar.r = 0.0f;
  73. m_tStartColorVar.g = 0.0f;
  74. m_tStartColorVar.b = 0.0f;
  75. m_tStartColorVar.a = 0.0f;
  76. m_tEndColor.r = 0.0f;
  77. m_tEndColor.g = 0.0f;
  78. m_tEndColor.b = 0.0f;
  79. m_tEndColor.a = 1.0f;
  80. m_tEndColorVar.r = 0.0f;
  81. m_tEndColorVar.g = 0.0f;
  82. m_tEndColorVar.b = 0.0f;
  83. m_tEndColorVar.a = 0.0f;
  84. return true;
  85. }
  86. return false;
  87. }
源码打印?
  1. //由粒子系统基类派生出CCParticleGalaxy,表现的是银河或一大堆星星。
  2. class CC_DLL CCParticleGalaxy : public CCParticleSystemQuad
  3. {
  4. public:
  5. //构造与析构
  6. CCParticleGalaxy(){}
  7. virtual ~CCParticleGalaxy(){}
  8. //初始化,创建200个粒子。
  9. bool init(){ return initWithTotalParticles(200); }
  10. //创建相应数量的例子。
  11. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  12. //创建当前类的实例,内部调用create实现。
  13. static CCParticleGalaxy * node()
  14. {
  15. return create();
  16. }
  17. //上面的create实现。
  18. static CCParticleGalaxy * create()
  19. {
  20. CCParticleGalaxy *pRet = new CCParticleGalaxy();
  21. if (pRet->init())
  22. {
  23. pRet->autorelease();
  24. return pRet;
  25. }
  26. CC_SAFE_DELETE(pRet);
  27. return NULL;
  28. }
  29. };
  30. 其对应的CPP:
  31. bool CCParticleGalaxy::initWithTotalParticles(unsigned int numberOfParticles)
  32. {
  33. //调用基类的相应函数。
  34. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  35. {
  36. // 设置为一直不断的发射。
  37. m_fDuration = kCCParticleDurationInfinity;
  38. // 设置为重力加速模式。
  39. m_nEmitterMode = kCCParticleModeGravity;
  40. // 设置重力加速度值。
  41. modeA.gravity = ccp(0,0);
  42. // 设置速度及其用于随机初始化的范围值。
  43. modeA.speed = 60;
  44. modeA.speedVar = 10;
  45. // 设置半径变化值及其用于随机初始化的范围值。
  46. modeA.radialAccel = -80;
  47. modeA.radialAccelVar = 0;
  48. // 设置切角变化值及其用于随机初始化的范围值。
  49. modeA.tangentialAccel = 80;
  50. modeA.tangentialAccelVar = 0;
  51. //设置起始角度及其用于随机初始化的范围值。
  52. m_fAngle = 90;
  53. m_fAngleVar = 360;
  54. //设置发射器的位置及其用于随机初始化的范围值。
  55. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  56. this->setPosition(ccp(winSize.width/2, winSize.height/2));
  57. m_tPosVar = CCPointZero;
  58. // 粒子的生命值及其用于随机初始化的范围值。
  59. m_fLife = 4;
  60. m_fLifeVar = 1;
  61. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  62. m_fStartSize = 37.0f;
  63. m_fStartSizeVar = 10.0f;
  64. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  65. //发射器的发射速率
  66. m_fEmissionRate = m_uTotalParticles/m_fLife;
  67. // 起始和结束的粒子颜色。
  68. m_tStartColor.r = 0.12f;
  69. m_tStartColor.g = 0.25f;
  70. m_tStartColor.b = 0.76f;
  71. m_tStartColor.a = 1.0f;
  72. m_tStartColorVar.r = 0.0f;
  73. m_tStartColorVar.g = 0.0f;
  74. m_tStartColorVar.b = 0.0f;
  75. m_tStartColorVar.a = 0.0f;
  76. m_tEndColor.r = 0.0f;
  77. m_tEndColor.g = 0.0f;
  78. m_tEndColor.b = 0.0f;
  79. m_tEndColor.a = 1.0f;
  80. m_tEndColorVar.r = 0.0f;
  81. m_tEndColorVar.g = 0.0f;
  82. m_tEndColorVar.b = 0.0f;
  83. m_tEndColorVar.a = 0.0f;
  84. // 设置为加亮模式。
  85. this->setBlendAdditive(true);
  86. return true;
  87. }
  88. return false;
  89. }
源码打印?
  1. //由粒子系统基类派生出CCParticleFlower,表现的是花瓣洒落。
  2. class CC_DLL CCParticleFlower : public CCParticleSystemQuad
  3. {
  4. public:
  5. //函数注释同上面的类,不再赘述。
  6. CCParticleFlower(){}
  7. virtual ~CCParticleFlower(){}
  8. bool init(){ return initWithTotalParticles(250); }
  9. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  10. static CCParticleFlower * node()
  11. {
  12. return create();
  13. }
  14. static CCParticleFlower * create()
  15. {
  16. CCParticleFlower *pRet = new CCParticleFlower();
  17. if (pRet->init())
  18. {
  19. pRet->autorelease();
  20. return pRet;
  21. }
  22. CC_SAFE_DELETE(pRet);
  23. return NULL;
  24. }
  25. };
  26. 对应的CPP:
  27. bool CCParticleFlower::initWithTotalParticles(unsigned int numberOfParticles)
  28. {
  29. //先调用基类的相应函数。
  30. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  31. {
  32. // 设置为一直不断的发射。
  33. m_fDuration = kCCParticleDurationInfinity;
  34. // 设置为重力加速模式。
  35. m_nEmitterMode = kCCParticleModeGravity;
  36. // 设置重力加速度的值。
  37. modeA.gravity = ccp(0,0);
  38. // 设置速度及其用于随机初始化的范围值。
  39. modeA.speed = 80;
  40. modeA.speedVar = 10;
  41. // 设置半径变化值及其用于随机初始化的范围值。
  42. modeA.radialAccel = -60;
  43. modeA.radialAccelVar = 0;
  44. // 设置切角变化值及其用于随机初始化的范围值。
  45. modeA.tangentialAccel = 15;
  46. modeA.tangentialAccelVar = 0;
  47. // 设置起始角度及其用于随机初始化的范围值。
  48. m_fAngle = 90;
  49. m_fAngleVar = 360;
  50. //设置发射器的位置及其用于随机初始化的范围值。
  51. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  52. this->setPosition(ccp(winSize.width/2, winSize.height/2));
  53. m_tPosVar = CCPointZero;
  54. // 粒子的生命值及其用于随机初始化的范围值。
  55. m_fLife = 4;
  56. m_fLifeVar = 1;
  57. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  58. m_fStartSize = 30.0f;
  59. m_fStartSizeVar = 10.0f;
  60. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  61. // 发射器的发射速率。
  62. m_fEmissionRate = m_uTotalParticles/m_fLife;
  63. // 起始和结束的粒子颜色。
  64. m_tStartColor.r = 0.50f;
  65. m_tStartColor.g = 0.50f;
  66. m_tStartColor.b = 0.50f;
  67. m_tStartColor.a = 1.0f;
  68. m_tStartColorVar.r = 0.5f;
  69. m_tStartColorVar.g = 0.5f;
  70. m_tStartColorVar.b = 0.5f;
  71. m_tStartColorVar.a = 0.5f;
  72. m_tEndColor.r = 0.0f;
  73. m_tEndColor.g = 0.0f;
  74. m_tEndColor.b = 0.0f;
  75. m_tEndColor.a = 1.0f;
  76. m_tEndColorVar.r = 0.0f;
  77. m_tEndColorVar.g = 0.0f;
  78. m_tEndColorVar.b = 0.0f;
  79. m_tEndColorVar.a = 0.0f;
  80. // 设置为加亮模式。
  81. this->setBlendAdditive(true);
  82. return true;
  83. }
  84. return false;
  85. }
源码打印?
  1. //由粒子系统基类派生出CCParticleMeteor,表现的是流星
  2. class CC_DLL CCParticleMeteor : public CCParticleSystemQuad
  3. {
  4. public:
  5. //函数注释同上面的类,不再赘述。
  6. CCParticleMeteor(){}
  7. virtual ~CCParticleMeteor(){}
  8. bool init(){ return initWithTotalParticles(150); }
  9. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  10. static CCParticleMeteor * node()
  11. {
  12. return create();
  13. }
  14. static CCParticleMeteor * create()
  15. {
  16. CCParticleMeteor *pRet = new CCParticleMeteor();
  17. if (pRet->init())
  18. {
  19. pRet->autorelease();
  20. return pRet;
  21. }
  22. CC_SAFE_DELETE(pRet);
  23. return NULL;
  24. }
  25. };
  26. 对应CPP:
  27. bool CCParticleMeteor::initWithTotalParticles(unsigned int numberOfParticles)
  28. {
  29. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  30. {
  31. // 设置为一直不断的发射。
  32. m_fDuration = kCCParticleDurationInfinity;
  33. // 设置为重力加速模式。
  34. m_nEmitterMode = kCCParticleModeGravity;
  35. // 设置重力加速度的值。
  36. modeA.gravity = ccp(-200,200);
  37. // 设置速度及其用于随机初始化的范围值。
  38. modeA.speed = 15;
  39. modeA.speedVar = 5;
  40. // 设置半径变化值及其用于随机初始化的范围值。
  41. modeA.radialAccel = 0;
  42. modeA.radialAccelVar = 0;
  43. // 设置切角变化值及其用于随机初始化的范围值。
  44. modeA.tangentialAccel = 0;
  45. modeA.tangentialAccelVar = 0;
  46. // 设置起始角度及其用于随机初始化的范围值。
  47. m_fAngle = 90;
  48. m_fAngleVar = 360;
  49. //设置发射器的位置及其用于随机初始化的范围值。
  50. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  51. this->setPosition(ccp(winSize.width/2, winSize.height/2));
  52. m_tPosVar = CCPointZero;
  53. // 粒子的生命值及其用于随机初始化的范围值。
  54. m_fLife = 2;
  55. m_fLifeVar = 1;
  56. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  57. m_fStartSize = 60.0f;
  58. m_fStartSizeVar = 10.0f;
  59. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  60. // 发射器的发射速率。
  61. m_fEmissionRate = m_uTotalParticles/m_fLife;
  62. // 起始和结束的粒子颜色。
  63. m_tStartColor.r = 0.2f;
  64. m_tStartColor.g = 0.4f;
  65. m_tStartColor.b = 0.7f;
  66. m_tStartColor.a = 1.0f;
  67. m_tStartColorVar.r = 0.0f;
  68. m_tStartColorVar.g = 0.0f;
  69. m_tStartColorVar.b = 0.2f;
  70. m_tStartColorVar.a = 0.1f;
  71. m_tEndColor.r = 0.0f;
  72. m_tEndColor.g = 0.0f;
  73. m_tEndColor.b = 0.0f;
  74. m_tEndColor.a = 1.0f;
  75. m_tEndColorVar.r = 0.0f;
  76. m_tEndColorVar.g = 0.0f;
  77. m_tEndColorVar.b = 0.0f;
  78. m_tEndColorVar.a = 0.0f;
  79. // 设置为加亮模式。
  80. this->setBlendAdditive(true);
  81. return true;
  82. }
  83. return false;
  84. }
源码打印?
  1. //由粒子系统基类派生出CCParticleSpiral,表现的是螺旋线
  2. class CC_DLL CCParticleSpiral : public CCParticleSystemQuad
  3. {
  4. public:
  5. //函数注释同上面的类,不再赘述。
  6. CCParticleSpiral(){}
  7. virtual ~CCParticleSpiral(){}
  8. bool init(){ return initWithTotalParticles(500); }
  9. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  10. static CCParticleSpiral * node()
  11. {
  12. return create();
  13. }
  14. static CCParticleSpiral * create()
  15. {
  16. CCParticleSpiral *pRet = new CCParticleSpiral();
  17. if (pRet->init())
  18. {
  19. pRet->autorelease();
  20. return pRet;
  21. }
  22. CC_SAFE_DELETE(pRet);
  23. return NULL;
  24. }
  25. };
  26. 对应CPP:
  27. //创建相应数量的粒子。
  28. bool CCParticleSpiral::initWithTotalParticles(unsigned int numberOfParticles)
  29. {
  30. //调用基类的相应函数。
  31. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  32. {
  33. // 设置为一直不断的发射。
  34. m_fDuration = kCCParticleDurationInfinity;
  35. // 设置为重力加速模式。
  36. m_nEmitterMode = kCCParticleModeGravity;
  37. // 设置重力加速度的值。
  38. modeA.gravity = ccp(0,0);
  39. // 设置速度及其用于随机初始化的范围值。
  40. modeA.speed = 150;
  41. modeA.speedVar = 0;
  42. // 设置半径变化值及其用于随机初始化的范围值。
  43. modeA.radialAccel = -380;
  44. modeA.radialAccelVar = 0;
  45. // 设置切角变化值及其用于随机初始化的范围值。
  46. modeA.tangentialAccel = 45;
  47. modeA.tangentialAccelVar = 0;
  48. // 设置起始角度及其用于随机初始化的范围值。
  49. m_fAngle = 90;
  50. m_fAngleVar = 0;
  51. //设置发射器的位置及其用于随机初始化的范围值。
  52. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  53. this->setPosition(ccp(winSize.width/2, winSize.height/2));
  54. m_tPosVar = CCPointZero;
  55. // 粒子的生命值及其用于随机初始化的范围值。
  56. m_fLife = 12;
  57. m_fLifeVar = 0;
  58. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  59. m_fStartSize = 20.0f;
  60. m_fStartSizeVar = 0.0f;
  61. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  62. // 发射器的发射速率。
  63. m_fEmissionRate = m_uTotalParticles/m_fLife;
  64. // 起始和结束的粒子颜色。
  65. m_tStartColor.r = 0.5f;
  66. m_tStartColor.g = 0.5f;
  67. m_tStartColor.b = 0.5f;
  68. m_tStartColor.a = 1.0f;
  69. m_tStartColorVar.r = 0.5f;
  70. m_tStartColorVar.g = 0.5f;
  71. m_tStartColorVar.b = 0.5f;
  72. m_tStartColorVar.a = 0.0f;
  73. m_tEndColor.r = 0.5f;
  74. m_tEndColor.g = 0.5f;
  75. m_tEndColor.b = 0.5f;
  76. m_tEndColor.a = 1.0f;
  77. m_tEndColorVar.r = 0.5f;
  78. m_tEndColorVar.g = 0.5f;
  79. m_tEndColorVar.b = 0.5f;
  80. m_tEndColorVar.a = 0.0f;
  81. // 设置不使用加亮模式。
  82. this->setBlendAdditive(false);
  83. return true;
  84. }
  85. return false;
  86. }
源码打印?
  1. //由粒子系统基类派生出CCParticleExplosion,表现的是爆炸
  2. class CC_DLL CCParticleExplosion : public CCParticleSystemQuad
  3. {
  4. public:
  5. //函数注释同上面的类,不再赘述。
  6. CCParticleExplosion(){}
  7. virtual ~CCParticleExplosion(){}
  8. bool init(){ return initWithTotalParticles(700); }
  9. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  10. static CCParticleExplosion * node()
  11. {
  12. return create();
  13. }
  14. static CCParticleExplosion * create()
  15. {
  16. CCParticleExplosion *pRet = new CCParticleExplosion();
  17. if (pRet->init())
  18. {
  19. pRet->autorelease();
  20. return pRet;
  21. }
  22. CC_SAFE_DELETE(pRet);
  23. return NULL;
  24. }
  25. };
  26. 对应CPP:
  27. //创建相应数量的粒子。
  28. bool CCParticleExplosion::initWithTotalParticles(unsigned int numberOfParticles)
  29. {
  30. //调用基类的相应函数。
  31. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  32. {
  33. // 设置为一直不断的发射。
  34. m_fDuration = 0.1f;
  35. // 设置为重力加速模式。
  36. m_nEmitterMode = kCCParticleModeGravity;
  37. // 设置重力加速度的值。
  38. modeA.gravity = ccp(0,0);
  39. // 设置速度及其用于随机初始化的范围值。
  40. modeA.speed = 70;
  41. modeA.speedVar = 40;
  42. // 设置半径变化值及其用于随机初始化的范围值。
  43. modeA.radialAccel = 0;
  44. modeA.radialAccelVar = 0;
  45. // 设置切角变化值及其用于随机初始化的范围值。
  46. modeA.tangentialAccel = 0;
  47. modeA.tangentialAccelVar = 0;
  48. // 设置起始角度及其用于随机初始化的范围值。
  49. m_fAngle = 90;
  50. m_fAngleVar = 360;
  51. //设置发射器的位置及其用于随机初始化的范围值。
  52. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  53. this->setPosition(ccp(winSize.width/2, winSize.height/2));
  54. m_tPosVar = CCPointZero;
  55. // 粒子的生命值及其用于随机初始化的范围值。
  56. m_fLife = 5.0f;
  57. m_fLifeVar = 2;
  58. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  59. m_fStartSize = 15.0f;
  60. m_fStartSizeVar = 10.0f;
  61. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  62. // 发射器的发射速率。
  63. m_fEmissionRate = m_uTotalParticles/m_fDuration;
  64. // 起始和结束的粒子颜色。
  65. m_tStartColor.r = 0.7f;
  66. m_tStartColor.g = 0.1f;
  67. m_tStartColor.b = 0.2f;
  68. m_tStartColor.a = 1.0f;
  69. m_tStartColorVar.r = 0.5f;
  70. m_tStartColorVar.g = 0.5f;
  71. m_tStartColorVar.b = 0.5f;
  72. m_tStartColorVar.a = 0.0f;
  73. m_tEndColor.r = 0.5f;
  74. m_tEndColor.g = 0.5f;
  75. m_tEndColor.b = 0.5f;
  76. m_tEndColor.a = 0.0f;
  77. m_tEndColorVar.r = 0.5f;
  78. m_tEndColorVar.g = 0.5f;
  79. m_tEndColorVar.b = 0.5f;
  80. m_tEndColorVar.a = 0.0f;
  81. // 设置不使用加亮模式。
  82. this->setBlendAdditive(false);
  83. return true;
  84. }
  85. return false;
  86. }
源码打印?
  1. //由粒子系统基类派生出CCParticleSmoke,表现的是烟雾
  2. class CC_DLL CCParticleSmoke : public CCParticleSystemQuad
  3. {
  4. public:
  5. //函数注释同上面的类,不再赘述。
  6. CCParticleSmoke(){}
  7. virtual ~CCParticleSmoke(){}
  8. bool init(){ return initWithTotalParticles(200); }
  9. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  10. static CCParticleSmoke * node()
  11. {
  12. return create();
  13. }
  14. static CCParticleSmoke * create()
  15. {
  16. CCParticleSmoke *pRet = new CCParticleSmoke();
  17. if (pRet->init())
  18. {
  19. pRet->autorelease();
  20. return pRet;
  21. }
  22. CC_SAFE_DELETE(pRet);
  23. return NULL;
  24. }
  25. };
  26. 对应CPP:
  27. //创建相应数量的粒子。
  28. bool CCParticleSmoke::initWithTotalParticles(unsigned int numberOfParticles)
  29. {
  30. //调用基类的相应函数。
  31. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  32. {
  33. // 设置为一直不断的发射。
  34. m_fDuration = kCCParticleDurationInfinity;
  35. // 设置为重力加速模式。
  36. m_nEmitterMode = kCCParticleModeGravity;
  37. // 设置重力加速度的值。
  38. modeA.gravity = ccp(0,0);
  39. // 设置半径变化值及其用于随机初始化的范围值。
  40. modeA.radialAccel = 0;
  41. modeA.radialAccelVar = 0;
  42. // 设置速度及其用于随机初始化的范围值。
  43. modeA.speed = 25;
  44. modeA.speedVar = 10;
  45. // 设置起始角度及其用于随机初始化的范围值。
  46. m_fAngle = 90;
  47. m_fAngleVar = 5;
  48. //设置发射器的位置及其用于随机初始化的范围值。
  49. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  50. this->setPosition(ccp(winSize.width/2, 0));
  51. m_tPosVar = ccp(20, 0);
  52. // 粒子的生命值及其用于随机初始化的范围值。
  53. m_fLife = 4;
  54. m_fLifeVar = 1;
  55. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  56. m_fStartSize = 60.0f;
  57. m_fStartSizeVar = 10.0f;
  58. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  59. // 发射器的发射速率。
  60. m_fEmissionRate = m_uTotalParticles/m_fLife;
  61. // 起始和结束的粒子颜色。
  62. m_tStartColor.r = 0.8f;
  63. m_tStartColor.g = 0.8f;
  64. m_tStartColor.b = 0.8f;
  65. m_tStartColor.a = 1.0f;
  66. m_tStartColorVar.r = 0.02f;
  67. m_tStartColorVar.g = 0.02f;
  68. m_tStartColorVar.b = 0.02f;
  69. m_tStartColorVar.a = 0.0f;
  70. m_tEndColor.r = 0.0f;
  71. m_tEndColor.g = 0.0f;
  72. m_tEndColor.b = 0.0f;
  73. m_tEndColor.a = 1.0f;
  74. m_tEndColorVar.r = 0.0f;
  75. m_tEndColorVar.g = 0.0f;
  76. m_tEndColorVar.b = 0.0f;
  77. m_tEndColorVar.a = 0.0f;
  78. // 设置不使用加亮模式。
  79. this->setBlendAdditive(false);
  80. return true;
  81. }
  82. return false;
  83. }
源码打印?
  1. //由粒子系统基类派生出CCParticleSnow,表现的是雪
  2. class CC_DLL CCParticleSnow : public CCParticleSystemQuad
  3. {
  4. public:
  5. //函数注释同上面的类,不再赘述。
  6. CCParticleSnow(){}
  7. virtual ~CCParticleSnow(){}
  8. bool init(){ return initWithTotalParticles(700); }
  9. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  10. static CCParticleSnow * node()
  11. {
  12. return create();
  13. }
  14. static CCParticleSnow * create()
  15. {
  16. CCParticleSnow *pRet = new CCParticleSnow();
  17. if (pRet->init())
  18. {
  19. pRet->autorelease();
  20. return pRet;
  21. }
  22. CC_SAFE_DELETE(pRet);
  23. return NULL;
  24. }
  25. };
  26. 对应CPP:
  27. //创建相应数量的粒子。
  28. bool CCParticleSnow::initWithTotalParticles(unsigned int numberOfParticles)
  29. {
  30. //调用基类的相应函数。
  31. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  32. {
  33. // 设置为一直不断的发射。
  34. m_fDuration = kCCParticleDurationInfinity;
  35. // 设置为重力加速模式。
  36. m_nEmitterMode = kCCParticleModeGravity;
  37. // 设置重力加速度的值。
  38. modeA.gravity = ccp(0,-1);
  39. // 设置速度及其用于随机初始化的范围值。
  40. modeA.speed = 5;
  41. modeA.speedVar = 1;
  42. // 设置半径变化值及其用于随机初始化的范围值。
  43. modeA.radialAccel = 0;
  44. modeA.radialAccelVar = 1;
  45. // 设置切角变化值及其用于随机初始化的范围值。
  46. modeA.tangentialAccel = 0;
  47. modeA.tangentialAccelVar = 1;
  48. //设置发射器的位置及其用于随机初始化的范围值。
  49. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  50. this->setPosition(ccp(winSize.width/2, winSize.height + 10));
  51. m_tPosVar = ccp( winSize.width/2, 0 );
  52. // 设置起始角度及其用于随机初始化的范围值。
  53. m_fAngle = -90;
  54. m_fAngleVar = 5;
  55. // 粒子的生命值及其用于随机初始化的范围值。
  56. m_fLife = 45;
  57. m_fLifeVar = 15;
  58. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  59. m_fStartSize = 10.0f;
  60. m_fStartSizeVar = 5.0f;
  61. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  62. // 发射器的发射速率。
  63. m_fEmissionRate = 10;
  64. // 起始和结束的粒子颜色。
  65. m_tStartColor.r = 1.0f;
  66. m_tStartColor.g = 1.0f;
  67. m_tStartColor.b = 1.0f;
  68. m_tStartColor.a = 1.0f;
  69. m_tStartColorVar.r = 0.0f;
  70. m_tStartColorVar.g = 0.0f;
  71. m_tStartColorVar.b = 0.0f;
  72. m_tStartColorVar.a = 0.0f;
  73. m_tEndColor.r = 1.0f;
  74. m_tEndColor.g = 1.0f;
  75. m_tEndColor.b = 1.0f;
  76. m_tEndColor.a = 0.0f;
  77. m_tEndColorVar.r = 0.0f;
  78. m_tEndColorVar.g = 0.0f;
  79. m_tEndColorVar.b = 0.0f;
  80. m_tEndColorVar.a = 0.0f;
  81. // 设置不使用加亮模式。
  82. this->setBlendAdditive(false);
  83. return true;
  84. }
  85. return false;
  86. }
源码打印?
  1. //由粒子系统基类派生出CCParticleRain,表现的是雨
  2. class CC_DLL CCParticleRain : public CCParticleSystemQuad
  3. {
  4. public:
  5. //函数注释同上面的类,不再赘述。
  6. CCParticleRain(){}
  7. virtual ~CCParticleRain(){}
  8. bool init(){ return initWithTotalParticles(1000); }
  9. virtual bool initWithTotalParticles(unsigned int numberOfParticles);
  10. static CCParticleRain * node()
  11. {
  12. return create();
  13. }
  14. static CCParticleRain * create()
  15. {
  16. CCParticleRain *pRet = new CCParticleRain();
  17. if (pRet->init())
  18. {
  19. pRet->autorelease();
  20. return pRet;
  21. }
  22. CC_SAFE_DELETE(pRet);
  23. return NULL;
  24. }
  25. };
  26. 对应CPP:
  27. //创建相应数量的粒子。
  28. bool CCParticleRain::initWithTotalParticles(unsigned int numberOfParticles)
  29. {
  30. //调用基类的相应函数。
  31. if( CCParticleSystemQuad::initWithTotalParticles(numberOfParticles) )
  32. {
  33. // 设置为一直不断的发射。
  34. m_fDuration = kCCParticleDurationInfinity;
  35. // 设置为重力加速模式。
  36. m_nEmitterMode = kCCParticleModeGravity;
  37. // 设置重力加速度的值。
  38. modeA.gravity = ccp(10,-10);
  39. // 设置半径变化值及其用于随机初始化的范围值。
  40. modeA.radialAccel = 0;
  41. modeA.radialAccelVar = 1;
  42. // 设置切角变化值及其用于随机初始化的范围值。
  43. modeA.tangentialAccel = 0;
  44. modeA.tangentialAccelVar = 1;
  45. // 设置速度及其用于随机初始化的范围值。
  46. modeA.speed = 130;
  47. modeA.speedVar = 30;
  48. // 设置起始角度及其用于随机初始化的范围值。
  49. m_fAngle = -90;
  50. m_fAngleVar = 5;
  51. //设置发射器的位置及其用于随机初始化的范围值。
  52. CCSize winSize = CCDirector::sharedDirector()->getWinSize();
  53. this->setPosition(ccp(winSize.width/2, winSize.height));
  54. m_tPosVar = ccp( winSize.width/2, 0 );
  55. // 粒子的生命值及其用于随机初始化的范围值。
  56. m_fLife = 4.5f;
  57. m_fLifeVar = 0;
  58. //起始大小及其用于随机初始化的范围值,终止大小指定与起始大小相同,即在更新时不变化。
  59. m_fStartSize = 4.0f;
  60. m_fStartSizeVar = 2.0f;
  61. m_fEndSize = kCCParticleStartSizeEqualToEndSize;
  62. // 发射器的发射速率。
  63. m_fEmissionRate = 20;
  64. // 起始和结束的粒子颜色。
  65. m_tStartColor.r = 0.7f;
  66. m_tStartColor.g = 0.8f;
  67. m_tStartColor.b = 1.0f;
  68. m_tStartColor.a = 1.0f;
  69. m_tStartColorVar.r = 0.0f;
  70. m_tStartColorVar.g = 0.0f;
  71. m_tStartColorVar.b = 0.0f;
  72. m_tStartColorVar.a = 0.0f;
  73. m_tEndColor.r = 0.7f;
  74. m_tEndColor.g = 0.8f;
  75. m_tEndColor.b = 1.0f;
  76. m_tEndColor.a = 0.5f;
  77. m_tEndColorVar.r = 0.0f;
  78. m_tEndColorVar.g = 0.0f;
  79. m_tEndColorVar.b = 0.0f;
  80. m_tEndColorVar.a = 0.0f;
  81. // 设置不使用加亮模式。
  82. this->setBlendAdditive(false);
  83. return true;
  84. }
  85. return false;
  86. }

CCParticleExample.h中都是典型的粒子系统的表现类。我们可以清楚的看到,粒子系统的基类已经将这些典型的粒子系统所需要的属性一一包含,想要使用粒子系统摸拟自然现象,所需要做的就是通过对其具有的粒子属性进行相应的设置,仅此而已。

在ParticleTest中,共有42个粒子系统的展示,它们均是基于ParticleDemo这个类进行派生实现的, ParticleDemo是基于CCLayerColor所派生的一个类,实现了对于粒子系统演示的管理控制,下面我们来看一下头文件:

源码打印?
  1. //粒子系统演示所用的场景
  2. class ParticleTestScene : public TestScene
  3. {
  4. public:
  5. //运行当前场景
  6. virtual void runThisTest();
  7. };
  8. //可见本实例中的粒子系统演示,是以层的形式来表现的。
  9. class ParticleDemo : public CCLayerColor
  10. {
  11. protected:
  12. //每一个粒子系统演示中,都有一个粒子系统的指针。
  13. CCParticleSystem*    m_emitter;
  14. //背景图精灵
  15. CCSprite*            m_background;
  16. public:
  17. //析构
  18. ~ParticleDemo(void);
  19. //加载当前粒子系统演示层时调用的函数。
  20. virtual void onEnter(void);
  21. //取得标题和幅标题。
  22. virtual std::string title();
  23. virtual std::string subtitle();
  24. //响应当前演示层的一些菜单触发事件,以便演示的控制。
  25. //重新演示当前的粒子系统。
  26. void restartCallback(CCObject* pSender);
  27. //进行下一个粒子系统的演示。
  28. void nextCallback(CCObject* pSender);
  29. //进行上一个粒子系统的演示。
  30. void backCallback(CCObject* pSender);
  31. //用于响应切换粒子系统的运动影响方式。
  32. void toggleCallback(CCObject* pSender);
  33. //注册触屏所要响应的事件。
  34. virtual void registerWithTouchDispatcher();
  35. //当有触点按下时响应的函数。
  36. virtual bool ccTouchBegan(CCTouch* touch, CCEvent* event);
  37. //当有触点按下并移动时响应的函数。
  38. virtual void ccTouchMoved(CCTouch* touch, CCEvent* event);
  39. //当有触点松下时响应的函数。
  40. virtual void ccTouchEnded(CCTouch* touch, CCEvent* event);
  41. //更新时的处理
  42. virtual void update(float dt);
  43. //初始化粒子发射器的位置。
  44. void setEmitterPosition();
  45. };
  46. //演示表现烟火的粒子系统,由基类ParticleDemo派生。
  47. class DemoFirework : public ParticleDemo
  48. {
  49. public:
  50. virtual void onEnter();
  51. virtual std::string title();
  52. };
  53. //演示表现火焰的粒子系统,由基类ParticleDemo派生。
  54. class DemoFire : public ParticleDemo
  55. {
  56. public:
  57. virtual void onEnter();
  58. virtual std::string title();
  59. };
  60. 后面雷同不再赘述…

看上面的代码,很容易理解,每个粒子系统的演示都是一个层,创建一个场景用来管理这些演示层。在CPP中,我们可以找到以下函数的实现。

源码打印?
  1. //场景运行时调用的函数处理。
  2. void ParticleTestScene::runThisTest()
  3. {
  4. //创建下一个粒子系统的演示层,放入当前场景。
  5. addChild(nextParticleAction());
  6. //调用设备的更新场景函数,运行当前场景。
  7. CCDirector::sharedDirector()->replaceScene(this);
  8. }

CPP中有三个函数,分别是运行下一个粒子系统的演示,运行上一个粒子系统的演示,重新进行当前粒子系统的演示。

源码打印?
  1. //下一个粒子系统的演示
  2. CCLayer* nextParticleAction()
  3. {
  4. //演示的索引加一并对最大演示数量取模防止出现无效值。
  5. sceneIdx++;
  6. sceneIdx = sceneIdx % MAX_LAYER;
  7. //由索引创建相应的粒子系统的演示层并设为由存管理器进行引用计数器的管理。
  8. CCLayer* pLayer = createParticleLayer(sceneIdx);
  9. pLayer->autorelease();
  10. return pLayer;
  11. }
  12. //上一个粒子系统的演示
  13. CCLayer* backParticleAction()
  14. {
  15. //演示的索引减一进行无效值处理。
  16. sceneIdx--;
  17. int total = MAX_LAYER;
  18. if( sceneIdx < 0 )
  19. sceneIdx += total;
  20. //由索引创建相应的粒子系统的演示层并设为由存管理器进行引用计数器的管理。
  21. CCLayer* pLayer = createParticleLayer(sceneIdx);
  22. pLayer->autorelease();
  23. return pLayer;
  24. }
  25. //重新创建当前的粒子系统的演示层。
  26. CCLayer* restartParticleAction()
  27. {
  28. //由索引创建相应的粒子系统的演示层并设为由存管理器进行引用计数器的管理。
  29. CCLayer* pLayer = createParticleLayer(sceneIdx);
  30. pLayer->autorelease();
  31. return pLayer;
  32. }

可以看到,就如TestCpp类似的管理方案,所有的演示都会放在createParticleLayer中,通过索引来进行相应的控制管理。

源码打印?
  1. //没错,就是这样。
  2. CCLayer* createParticleLayer(int nIndex)
  3. {
  4. switch(nIndex)
  5. {
  6. case 0: return new ParticleReorder();
  7. case 1: return new ParticleBatchHybrid();
  8. case 2: return new ParticleBatchMultipleEmitters();
  9. case 3: return new DemoFlower();
  10. case 4: return new DemoGalaxy();
  11. case 5: return new DemoFirework();
  12. case 6: return new DemoSpiral();
  13. case 7: return new DemoSun();
  14. case 8: return new DemoMeteor();
  15. case 9: return new DemoFire();
  16. case 10: return new DemoSmoke();
  17. case 11: return new DemoExplosion();
  18. case 12: return new DemoSnow();
  19. case 13: return new DemoRain();
  20. case 14: return new DemoBigFlower();
  21. case 15: return new DemoRotFlower();
  22. case 16: return new DemoModernArt();
  23. case 17: return new DemoRing();
  24. case 18: return new ParallaxParticle();
  25. case 19: return new DemoParticleFromFile("BoilingFoam");
  26. case 20: return new DemoParticleFromFile("BurstPipe");
  27. case 21: return new DemoParticleFromFile("Comet");
  28. case 22: return new DemoParticleFromFile("debian");
  29. case 23: return new DemoParticleFromFile("ExplodingRing");
  30. case 24: return new DemoParticleFromFile("LavaFlow");
  31. case 25: return new DemoParticleFromFile("SpinningPeas");
  32. case 26: return new DemoParticleFromFile("SpookyPeas");
  33. case 27: return new DemoParticleFromFile("Upsidedown");
  34. case 28: return new DemoParticleFromFile("Flower");
  35. case 29: return new DemoParticleFromFile("Spiral");
  36. case 30: return new DemoParticleFromFile("Galaxy");
  37. case 31: return new DemoParticleFromFile("Phoenix");
  38. case 32: return new RadiusMode1();
  39. case 33: return new RadiusMode2();
  40. case 34: return new Issue704();
  41. case 35: return new Issue870();
  42. case 36: return new Issue1201();
  43. // v1.1 tests
  44. case 37: return new MultipleParticleSystems();
  45. case 38: return new MultipleParticleSystemsBatched();
  46. case 39: return new AddAndDeleteParticleSystems();
  47. case 40: return new ReorderParticleSystems();
  48. case 41: return new PremultipliedAlphaTest();
  49. case 42: return new PremultipliedAlphaTest2();
  50. default:
  51. break;
  52. }
  53. return NULL;
  54. }

然后是演示粒子效果所用的层的基类ParticleDemo:

源码打印?
  1. //析构函数。
  2. ParticleDemo::~ParticleDemo(void)
  3. {
  4. //释放粒子系统。
  5. CC_SAFE_RELEASE(m_emitter);
  6. }
  7. //加载当前层时调用的函数。
  8. void ParticleDemo::onEnter(void)
  9. {
  10. //调用基类的相应函数。
  11. CCLayer::onEnter();
  12. //初始化背景色。
  13. initWithColor( ccc4(127,127,127,255) );
  14. //粒子系统置空。
  15. m_emitter = NULL;
  16. //设置接受触屏消息。
  17. setTouchEnabled( true );
  18. //取得屏幕大小。
  19. CCSize s = CCDirector::sharedDirector()->getWinSize();
  20. //创建主标题文字标签并放到当前层中的相应位置。
  21. CCLabelTTF* label = CCLabelTTF::create(title().c_str(), "Arial", 28);
  22. addChild(label, 100, 1000);
  23. label->setPosition( CCPointMake(s.width/2, s.height-50) );
  24. //创建幅标题文字标签并放到当前层中的相应位置。
  25. CCLabelTTF *sub = CCLabelTTF::create(subtitle().c_str(), "Arial", 16);
  26. addChild(sub, 100);
  27. sub->setPosition(CCPointMake(s.width/2, s.height-80));
  28. //创建菜单按钮用于控制演示。
  29. CCMenuItemImage* item1 = CCMenuItemImage::create(s_pPathB1, s_pPathB2, this, menu_selector(ParticleDemo::backCallback) );
  30. CCMenuItemImage* item2 = CCMenuItemImage::create(s_pPathR1, s_pPathR2, this, menu_selector(ParticleDemo::restartCallback) );
  31. CCMenuItemImage* item3 = CCMenuItemImage::create(s_pPathF1, s_pPathF2,  this, menu_selector(ParticleDemo::nextCallback) );
  32. //创建一个菜单按钮用于切换运动时的受影响类型,响应函数为ParticleDemo::toggleCallback。
  33. CCMenuItemToggle* item4 = CCMenuItemToggle::createWithTarget(this,
  34. menu_selector(ParticleDemo::toggleCallback),
  35. CCMenuItemFont::create( "Free Movement" ),
  36. CCMenuItemFont::create( "Relative Movement" ),
  37. CCMenuItemFont::create( "Grouped Movement" ),
  38. NULL );
  39. //创建菜单。
  40. CCMenu *menu = CCMenu::create(item1, item2, item3, item4, NULL);
  41. //设置各菜单按钮的位置。
  42. menu->setPosition( CCPointZero );
  43. item1->setPosition( ccp( s.width/2 - item2->getContentSize().width*2, item2->getContentSize().height/2) );
  44. item2->setPosition( ccp( s.width/2, item2->getContentSize().height/2) );
  45. item3->setPosition( ccp( s.width/2 + item2->getContentSize().width*2, item2->getContentSize().height/2) );
  46. item4->setPosition( ccp( 0, 100) );
  47. item4->setAnchorPoint( ccp(0,0) );
  48. //将菜单放入当前层中。
  49. addChild( menu, 100 );
  50. //创建一个文字标签显示FPS
  51. CCLabelAtlas* labelAtlas = CCLabelAtlas::create("0000", "fps_images.png", 12, 32, '.');
  52. addChild(labelAtlas, 100, kTagParticleCount);
  53. labelAtlas->setPosition(ccp(s.width-66,50));
  54. //创建背景图精灵并放在当前层的相应位置。
  55. m_background = CCSprite::create(s_back3);
  56. addChild(m_background, 5);
  57. m_background->setPosition( ccp(s.width/2, s.height-180) );
  58. //创建移动动画以及反向动画。
  59. CCActionInterval* move = CCMoveBy::create(4, ccp(300,0) );
  60. CCActionInterval* move_back = move->reverse();
  61. //将两个动画放到一个动画序列中。
  62. CCFiniteTimeAction* seq = CCSequence::create( move, move_back, NULL);
  63. //让背景图精录无限循环执行这个动画序列。
  64. m_background->runAction( CCRepeatForever::create((CCActionInterval*)seq) );
  65. //让当前层响应Update函数。
  66. scheduleUpdate();
  67. //取得主标题并设置显示文字串。
  68. CCLabelTTF* pLabel = (CCLabelTTF*)(this->getChildByTag(1000));
  69. pLabel->setString(title().c_str());
  70. }
  71. //取得主标题。
  72. std::string ParticleDemo::title()
  73. {
  74. return "No title";
  75. }
  76. //取得幅标题。
  77. std::string ParticleDemo::subtitle()
  78. {
  79. return "No titile";
  80. }
  81. //开启触屏消息响应。
  82. void ParticleDemo::registerWithTouchDispatcher()
  83. {
  84. CCDirector* pDirector = CCDirector::sharedDirector();
  85. pDirector->getTouchDispatcher()->addTargetedDelegate(this, 0, false);
  86. }
  87. //当手指按下屏幕时
  88. bool ParticleDemo::ccTouchBegan(CCTouch* touch, CCEvent* event)
  89. {
  90. return true;
  91. }
  92. //当手指在按下屏幕状态并滑动时响应。
  93. void ParticleDemo::ccTouchMoved(CCTouch* touch, CCEvent* event)
  94. {
  95. return ccTouchEnded(touch, event);
  96. }
  97. //当手指从按下状态抬起时响应。
  98. void ParticleDemo::ccTouchEnded(CCTouch* touch, CCEvent* event)
  99. {
  100. //取得按下的屏幕位置
  101. CCPoint location = touch->getLocation();
  102. //创建临时变量取得背景精灵的位置。
  103. CCPoint pos = CCPointZero;
  104. if (m_background)
  105. {
  106. pos = m_background->convertToWorldSpace(CCPointZero);
  107. }
  108. //如果粒子系统发射器有效,设置其位置为触点位置减去背景精零的零点世界位置(即当前层的左下角世界位置),因为粒子系统是当前层的子结点,所以ccpSub(location, pos)结果即为触点与当前层的相对位置。。
  109. if (m_emitter != NULL)
  110. {
  111. m_emitter->setPosition( ccpSub(location, pos) );
  112. }
  113. }
  114. //更新函数。
  115. void ParticleDemo::update(float dt)
  116. {
  117. //显示粒子的数量。
  118. if (m_emitter)
  119. {
  120. CCLabelAtlas* atlas = (CCLabelAtlas*)getChildByTag(kTagParticleCount);
  121. char str[5] = {0};
  122. sprintf(str, "%04d", m_emitter->getParticleCount());
  123. atlas->setString(str);
  124. }
  125. }
  126. //点击切换粒子系统的运动影响方式时的响应函数。
  127. void ParticleDemo::toggleCallback(CCObject* pSender)
  128. {
  129. //根据当前粒子系统运动影响方式类型,切换到下一种枚举的运动影响方式类型。
  130. if (m_emitter != NULL)
  131. {
  132. if( m_emitter->getPositionType() == kCCPositionTypeGrouped )
  133. m_emitter->setPositionType( kCCPositionTypeFree );
  134. else if (m_emitter->getPositionType() == kCCPositionTypeFree)
  135. m_emitter->setPositionType(kCCPositionTypeRelative);
  136. else if (m_emitter->getPositionType() == kCCPositionTypeRelative)
  137. m_emitter->setPositionType( kCCPositionTypeGrouped );
  138. }
  139. }
  140. //重新启动当前的粒子系统。
  141. void ParticleDemo::restartCallback(CCObject* pSender)
  142. {
  143. if (m_emitter != NULL)
  144. {
  145. m_emitter->resetSystem();
  146. }
  147. }
  148. //切换到下一个粒子系统演示。
  149. void ParticleDemo::nextCallback(CCObject* pSender)
  150. {
  151. CCScene* s = new ParticleTestScene();
  152. s->addChild( nextParticleAction() );
  153. CCDirector::sharedDirector()->replaceScene(s);
  154. s->release();
  155. }
  156. //返回上一个粒子系统的演示。
  157. void ParticleDemo::backCallback(CCObject* pSender)
  158. {
  159. CCScene* s = new ParticleTestScene();
  160. s->addChild( backParticleAction() );
  161. CCDirector::sharedDirector()->replaceScene(s);
  162. s->release();
  163. }
  164. //设置粒子系统发射器的位置为屏幕中心位置。
  165. void ParticleDemo::setEmitterPosition()
  166. {
  167. CCSize s = CCDirector::sharedDirector()->getWinSize();
  168. if (m_emitter != NULL)
  169. {
  170. m_emitter->setPosition( CCPointMake(s.width / 2, s.height / 2) );
  171. }
  172. }

OK,这个基类搞定后,下面我们来一一把本演示DEMO中的演示实例进行解释:

(1)    ParticleReorder

描述:

粒子系统的排序。每秒对粒子系统进行一个不同的显示顺序的设定。

截图:

源码解析:

源码打印?
  1. //当前层加载时的处理。
  2. void ParticleReorder::onEnter()
  3. {
  4. //调用基类的相应初始化函数。
  5. ParticleDemo::onEnter();
  6. //
  7. m_nOrder = 0;
  8. //设置层背景色为黑色。
  9. setColor(ccBLACK);
  10. //将背景精灵移除并置空
  11. removeChild(m_background, true);
  12. m_background = NULL;
  13. //从SmallSun.plist中加载创建一个粒子系统。
  14. CCParticleSystem* ignore = CCParticleSystemQuad::create("Particles/SmallSun.plist");
  15. //创建第一个父结点。
  16. CCNode *parent1 = CCNode::create();
  17. //由粒子系统取出的纹理对象创建一个粒子批次结点做为第二个父结点。
  18. CCNode *parent2 = CCParticleBatchNode::createWithTexture(ignore->getTexture());
  19. //粒子系统不调用Update函数。
  20. ignore->unscheduleUpdate();
  21. //
  22. for( unsigned int i=0; i<2;i++)
  23. {
  24. //循环两次,第一次parent取parent1,第二次取parent2。
  25. CCNode *parent = ( i==0 ? parent1 : parent2 );
  26. //由SmallSun.plist文件创建第一个粒子系统。
  27. CCParticleSystemQuad *emitter1 = CCParticleSystemQuad::create("Particles/SmallSun.plist");
  28. //设置粒子系统的粒子的起始颜色。
  29. emitter1->setStartColor(ccc4f(1,0,0,1));
  30. //设置粒子系统不使用加亮模式。
  31. emitter1->setBlendAdditive(false);
  32. //由SmallSun.plist文件创建第二个粒子系统。
  33. CCParticleSystemQuad *emitter2 = CCParticleSystemQuad::create("Particles/SmallSun.plist");
  34. //设置粒子系统的粒子的起始颜色。
  35. emitter2->setStartColor(ccc4f(0,1,0,1));
  36. //设置粒子系统不使用加亮模式。
  37. emitter2->setBlendAdditive(false);
  38. //由SmallSun.plist文件创建第三个粒子系统。
  39. CCParticleSystemQuad *emitter3 = CCParticleSystemQuad::create("Particles/SmallSun.plist");
  40. //设置粒子系统的粒子的起始颜色。
  41. emitter3->setStartColor(ccc4f(0,0,1,1));
  42. //设置粒子系统不使用加亮模式。
  43. emitter3->setBlendAdditive(false);
  44. //取得屏幕大小。
  45. CCSize s = CCDirector::sharedDirector()->getWinSize();
  46. //根据遍历计数器值设定一个位置影响参数。
  47. int neg = (i==0 ? 1 : -1 );
  48. //设置三个粒子系统的位置。
  49. emitter1->setPosition(ccp( s.width/2-30,    s.height/2+60*neg));
  50. emitter2->setPosition(ccp( s.width/2,        s.height/2+60*neg));
  51. emitter3->setPosition(ccp( s.width/2+30,    s.height/2+60*neg));
  52. //将三个粒子系统放入相应的父结点。
  53. parent->addChild(emitter1, 0, 1);
  54. parent->addChild(emitter2, 0, 2);
  55. parent->addChild(emitter3, 0, 3);
  56. //将父结点做为子结点放入当前层。
  57. addChild(parent, 10, 1000+i);
  58. }
  59. //定时器每秒响应一次ParticleReorder::reorderParticles函数。
  60. schedule(schedule_selector(ParticleReorder::reorderParticles), 1.0f);
  61. }
  62. //取得标题。
  63. std::string ParticleReorder::title()
  64. {
  65. return "Reordering particles";
  66. }
  67. //取得幅标题。
  68. std::string ParticleReorder::subtitle()
  69. {
  70. return "Reordering particles with and without batches batches";
  71. }
  72. //每秒响应的回调函数。
  73. void ParticleReorder::reorderParticles(float dt)
  74. {
  75. for( int i=0; i<2;i++) {
  76. //取得不同的粒子系统父结点。
  77. CCNode *parent = getChildByTag(1000+i);
  78. //取得相应的粒子系统。
  79. CCNode *child1 = parent->getChildByTag(1);
  80. CCNode *child2 = parent->getChildByTag(2);
  81. CCNode *child3 = parent->getChildByTag(3);
  82. //对3取模后设置不同的排序。
  83. if( m_nOrder % 3 == 0 ) {
  84. parent->reorderChild(child1, 1);
  85. parent->reorderChild(child2, 2);
  86. parent->reorderChild(child3, 3);
  87. } else if (m_nOrder % 3 == 1 ) {
  88. parent->reorderChild(child1, 3);
  89. parent->reorderChild(child2, 1);
  90. parent->reorderChild(child3, 2);
  91. } else if (m_nOrder % 3 == 2 ) {
  92. parent->reorderChild(child1, 2);
  93. parent->reorderChild(child2, 3);
  94. parent->reorderChild(child3, 1);
  95. }
  96. }
  97. m_nOrder++;
  98. }

(2)    ParticleBatchHybrid

描述:

表现使用批次结点

截图:

源码分析:

源码打印?
  1. //加载当前层时的处理。
  2. void ParticleBatchHybrid::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //删除背景精灵并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //由LavaFlow.plist文件创建粒子系统。
  12. m_emitter = CCParticleSystemQuad::create("Particles/LavaFlow.plist");
  13. //占用此粒子系统,对其引用计数器加一操作。
  14. m_emitter->retain();
  15. //由粒子系统的纹理对象创建一个粒子批次结点。
  16. CCParticleBatchNode *batch = CCParticleBatchNode::createWithTexture(m_emitter->getTexture());
  17. //将粒子系统加入到粒子批次结点中。
  18. batch->addChild(m_emitter);
  19. //将粒子批次结点加入到当前层中。
  20. addChild(batch, 10);
  21. //每2秒调用一次ParticleBatchHybrid::switchRender函数切换使用批次结点。
  22. schedule(schedule_selector(ParticleBatchHybrid::switchRender), 2.0f);
  23. //创建一个结点做为子结点。
  24. CCNode *node = CCNode::create();
  25. addChild(node);
  26. //第一父结点设为批次结点。
  27. m_pParent1 = batch;
  28. //第二父结点设为上面的子结点。
  29. m_pParent2 = node;
  30. }
  31. //切换使用或不使用批次结点的函数。
  32. void ParticleBatchHybrid::switchRender(float dt)
  33. {
  34. //取得是否使用了批次结点。
  35. bool usingBatch = ( m_emitter->getBatchNode() != NULL );
  36. //从父结点中移除。
  37. m_emitter->removeFromParentAndCleanup(false);
  38. //根据上面的usingBatch来设置不同的父结点,这样就可以让粒子系统进行来回切换了。
  39. CCNode *newParent = (usingBatch ? m_pParent2  : m_pParent1 );
  40. //将粒子系统放入父结点中。
  41. newParent->addChild(m_emitter);
  42. //打印信息
  43. CCLog("Particle: Using new parent: %s", usingBatch ? "CCNode" : "CCParticleBatchNode");
  44. }
  45. //取得标题。
  46. std::string ParticleBatchHybrid::title()
  47. {
  48. return "Paticle Batch";
  49. }
  50. //取得幅标题。
  51. std::string ParticleBatchHybrid::subtitle()
  52. {
  53. return "Hybrid: batched and non batched every 2 seconds";
  54. }

(3)    ParticleBatchMultipleEmitters

描述:

多个粒子系统应用一个批次结点。

截图:

源码分析:

源码打印?
  1. //加载当前层的处理。
  2. void ParticleBatchMultipleEmitters::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //移除背景精灵并将指针置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //创建三个粒子系统,分别设置不同的初始颜色。
  12. CCParticleSystemQuad *emitter1 = CCParticleSystemQuad::create("Particles/LavaFlow.plist");
  13. emitter1->setStartColor(ccc4f(1,0,0,1));
  14. CCParticleSystemQuad *emitter2 = CCParticleSystemQuad::create("Particles/LavaFlow.plist");
  15. emitter2->setStartColor(ccc4f(0,1,0,1));
  16. CCParticleSystemQuad *emitter3 = CCParticleSystemQuad::create("Particles/LavaFlow.plist");
  17. emitter3->setStartColor(ccc4f(0,0,1,1));
  18. //取得屏幕大小
  19. CCSize s = CCDirector::sharedDirector()->getWinSize();
  20. //设置粒子系统的位置。
  21. emitter1->setPosition(ccp( s.width/1.25f, s.height/1.25f));
  22. emitter2->setPosition(ccp( s.width/2, s.height/2));
  23. emitter3->setPosition(ccp( s.width/4, s.height/4));
  24. //由粒子系统的纹理创建相应的批次结点。
  25. CCParticleBatchNode *batch = CCParticleBatchNode::createWithTexture(emitter1->getTexture());
  26. //将粒子系统都放入批次结点中。
  27. batch->addChild(emitter1, 0);
  28. batch->addChild(emitter2, 0);
  29. batch->addChild(emitter3, 0);
  30. //将批次结点放入当前层。
  31. addChild(batch, 10);
  32. }
  33. //标题。
  34. std::string ParticleBatchMultipleEmitters::title()
  35. {
  36. return "Paticle Batch";
  37. }
  38. //幅标题。
  39. std::string ParticleBatchMultipleEmitters::subtitle()
  40. {
  41. return "Multiple emitters. One Batch";
  42. }

(4)    DemoFlower:

描述:

花?不像,倒不如说是星光闪烁。

截图:

源码分析:

源码打印?
  1. //加载当前层时的处理
  2. void DemoFlower::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建粒子系统。
  7. m_emitter = CCParticleFlower::create();
  8. m_emitter->retain();
  9. //将粒子系统放入背景精灵结点下。
  10. m_background->addChild(m_emitter, 10);
  11. //设置粒子系统使用星星的纹理。
  12. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_stars1) );
  13. //调用基类的相应函数将粒子发射器置于屏幕中央。
  14. setEmitterPosition();
  15. }
  16. //取得标题。
  17. std::string DemoFlower::title()
  18. {
  19. return "ParticleFlower";
  20. }<span style="font-weight: bold; ">
  21. </span>

注:这里星星的纹理为: 

这是一个PNG格式的ALPHA渐变图,本身色彩就是由白到黑的一个亮度变化。通过粒子的顶点着色就能出现五彩缤纷的星光了。

(5)    DemoGalaxy

描述:

星系。

截图:

源码分析:

源码打印?
  1. //加载当前层时的处理。
  2. void DemoGalaxy::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleGalaxy类的实例。
  7. m_emitter = CCParticleGalaxy::create();
  8. //占用,则对其使用计数器加一。
  9. m_emitter->retain();
  10. //将粒子系统放入背景结点下。
  11. m_background->addChild(m_emitter, 10);
  12. //加载一个火焰的图片,设置为粒子系统的纹理。
  13. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );
  14. //调用基类的相应函数,设置粒子系统的位置居于屏幕中央。
  15. setEmitterPosition();
  16. }
  17. //取得标题
  18. std::string DemoGalaxy::title()
  19. {
  20. return "ParticleGalaxy";
  21. }<strong>
  22. </strong>

注:这里火焰的纹理为: 

这是一个PNG格式的ALPHA渐变图,本身色彩就是由白到黑的一个亮度变化。通过粒子的顶点着色就能出现五彩的火火焰了。

(6)     DemoFirework

描述:

烟火的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void DemoFirework::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleFireworks类的实例。
  7. m_emitter = CCParticleFireworks::create();
  8. //对其占用,故引用计数器加一操作。
  9. m_emitter->retain();
  10. //将粒子系统加入到背景精灵结点之下
  11. m_background->addChild(m_emitter, 10);
  12. //加载星星的图片做为粒子的纹理。
  13. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_stars1) );
  14. //设置粒子系统居中。
  15. setEmitterPosition();
  16. }
  17. //取得标题。
  18. std::string DemoFirework::title()
  19. {
  20. return "ParticleFireworks";
  21. }

(7)     DemoSpiral

描述:

螺旋线的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层的处理。
  2. void DemoSpiral::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleSpiral类的实例。
  7. m_emitter = CCParticleSpiral::create();
  8. //占用,对其引用计数器加一。
  9. m_emitter->retain();
  10. //将粒子系统放在精灵背景结点之下。
  11. m_background->addChild(m_emitter, 10);
  12. //加载火焰图片设置为粒子系统所用的纹理。
  13. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );
  14. //设置粒子系统发射器的位置居于屏幕中央。
  15. setEmitterPosition();
  16. }
  17. //取得标题。
  18. std::string DemoSpiral::title()
  19. {
  20. return "ParticleSpiral";
  21. }

(8)    DemoSun

描述:

太阳的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void DemoSun::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleSun类的实例
  7. m_emitter = CCParticleSun::create();
  8. //占用粒子系统,对其引用计数器加一。
  9. m_emitter->retain();
  10. //将粒子系统放在背景精灵结点之下。
  11. m_background->addChild(m_emitter, 10);
  12. //加载火焰图片做为粒子系统的纹理。
  13. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );
  14. //设置粒子系统发射器的位置居于屏幕中央。
  15. setEmitterPosition();
  16. }
  17. //取得标题文字。
  18. std::string DemoSun::title()
  19. {
  20. return "ParticleSun";
  21. }

(9)    DemoMeteor:

描述:

流星的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层的处理。
  2. void DemoMeteor::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleMeteor类的实例。
  7. m_emitter = CCParticleMeteor::create();
  8. //占用它,对它的引用计数器加一。
  9. m_emitter->retain();
  10. //将粒子系统加入到当前背景精灵节点之下。
  11. m_background->addChild(m_emitter, 10);
  12. //加载火焰的图片做为粒子系统的纹理。
  13. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );
  14. //设置粒子系统居于屏幕中央。
  15. setEmitterPosition();
  16. }
  17. //取得标题。
  18. std::string DemoMeteor::title()
  19. {
  20. return "ParticleMeteor";
  21. }<strong>
  22. </strong>

(10)     DemoFire

描述:

火焰的摸拟

截图:

源码解析:

源码打印?
  1. void DemoFire::onEnter()
  2. {
  3. //调用基类的相应函数。
  4. ParticleDemo::onEnter();
  5. //创建一个CCParticleFire类的实例。
  6. m_emitter = CCParticleFire::create();
  7. //占用它,对其引用计数器加一。
  8. m_emitter->retain();
  9. //将粒子系统放在背景精灵结点之下。
  10. m_background->addChild(m_emitter, 10);
  11. //加载一个火焰图片做为粒子系统的纹理。
  12. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );//.pvr");
  13. //取得粒子系统的位置。设置高度在100。
  14. CCPoint p = m_emitter->getPosition();
  15. m_emitter->setPosition( CCPointMake(p.x, 100) );
  16. //将粒子系统居中。
  17. setEmitterPosition();
  18. }
  19. //取得标题。
  20. std::string DemoFire::title()
  21. {
  22. return "ParticleFire";
  23. }

(11)    DemoSmoke

描述:

烟雾的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void DemoSmoke::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleSmoke的实例。
  7. m_emitter = CCParticleSmoke::create();
  8. //占用它,对它的引用计数器加一。
  9. m_emitter->retain();
  10. //将粒子系统放入到背景精灵结点之下。
  11. m_background->addChild(m_emitter, 10);
  12. //加载一个火焰的图片设置为粒子系统的纹理。
  13. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );
  14. //取得粒子系统的位置并限制其高度在100。
  15. CCPoint p = m_emitter->getPosition();
  16. m_emitter->setPosition( CCPointMake( p.x, 100) );
  17. //将粒子系统居于屏幕中央。
  18. setEmitterPosition();
  19. }
  20. //取得粒子系统的标题。
  21. std::string DemoSmoke::title()
  22. {
  23. return "ParticleSmoke";
  24. }

(12)    DemoExplosion

描述:

爆炸的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void DemoExplosion::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleExplosion类的实例。
  7. m_emitter = CCParticleExplosion::create();
  8. //占用实例,对其引用计数器加一。
  9. m_emitter->retain();
  10. //将粒子发射器放到背景精灵结点之下。
  11. m_background->addChild(m_emitter, 10);
  12. //加载星星图片做为粒子系统的纹理。
  13. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_stars1) );
  14. //设置粒子释放完成后自动移除并释放,这样的话,不会连续不断的发射粒子。
  15. m_emitter->setAutoRemoveOnFinish(true);
  16. //设置粒子发射器的位置居于屏幕中央。
  17. setEmitterPosition();
  18. }
  19. //取得标题。
  20. std::string DemoExplosion::title()
  21. {
  22. return "ParticleExplosion";
  23. }<strong>
  24. </strong>

(13)    DemoSnow

描述:

雪的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void DemoSnow::onEnter()
  3. {
  4. //先调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleSnow的实例。
  7. m_emitter = CCParticleSnow::create();
  8. //占用它,对它的引用计数器加一。
  9. m_emitter->retain();
  10. //将其放在背景精灵结点之下。
  11. m_background->addChild(m_emitter, 10);
  12. //取得粒子系统的位置,设置为当前位置往下移110像素。具体位置请参看前面CCParticleExample中CCParticleSnow的initWithTotalParticles函数。
  13. CCPoint p = m_emitter->getPosition();
  14. m_emitter->setPosition( CCPointMake( p.x, p.y-110) );
  15. //设置生命值为3
  16. m_emitter->setLife(3);
  17. //设置生命随机加值范围为1,也就是生命值在2~4间初始化。
  18. m_emitter->setLifeVar(1);
  19. // 设置重力加速度值。
  20. m_emitter->setGravity(CCPointMake(0,-10));
  21. // 设置初始速度值及随机加值范围,生命值在100~160间初始化。
  22. m_emitter->setSpeed(130);
  23. m_emitter->setSpeedVar(30);
  24. //取得粒子系统的起始色彩值。
  25. ccColor4F startColor = m_emitter->getStartColor();
  26. startColor.r = 0.9f;
  27. startColor.g = 0.9f;
  28. startColor.b = 0.9f;
  29. m_emitter->setStartColor(startColor);
  30. //取得粒子系统的起始随机色彩加值范围。
  31. ccColor4F startColorVar = m_emitter->getStartColorVar();
  32. startColorVar.b = 0.1f;
  33. m_emitter->setStartColorVar(startColorVar);
  34. //设置粒子系统发射的速率。
  35. m_emitter->setEmissionRate(m_emitter->getTotalParticles()/m_emitter->getLife());
  36. //加载雪的图片并设置为当前粒子系统使用的纹理。
  37. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_snow) );
  38. //设置粒子系统发射器的位置居于屏幕中央。
  39. setEmitterPosition();
  40. }
  41. //取得标题。
  42. std::string DemoSnow::title()
  43. {
  44. return "ParticleSnow";
  45. }

(14)    DemoRain:

描述:

雨的摸拟

截图:

源码解析:

源码打印?
  1. //当前层加载时的处理
  2. void DemoRain::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleRain的实例,
  7. m_emitter = CCParticleRain::create();
  8. //占用,对其引用计数器加一。
  9. m_emitter->retain();
  10. //将粒子系统加入到背景精灵结点下。
  11. m_background->addChild(m_emitter, 10);
  12. //取得粒子系统的位置,设置为当前位置往下移110像素。具体位置请参看前面CCParticleExample中CCParticleRain的initWithTotalParticles函数。
  13. CCPoint p = m_emitter->getPosition();
  14. m_emitter->setPosition( CCPointMake( p.x, p.y-100) );
  15. //设置粒子的生命值为4
  16. m_emitter->setLife(4);
  17. //加载火焰图片做为当前粒子系统的纹理
  18. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );
  19. //设置粒子系统发射器的位置居于屏幕中央。
  20. setEmitterPosition();
  21. }
  22. //取得标题。
  23. std::string DemoRain::title()
  24. {
  25. return "ParticleRain";
  26. }<strong>
  27. </strong>

(15)    DemoBigFlower

描述:

大颗星光闪烁的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void DemoBigFlower::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleSystemQuad的实例。
  7. m_emitter = new CCParticleSystemQuad();
  8. //创建50个粒子。
  9. m_emitter->initWithTotalParticles(50);
  10. //m_emitter->autorelease();
  11. //将创建的粒子系统放入到背景精灵的结点之下。
  12. m_background->addChild(m_emitter, 10);
  13. m_emitter->release();    // win32 :  use this line or remove this line and use autorelease()
  14. //加载星星的图片做为粒子系统的纹理。
  15. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_stars1) );
  16. //设置粒子系统更新没有时长限制。
  17. m_emitter->setDuration(-1);
  18. //设置重力加速度。
  19. m_emitter->setGravity(CCPointZero);
  20. // 设置初始角度及角度初始随机变化范围
  21. m_emitter->setAngle(90);
  22. m_emitter->setAngleVar(360);
  23. // 设置初始速度及速度初始随机变化范围
  24. m_emitter->setSpeed(160);
  25. m_emitter->setSpeedVar(20);
  26. //设置初始半径长度及半径长度初始随机变化范围
  27. m_emitter->setRadialAccel(-120);
  28. m_emitter->setRadialAccelVar(0);
  29. //设置初始切角度及切角度初始随机变化范围
  30. m_emitter->setTangentialAccel(30);
  31. m_emitter->setTangentialAccelVar(0);
  32. //设置初始位置及切位置初始随机变化范围
  33. m_emitter->setPosition( CCPointMake(160,240) );
  34. m_emitter->setPosVar(CCPointZero);
  35. //设置初始生命值及生命值随机变化范围
  36. m_emitter->setLife(4);
  37. m_emitter->setLifeVar(1);
  38. // 设置粒子起始的旋转角度和随机的旋转角度加值范围,这里设置为不旋转。
  39. m_emitter->setStartSpin(0);
  40. m_emitter->setStartSizeVar(0);
  41. m_emitter->setEndSpin(0);
  42. m_emitter->setEndSpinVar(0);
  43. // 设置粒子的起始,结束色彩值和其相应的随机变化范围。
  44. ccColor4F startColor = {0.5f, 0.5f, 0.5f, 1.0f};
  45. m_emitter->setStartColor(startColor);
  46. ccColor4F startColorVar = {0.5f, 0.5f, 0.5f, 1.0f};
  47. m_emitter->setStartColorVar(startColorVar);
  48. ccColor4F endColor = {0.1f, 0.1f, 0.1f, 0.2f};
  49. m_emitter->setEndColor(endColor);
  50. ccColor4F endColorVar = {0.1f, 0.1f, 0.1f, 0.2f};
  51. m_emitter->setEndColorVar(endColorVar);
  52. // 设置粒子的大小值及其随机变化范围。
  53. m_emitter->setStartSize(80.0f);
  54. m_emitter->setStartSizeVar(40.0f);
  55. //结束大小设为宏kParticleStartSizeEqualToEndSize,代表大小不变化。
  56. m_emitter->setEndSize(kParticleStartSizeEqualToEndSize);
  57. // 设置粒子系统的发射速率。
  58. m_emitter->setEmissionRate(m_emitter->getTotalParticles()/m_emitter->getLife());
  59. // 设置为加亮模式。
  60. m_emitter->setBlendAdditive(true);
  61. //设置粒子系统发射器的位置居于屏幕中央。
  62. setEmitterPosition();
  63. }
  64. //取得标题。
  65. std::string DemoBigFlower::title()
  66. {
  67. return "ParticleBigFlower";
  68. }<strong>
  69. </strong>

(16)    DemoRotFlower

描述:

旋转的星光的摸拟

截图:

 
源码解析:

源码打印?
  1. void DemoRotFlower::onEnter()
  2. {
  3. //调用基类的相应函数。
  4. ParticleDemo::onEnter();
  5. //创建一个粒子系统的实例。
  6. m_emitter = new CCParticleSystemQuad();
  7. //创建300个粒子。
  8. m_emitter->initWithTotalParticles(300);
  9. //m_emitter->autorelease();
  10. //将粒子系统加入到背景精灵结点之下。
  11. m_background->addChild(m_emitter, 10);
  12. m_emitter->release();    // win32 : Remove this line
  13. //加载星星的图片做为粒子系统的纹理。
  14. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_stars2) );
  15. // 设置粒子系统一直进行update
  16. m_emitter->setDuration(-1);
  17. // 设置无重力加速度。
  18. m_emitter->setGravity(CCPointZero);
  19. // 设置起始的角度以及初始化时的随机角度加值范围。
  20. m_emitter->setAngle(90);
  21. m_emitter->setAngleVar(360);
  22. //设置起始的速度以及初始化时的随机速度加值范围。
  23. m_emitter->setSpeed(160);
  24. m_emitter->setSpeedVar(20);
  25. //设置起始的半径以及初始化时的随机半径加值范围。
  26. m_emitter->setRadialAccel(-120);
  27. m_emitter->setRadialAccelVar(0);
  28. //设置起始的切角以及初始化时的随机切角加值范围。
  29. m_emitter->setTangentialAccel(30);
  30. m_emitter->setTangentialAccelVar(0);
  31. //设置起始的位置以及初始化时的随机位置加值范围。
  32. m_emitter->setPosition( CCPointMake(160,240) );
  33. m_emitter->setPosVar(CCPointZero);
  34. //设置起始的生命值以及初始化时的随机生命值加值范围。
  35. m_emitter->setLife(3);
  36. m_emitter->setLifeVar(1);
  37. //设置起始的旋转角度以及初始化时的随机旋转角度加值范围。
  38. m_emitter->setStartSpin(0);
  39. m_emitter->setStartSpinVar(0);
  40. m_emitter->setEndSpin(0);
  41. m_emitter->setEndSpinVar(2000);
  42. //设置起始的颜色以及初始化时起始颜色的随机颜色加值范围。
  43. ccColor4F startColor = {0.5f, 0.5f, 0.5f, 1.0f};
  44. m_emitter->setStartColor(startColor);
  45. ccColor4F startColorVar = {0.5f, 0.5f, 0.5f, 1.0f};
  46. m_emitter->setStartColorVar(startColorVar);
  47. //设置结束的颜色以及初始化时结束颜色的随机颜色加值范围。
  48. ccColor4F endColor = {0.1f, 0.1f, 0.1f, 0.2f};
  49. m_emitter->setEndColor(endColor);
  50. ccColor4F endColorVar = {0.1f, 0.1f, 0.1f, 0.2f};
  51. m_emitter->setEndColorVar(endColorVar);
  52. //设置起始的粒子大小以及初始化时起始粒子大小的随机颜色加值范围。
  53. m_emitter->setStartSize(30.0f);
  54. m_emitter->setStartSizeVar(00.0f);
  55. //设置在Update过程中大小不变。
  56. m_emitter->setEndSize(kParticleStartSizeEqualToEndSize);
  57. // 设置粒子系统发射速率
  58. m_emitter->setEmissionRate(m_emitter->getTotalParticles()/m_emitter->getLife());
  59. // 设置不使用加亮模式。
  60. m_emitter->setBlendAdditive(false);
  61. //设置粒子系统发射器的位置居于屏幕中央。
  62. setEmitterPosition();
  63. }
  64. //取得标题。
  65. std::string DemoRotFlower::title()
  66. {
  67. return "ParticleRotFlower";
  68. }

(17)    DemoModernArt

描述:

大小的变化

截图:

源码解析:

源码打印?
  1. //加载本层的源码
  2. void DemoModernArt::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个粒子系统。
  7. glDrawArrays(GL_POINTS, 0, m_uParticleIdx);
  8. //  m_emitter = new CCParticleSystemPoint();
  9. m_emitter = new CCParticleSystemQuad();
  10. //创建1000个粒子
  11. m_emitter->initWithTotalParticles(1000);
  12. //m_emitter->autorelease();
  13. //将粒子系统放入到背景精灵的结点下。
  14. m_background->addChild(m_emitter, 10);
  15. m_emitter->release();
  16. //取得屏幕大小。
  17. CCSize s = CCDirector::sharedDirector()->getWinSize();
  18. //设置一直更新粒子系统。
  19. m_emitter->setDuration(-1);
  20. //设置重力加速度。
  21. m_emitter->setGravity(CCPointMake(0,0));
  22. //设置角度初始值及角度初始值的随机加值范围 。
  23. m_emitter->setAngle(0);
  24. m_emitter->setAngleVar(360);
  25. //设置半径初始值及半径初始值的随机加值范围。
  26. m_emitter->setRadialAccel(70);
  27. m_emitter->setRadialAccelVar(10);
  28. //设置切角初始值及切角初始值的随机加值范围。
  29. m_emitter->setTangentialAccel(80);
  30. m_emitter->setTangentialAccelVar(0);
  31. //设置速度初始值及速度初始值的随机加值范围。
  32. m_emitter->setSpeed(50);
  33. m_emitter->setSpeedVar(10);
  34. //设置位置初始值在屏幕中央。
  35. m_emitter->setPosition( CCPointMake( s.width/2, s.height/2) );
  36. m_emitter->setPosVar(CCPointZero);
  37. //设置粒子的生命初始值及初始时生命值的随机加值范围。
  38. m_emitter->setLife(2.0f);
  39. m_emitter->setLifeVar(0.3f);
  40. //设置粒子系统的发射速率。
  41. m_emitter->setEmissionRate(m_emitter->getTotalParticles()/m_emitter->getLife());
  42. //设置粒子系统的起始颜色和起始颜色的随机加值范围。
  43. ccColor4F startColor = {0.5f, 0.5f, 0.5f, 1.0f};
  44. m_emitter->setStartColor(startColor);
  45. ccColor4F startColorVar = {0.5f, 0.5f, 0.5f, 1.0f};
  46. m_emitter->setStartColorVar(startColorVar);
  47. //设置粒子系统的结束颜色和结束颜色的随机加值范围。
  48. ccColor4F endColor = {0.1f, 0.1f, 0.1f, 0.2f};
  49. m_emitter->setEndColor(endColor);
  50. ccColor4F endColorVar = {0.1f, 0.1f, 0.1f, 0.2f};
  51. m_emitter->setEndColorVar(endColorVar);
  52. //设置粒子系统的起始大小和起始大小的随机加值范围。
  53. m_emitter->setStartSize(1.0f);
  54. m_emitter->setStartSizeVar(1.0f);
  55. //设置粒子系统的结束大小和结束大小的随机加值范围。
  56. m_emitter->setEndSize(32.0f);
  57. m_emitter->setEndSizeVar(8.0f);
  58. //加载火焰的图片做为粒子系统的纹理。
  59. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );
  60. //设置不使用加亮模式。
  61. m_emitter->setBlendAdditive(false);
  62. //设置粒子系统居中。
  63. setEmitterPosition();
  64. }
  65. //取得标题。
  66. std::string DemoModernArt::title()
  67. {
  68. return "Varying size";
  69. }<strong>
  70. </strong>

(18)    DemoRing

描述:

光环的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void DemoRing::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //创建一个CCParticleFlower类的粒子系统实例。
  7. m_emitter = CCParticleFlower::create();
  8. //占用它,对其引用计数器加一。
  9. m_emitter->retain();
  10. //将粒子系统加入到背景精灵的结点之下。
  11. m_background->addChild(m_emitter, 10);
  12. //加载星星的图片做为粒子系统的纹理。
  13. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_stars1) );
  14. //设置粒子的生命值为10。
  15. m_emitter->setLifeVar(0);
  16. m_emitter->setLife(10);
  17. //设置粒子的速度。
  18. m_emitter->setSpeed(100);
  19. m_emitter->setSpeedVar(0);
  20. //设置粒子发射器的发射速率。
  21. m_emitter->setEmissionRate(10000);
  22. //设置粒子系统的位置居于屏幕中央。
  23. setEmitterPosition();
  24. }
  25. //取得标题。
  26. std::string DemoRing::title()
  27. {
  28. return "Ring Demo";
  29. }

(19)    ParallaxParticle

描述:

视差的摸拟

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void ParallaxParticle::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //将背景精灵移除。
  7. m_background->getParent()->removeChild(m_background, true);
  8. m_background = NULL;
  9. //创建一个CCParallaxNode结点p。
  10. CCParallaxNode* p = CCParallaxNode::create();
  11. //将p放入当前层中。
  12. addChild(p, 5);
  13. //创建两个以s_back3为纹理的精灵p1,p2。
  14. CCSprite *p1 = CCSprite::create(s_back3);
  15. CCSprite *p2 = CCSprite::create(s_back3);
  16. //将p1,p2分别放入CCParallaxNode结点p中。
  17. p->addChild( p1, 1, CCPointMake(0.5f,1), CCPointMake(0,250) );
  18. p->addChild(p2, 2, CCPointMake(1.5f,1), CCPointMake(0,50) );
  19. //创建一个CCParticleFlower类的粒子系统实例。
  20. m_emitter = CCParticleFlower::create();
  21. //占用它,对其引用计数器加一。
  22. m_emitter->retain();
  23. //加载火焰的图片做为粒子系统的纹理。
  24. m_emitter->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );
  25. //将粒子系统emitter放入p1的结点下。
  26. p1->addChild(m_emitter, 10);
  27. //设置粒子系统的位置。
  28. m_emitter->setPosition( CCPointMake(250,200) );
  29. //创建一个CCParticleSun类的粒子系统实例。
  30. CCParticleSun* par = CCParticleSun::create();
  31. //将粒子系统par放入p2的结点下。
  32. p2->addChild(par, 10);
  33. //加载火焰的图片做为粒子系统的纹理。par->setTexture( CCTextureCache::sharedTextureCache()->addImage(s_fire) );
  34. //创建动画move和反向动画move_back,由两个动画创建动画序列seq.
  35. CCActionInterval* move = CCMoveBy::create(4, CCPointMake(300,0));
  36. CCActionInterval* move_back = move->reverse();
  37. CCFiniteTimeAction* seq = CCSequence::create( move, move_back, NULL);
  38. //让CCParallaxNode结点p运行这个序列动画。
  39. p->runAction(CCRepeatForever::create((CCActionInterval*)seq));
  40. }
  41. //取得标题。
  42. std::string ParallaxParticle::title()
  43. {
  44. return "Parallax + Particles";
  45. }

(20)    DemoParticleFromFile

描述:

从PLIST文件中创建一个粒子系统。

截图:

源码解析:

源码打印?
  1. //加载当前层时进行的处理。
  2. void DemoParticleFromFile::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景为黑色。
  7. setColor(ccBLACK);
  8. //将背景精灵移除并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //创建一个新的粒子系统。
  12. m_emitter = new CCParticleSystemQuad();
  13. //通过参数创建一个字符串做为PLIST文件名用于加载一个粒子系统。
  14. std::string filename = "Particles/" + m_title + ".plist";
  15. m_emitter->initWithFile(filename.c_str());
  16. //将粒子系统加入当前结点下。
  17. addChild(m_emitter, 10);
  18. //设置粒子系统居中。
  19. setEmitterPosition();
  20. }
  21. 在createParticleLayer函数中有
  22. case 19: return new DemoParticleFromFile("BoilingFoam");
  23. case 20: return new DemoParticleFromFile("BurstPipe");
  24. case 21: return new DemoParticleFromFile("Comet");
  25. case 22: return new DemoParticleFromFile("debian");
  26. case 23: return new DemoParticleFromFile("ExplodingRing");
  27. case 24: return new DemoParticleFromFile("LavaFlow");
  28. case 25: return new DemoParticleFromFile("SpinningPeas");
  29. case 26: return new DemoParticleFromFile("SpookyPeas");
  30. case 27: return new DemoParticleFromFile("Upsidedown");
  31. case 28: return new DemoParticleFromFile("Flower");
  32. case 29: return new DemoParticleFromFile("Spiral");
  33. case 30: return new DemoParticleFromFile("Galaxy");
  34. case 31: return new DemoParticleFromFile("Phoenix");
源码打印?
  1. <span style="font-family: Arial; font-size: 14px; line-height: 26px; ">大家可以一一查看,其实原理就是通过PLIST文件创建不同型态的粒子系统。</span>

(21)    RadiusMode1

描述:

环形运动模式演示一。

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理
  2. void RadiusMode1::onEnter()
  3. {
  4. //调用基类的相应处理
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色
  7. setColor(ccBLACK);
  8. //移除背景精灵并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //创建粒子系统,创建200个粒子。
  12. m_emitter = new CCParticleSystemQuad();
  13. m_emitter->initWithTotalParticles(200);
  14. addChild(m_emitter, 10);
  15. //加载图片做为粒子系统的纹理。
  16. m_emitter->setTexture(CCTextureCache::sharedTextureCache()->addImage("Images/stars-grayscale.png"));
  17. //设置粒子系统永远更新,宏kCCParticleDurationInfinity值为-1。
  18. m_emitter->setDuration(kCCParticleDurationInfinity);
  19. // 设置粒子系统运动模式为环型模式。
  20. m_emitter->setEmitterMode(kCCParticleModeRadius);
  21. // 环型模式的起始和结束半径以及相应的半径随机加成范围值。
  22. m_emitter->setStartRadius(0);
  23. m_emitter->setStartRadiusVar(0);
  24. m_emitter->setEndRadius(160);
  25. m_emitter->setEndRadiusVar(0);
  26. // 设置环型运动模式的每秒旋转角度及相应的随机加成范围值。
  27. m_emitter->setRotatePerSecond(180);
  28. m_emitter->setRotatePerSecondVar(0);
  29. // 设置初始时粒子系统的角度以及相应的随机加成范围值。
  30. m_emitter->setAngle(90);
  31. m_emitter->setAngleVar(0);
  32. // 设置粒子系统的位置居于屏幕中央。
  33. CCSize size = CCDirector::sharedDirector()->getWinSize();
  34. m_emitter->setPosition(ccp(size.width/2, size.height/2));
  35. m_emitter->setPosVar(CCPointZero);
  36. // 设置初始时粒子的生命值为5。
  37. m_emitter->setLife(5);
  38. m_emitter->setLifeVar(0);
  39. // 设置粒子本身起始和结束状态不旋转
  40. m_emitter->setStartSpin(0);
  41. m_emitter->setStartSpinVar(0);
  42. m_emitter->setEndSpin(0);
  43. m_emitter->setEndSpinVar(0);
  44. //设置粒子系统发射粒子的起始颜色和随机加值范围。
  45. ccColor4F startColor = {0.5f, 0.5f, 0.5f, 1.0f};
  46. m_emitter->setStartColor(startColor);
  47. ccColor4F startColorVar = {0.5f, 0.5f, 0.5f, 1.0f};
  48. m_emitter->setStartColorVar(startColorVar);
  49. //设置粒子系统发射粒子的终止颜色和随机加值范围。
  50. ccColor4F endColor = {0.1f, 0.1f, 0.1f, 0.2f};
  51. m_emitter->setEndColor(endColor);
  52. ccColor4F endColorVar = {0.1f, 0.1f, 0.1f, 0.2f};
  53. m_emitter->setEndColorVar(endColorVar);
  54. // 设置粒子系统发射粒子的起始大小和随机加值范围,结束值指定为宏kCCParticleStartSizeEqualToEndSize代表大小在粒子运动时不变化。
  55. m_emitter->setStartSize(32);
  56. m_emitter->setStartSizeVar(0);
  57. m_emitter->setEndSize(kCCParticleStartSizeEqualToEndSize);
  58. // 设置粒子系统的发射速率。
  59. m_emitter->setEmissionRate(m_emitter->getTotalParticles() / m_emitter->getLife());
  60. // 设置不使用高亮模式。
  61. m_emitter->setBlendAdditive(false);
  62. }
  63. //取得标题。
  64. std::string RadiusMode1::title()
  65. {
  66. return "Radius Mode: Spiral";
  67. }

(22)    RadiusMode2

描述:

环形运动模式演示一。

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void RadiusMode2::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //移除背景精灵并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //创建粒子系统,创建200个粒子。
  12. m_emitter = new CCParticleSystemQuad();
  13. m_emitter->initWithTotalParticles(200);
  14. addChild(m_emitter, 10);
  15. //加载图片做为粒子系统的纹理。m_emitter->setTexture(CCTextureCache::sharedTextureCache()->addImage("Images/stars-grayscale.png"));
  16. //设置粒子系统永远更新,宏kCCParticleDurationInfinity值为-1。
  17. m_emitter->setDuration(kCCParticleDurationInfinity);
  18. // 设置粒子系统运动模式为环型模式。
  19. m_emitter->setEmitterMode(kCCParticleModeRadius);
  20. // 环型模式的起始和结束半径以及相应的半径随机加成范围值。
  21. m_emitter->setStartRadius(100);
  22. m_emitter->setStartRadiusVar(0);
  23. m_emitter->setEndRadius(kCCParticleStartRadiusEqualToEndRadius);
  24. m_emitter->setEndRadiusVar(0);
  25. // 设置环型运动模式的每秒旋转角度及相应的随机加成范围值。
  26. m_emitter->setRotatePerSecond(45);
  27. m_emitter->setRotatePerSecondVar(0);
  28. // 设置初始时粒子系统的角度以及相应的随机加成范围值。
  29. m_emitter->setAngle(90);
  30. m_emitter->setAngleVar(0);
  31. // 设置粒子系统的位置居于屏幕中央。
  32. CCSize size = CCDirector::sharedDirector()->getWinSize();
  33. m_emitter->setPosition(ccp(size.width/2, size.height/2));
  34. m_emitter->setPosVar(CCPointZero);
  35. // 设置初始时粒子的生命值为4。
  36. m_emitter->setLife(4);
  37. m_emitter->setLifeVar(0);
  38. // 设置粒子本身起始和结束状态不旋转
  39. m_emitter->setStartSpin(0);
  40. m_emitter->setStartSpinVar(0);
  41. m_emitter->setEndSpin(0);
  42. m_emitter->setEndSpinVar(0);
  43. //设置粒子系统发射粒子的起始颜色和随机加值范围。
  44. ccColor4F startColor = {0.5f, 0.5f, 0.5f, 1.0f};
  45. m_emitter->setStartColor(startColor);
  46. ccColor4F startColorVar = {0.5f, 0.5f, 0.5f, 1.0f};
  47. m_emitter->setStartColorVar(startColorVar);
  48. //设置粒子系统发射粒子的终止颜色和随机加值范围。
  49. ccColor4F endColor = {0.1f, 0.1f, 0.1f, 0.2f};
  50. m_emitter->setEndColor(endColor);
  51. ccColor4F endColorVar = {0.1f, 0.1f, 0.1f, 0.2f};
  52. m_emitter->setEndColorVar(endColorVar);
  53. // 设置粒子系统发射粒子的起始大小和随机加值范围,结束值指定为宏kCCParticleStartSizeEqualToEndSize代表大小在粒子运动时不变化。
  54. m_emitter->setStartSize(32);
  55. m_emitter->setStartSizeVar(0);
  56. m_emitter->setEndSize(kCCParticleStartSizeEqualToEndSize);
  57. // 设置粒子系统的发射速率。
  58. m_emitter->setEmissionRate(m_emitter->getTotalParticles() / m_emitter->getLife());
  59. // 设置不使用高亮模式。
  60. m_emitter->setBlendAdditive(false);
  61. }
  62. //取得标题。
  63. std::string RadiusMode2::title()
  64. {
  65. return "Radius Mode: Semi Circle";
  66. }<strong>
  67. </strong>

(23)    Issue704

描述:

从PLIST文件中创建一个粒子系统。

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void Issue704::onEnter()
  3. {
  4. //调用基类的相应函数
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //移除背景精灵并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //创建粒子系统,创建100个粒子。
  12. m_emitter = new CCParticleSystemQuad();
  13. m_emitter->initWithTotalParticles(100);
  14. addChild(m_emitter, 10);
  15. //加载图片做为粒子系统的纹理。m_emitter->setTexture(CCTextureCache::sharedTextureCache()->addImage("Images/fire.png"));
  16. //设置粒子系统永远更新,宏kCCParticleDurationInfinity值为-1。
  17. m_emitter->setDuration(kCCParticleDurationInfinity);
  18. // 设置粒子系统运动模式为环型模式。
  19. m_emitter->setEmitterMode(kCCParticleModeRadius);
  20. // 环型模式的起始和结束半径以及相应的半径随机加成范围值。
  21. m_emitter->setStartRadius(50);
  22. m_emitter->setStartRadiusVar(0);
  23. m_emitter->setEndRadius(kCCParticleStartRadiusEqualToEndRadius);
  24. m_emitter->setEndRadiusVar(0);
  25. // 设置环型运动模式的每秒旋转角度及相应的随机加成范围值。
  26. m_emitter->setRotatePerSecond(0);
  27. m_emitter->setRotatePerSecondVar(0);
  28. // 设置初始时粒子系统的角度以及相应的随机加成范围值。
  29. m_emitter->setAngle(90);
  30. m_emitter->setAngleVar(0);
  31. // 设置粒子系统的位置居于屏幕中央。
  32. CCSize size = CCDirector::sharedDirector()->getWinSize();
  33. m_emitter->setPosition(ccp(size.width/2, size.height/2));
  34. m_emitter->setPosVar(CCPointZero);
  35. // 设置初始时粒子的生命值为5。
  36. m_emitter->setLife(5);
  37. m_emitter->setLifeVar(0);
  38. // 设置粒子本身起始和结束状态不旋转
  39. m_emitter->setStartSpin(0);
  40. m_emitter->setStartSpinVar(0);
  41. m_emitter->setEndSpin(0);
  42. m_emitter->setEndSpinVar(0);
  43. //设置粒子系统发射粒子的起始颜色和随机加值范围。
  44. ccColor4F startColor = {0.5f, 0.5f, 0.5f, 1.0f};
  45. m_emitter->setStartColor(startColor);
  46. ccColor4F startColorVar = {0.5f, 0.5f, 0.5f, 1.0f};
  47. m_emitter->setStartColorVar(startColorVar);
  48. //设置粒子系统发射粒子的终止颜色和随机加值范围。
  49. ccColor4F endColor = {0.1f, 0.1f, 0.1f, 0.2f};
  50. m_emitter->setEndColor(endColor);
  51. ccColor4F endColorVar = {0.1f, 0.1f, 0.1f, 0.2f};
  52. m_emitter->setEndColorVar(endColorVar);
  53. // 设置粒子系统发射粒子的起始大小和随机加值范围,结束值指定为宏kCCParticleStartSizeEqualToEndSize代表大小在粒子运动时不变化。
  54. m_emitter->setStartSize(16);
  55. m_emitter->setStartSizeVar(0);
  56. m_emitter->setEndSize(kCCParticleStartSizeEqualToEndSize);
  57. // 设置粒子系统的发射速率。
  58. m_emitter->setEmissionRate(m_emitter->getTotalParticles() / m_emitter->getLife());
  59. // 设置不使用高亮模式。
  60. m_emitter->setBlendAdditive(false);
  61. // 让粒子系统的发射器运行一个无限旋转的动画。
  62. CCRotateBy* rot = CCRotateBy::create(16, 360);
  63. m_emitter->runAction(CCRepeatForever::create(rot));
  64. }
  65. //取得标题。
  66. std::string Issue704::title()
  67. {
  68. return "Issue 704. Free + Rot";
  69. }
  70. //取得幅标题。
  71. std::string Issue704::subtitle()
  72. {
  73. return "Emitted particles should not rotate";
  74. }

(24)    Issue870

描述:

从PLIST文件中创建一个粒子系统。

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void Issue870::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //移除背景精灵并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //创建一个粒子系统,由一个PLIST文件来创建相应的粒子。
  12. CCParticleSystemQuad *system = new CCParticleSystemQuad();
  13. system->initWithFile("Particles/SpinningPeas.plist");
  14. //加载纹得中的一个图块做为粒子的纹理。
  15. system->setTextureWithRect(CCTextureCache::sharedTextureCache()->addImage("Images/particles.png"), CCRectMake(0,0,32,32));
  16. addChild(system, 10);
  17. //将粒子系统实例指针保存到成员变量中。在后面updateQuads使用。
  18. m_emitter = system;
  19. //图片中的图块索引。
  20. m_nIndex = 0;
  21. //让当前层每2秒调用一下更新粒子的绘制矩形函数。
  22. schedule(schedule_selector(Issue870::updateQuads), 2.0f);
  23. }
  24. //更新粒子的绘制矩形函数。
  25. void Issue870::updateQuads(float dt)
  26. {
  27. //图块索引加一,并限定在[0,4)间。
  28. m_nIndex = (m_nIndex + 1) % 4;
  29. //通过图块索引来取得相应的图块位置并设置为粒子使用的纹理。
  30. CCRect rect = CCRectMake(m_nIndex * 32, 0, 32, 32);
  31. CCParticleSystemQuad* system = (CCParticleSystemQuad*)m_emitter;
  32. system->setTextureWithRect(m_emitter->getTexture(), rect);
  33. }
  34. //取得标题
  35. std::string Issue870::title()
  36. {
  37. return "Issue 870. SubRect";
  38. }
  39. //取得幅标题
  40. std::string Issue870::subtitle()
  41. {
  42. return "Every 2 seconds the particle should change";
  43. }

(25)    Issue1201

描述:

似乎从截图上看不到什么,仔细看,并移动鼠标。这个实例应该是一个类似慧尾的效果,只是很淡。

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理
  2. void Issue1201::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //移除背景精灵并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //创建一个RainbowEffect类的实例,创建5O个粒子。
  12. RainbowEffect *particle = new RainbowEffect();
  13. particle->initWithTotalParticles(50);
  14. //将其加入到当前层结点下。
  15. addChild(particle);
  16. //将粒子系统的位置居于屏幕中央。
  17. CCSize s = CCDirector::sharedDirector()->getWinSize();
  18. particle->setPosition(ccp(s.width/2, s.height/2));
  19. m_emitter = particle;
  20. }
  21. //取得标题。
  22. std::string Issue1201::title()
  23. {
  24. return "Issue 1201. Unfinished";
  25. }
  26. //取得幅标题。
  27. std::string Issue1201::subtitle()
  28. {
  29. return "Unfinished test. Ignore it";
  30. }

(26)    MultipleParticleSystems

描述:

多个粒子系统。

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理
  2. void MultipleParticleSystems::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //移除背景精灵并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //加载纹得中的一个图块做为粒子的纹理。CCTextureCache::sharedTextureCache()->addImage("Images/particles.png");
  12. //创建5个粒子系统。
  13. for (int i = 0; i<5; i++) {
  14. //由相应的PLIST创建出粒子系统来。
  15. CCParticleSystemQuad *particleSystem = CCParticleSystemQuad::create("Particles/SpinningPeas.plist");
  16. //根据索引将粒子系统放在不同的位置。
  17. particleSystem->setPosition(ccp(i*50 ,i*50));
  18. //设置粒子系统运动影响方式类型为按组方式。
  19. particleSystem->setPositionType(kCCPositionTypeGrouped);
  20. addChild(particleSystem);
  21. }
  22. //粒子发射器指针置空。
  23. m_emitter = NULL;
  24. }
  25. //取得标题。
  26. std::string MultipleParticleSystems::title()
  27. {
  28. return "Multiple particle systems";
  29. }
  30. //取得幅标题。
  31. std::string MultipleParticleSystems::subtitle()
  32. {
  33. return "v1.1 test: FPS should be lower than next test";
  34. }
  35. //更新函数。
  36. void MultipleParticleSystems::update(float dt)
  37. {
  38. //取得用于标识粒子数量的文字标签。
  39. CCLabelAtlas *atlas = (CCLabelAtlas*) getChildByTag(kTagParticleCount);
  40. //定义一个计数器变量count
  41. unsigned int count = 0;
  42. //遍历所有粒子系统子结点
  43. CCObject* pObj = NULL;
  44. //CCARRAY_FOREACH为遍历CArray数组的宏
  45. CCARRAY_FOREACH(m_pChildren, pObj)
  46. {
  47. //通过dynamic_cast来将数组元素转换成为相应的粒子系统指针。
  48. CCParticleSystem* item = dynamic_cast<CCParticleSystem*>(pObj);
  49. if (item != NULL)
  50. {
  51. //当前计数器变量count值加上当前粒子系统子结点的粒子数量,统计粒子总数。
  52. count += item->getParticleCount();
  53. }
  54. }
  55. //让文字标签显示相应的粒子数量。
  56. char str[100] = {0};
  57. sprintf(str, "%4d", count);
  58. atlas->setString(str);
  59. }<strong>
  60. </strong>

(27)    MultipleParticleSystemBatched

描述:

使用批次结点进行多外粒子系统的渲染管理。

截图:

源码解析:

源码打印?
  1. //当前层加载时的处理
  2. void MultipleParticleSystemsBatched::onEnter()
  3. {
  4. //先调用基类的相应处理。
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //移除背景精灵并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //创建一个新的粒子系统的批次结点。
  12. CCParticleBatchNode *batchNode = new CCParticleBatchNode();
  13. //初始化,渲染用的矩形信息容器的容量初始化为3000。
  14. batchNode->initWithTexture(NULL, 3000);
  15. //将粒子系统的批次结点放入当前结点之下。
  16. addChild(batchNode, 1, 2);
  17. //创建5个粒子系统。
  18. for (int i = 0; i<5; i++) {
  19. //由PLIST文件创建相应的粒子系统。
  20. CCParticleSystemQuad *particleSystem = CCParticleSystemQuad::create("Particles/SpinningPeas.plist");
  21. //设置粒子系统运动影响方式类型为按组方式。
  22. particleSystem->setPositionType(kCCPositionTypeGrouped);
  23. //根据索引将粒子系统放在不同的位置。
  24. particleSystem->setPosition(ccp(i*50 ,i*50));
  25. //设置使用粒子系统的纹理。
  26. batchNode->setTexture(particleSystem->getTexture());
  27. batchNode->addChild(particleSystem);
  28. }
  29. //已经放入到当前结点下,不再占用粒子系统批次结点,所以对其引用计数器减一操作。
  30. batchNode->release();
  31. //使用批次结点,则原指向所用的粒子系统发射器的指针置空。
  32. m_emitter = NULL;
  33. }
  34. //更新处理。
  35. void MultipleParticleSystemsBatched::update(float dt)
  36. {   //取得用于标识粒子数量的文字标签。
  37. CCLabelAtlas *atlas = (CCLabelAtlas*) getChildByTag(kTagParticleCount);
  38. //定义一个计数器变量count
  39. unsigned count = 0;
  40. //根据索引取得粒子系统的批次结点。
  41. CCNode* batchNode = getChildByTag(2);
  42. //遍历所有粒子系统子结点
  43. CCObject* pObj = NULL;
  44. //CCARRAY_FOREACH为遍历CArray数组的宏
  45. CCARRAY_FOREACH(batchNode->getChildren(), pObj)
  46. {
  47. //通过dynamic_cast来将数组元素转换成为相应的粒子系统指针。
  48. CCParticleSystem* item = dynamic_cast<CCParticleSystem*>(pObj);
  49. if (item != NULL)
  50. {
  51. //当前计数器变量count值加上当前粒子系统子结点的粒子数量,统计粒子总数。
  52. count += item->getParticleCount();
  53. }
  54. }
  55. //让文字标签显示相应的粒子数量。
  56. char str[50] = {0};
  57. sprintf(str, "%4d", count);
  58. atlas->setString(str);
  59. }
  60. //取得标题。
  61. std::string MultipleParticleSystemsBatched::title()
  62. {
  63. return "Multiple particle systems batched";
  64. }
  65. //取得幅标题。
  66. std::string MultipleParticleSystemsBatched::subtitle()
  67. {
  68. return "v1.1 test: should perform better than previous test";
  69. }

(28)    AddAndDeleteParticleSystems

描述:

动态的增加和删除粒子系统。

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理
  2. void AddAndDeleteParticleSystems::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //移除背景精灵并置空。
  9. removeChild(m_background, true);
  10. m_background = NULL;
  11. //创建一个粒子系统的批次结点,渲染用的矩形信息容器的容量初始化为16000。
  12. m_pBatchNode = CCParticleBatchNode::createWithTexture((CCTexture2D*)NULL, 16000);
  13. //将批次结点加入当前层中。
  14. addChild(m_pBatchNode, 1, 2);
  15. //创建6个粒子系统。
  16. for (int i = 0; i<6; i++) {
  17. //由相应的PLIST文件创建出粒子系统。
  18. CCParticleSystemQuad *particleSystem = CCParticleSystemQuad::create("Particles/Spiral.plist");
  19. //取出粒子系统所用的纹理设置为批次结点的纹理。
  20. m_pBatchNode->setTexture(particleSystem->getTexture());
  21. //设置粒子系统的运动方式为组运动方式,最大粒子数量为200。
  22. particleSystem->setPositionType(kCCPositionTypeGrouped);
  23. particleSystem->setTotalParticles(200);
  24. //设置每个粒子系统的位置。
  25. particleSystem->setPosition(ccp(i*15 +100,i*15+100));
  26. //将粒子系统放入到批次结点中。
  27. unsigned int randZ = rand() % 100;
  28. m_pBatchNode->addChild(particleSystem, randZ, -1);
  29. }
  30. //让当前层每0.5秒触发一次函数removeSystem
  31. chedule(schedule_selector(AddAndDeleteParticleSystems::removeSystem), 0.5f);
  32. //因为使用的是粒子系统的批次结点,所以指向粒子系统的指针置空。
  33. m_emitter = NULL;
  34. }
  35. //定时触发的函数。
  36. void AddAndDeleteParticleSystems::removeSystem(float dt)
  37. {
  38. //取得批次结点中的粒子系统的数量。
  39. int nChildrenCount = m_pBatchNode->getChildren()->count();
  40. if (nChildrenCount > 0)
  41. {
  42. CCLOG("remove random system");
  43. //产生一个随机索引。
  44. unsigned int uRand = rand() % (nChildrenCount - 1);
  45. //将对应索引的粒子系统从批次结点中删除。
  46. pBatchNode->removeChild((CCNode*)m_pBatchNode->getChildren()->objectAtIndex(uRand), true);
  47. //再由PLIST创建一个新的粒子系统。
  48. CCParticleSystemQuad *particleSystem = CCParticleSystemQuad::create("Particles/Spiral.plist");
  49. //add new
  50. //设置粒子系统运动方式为组方式,粒子总数量为200
  51. particleSystem->setPositionType(kCCPositionTypeGrouped);
  52. particleSystem->setTotalParticles(200);
  53. //设置粒子系统处于一个随机的位置。
  54. particleSystem->setPosition(ccp(rand() % 300 ,rand() % 400));
  55. //打印日志,将新粒子系统放入到批次结点中。
  56. CCLOG("add a new system");
  57. unsigned int randZ = rand() % 100;
  58. m_pBatchNode->addChild(particleSystem, randZ, -1);
  59. }
  60. }
  61. //更新处理
  62. void AddAndDeleteParticleSystems::update(float dt)
  63. {
  64. //取得用于显示粒子数量的文字标签。
  65. CCLabelAtlas *atlas = (CCLabelAtlas*) getChildByTag(kTagParticleCount);
  66. unsigned int count = 0;
  67. //取得粒子系统的批次结点。
  68. CCNode* batchNode = getChildByTag(2);
  69. //定义临时指针变量pObj,用于遍历所有的粒子系统结点。
  70. CCObject* pObj = NULL;
  71. CCARRAY_FOREACH(batchNode->getChildren(), pObj)
  72. {
  73. //通过dynamic_cast将物体基类指针转化为粒子系统结点指针。
  74. CCParticleSystem* item = dynamic_cast<CCParticleSystem*>(pObj);
  75. if (item != NULL)
  76. {
  77. //更新粒子的计数器值。
  78. count += item->getParticleCount();
  79. }
  80. }
  81. //写字,显示数量。
  82. char str[100] = {0};
  83. sprintf(str, "%4d", count);
  84. atlas->setString(str);
  85. }
  86. //取得标题。
  87. std::string AddAndDeleteParticleSystems::title()
  88. {
  89. return "Add and remove Particle System";
  90. }
  91. //取得幅标题。
  92. std::string AddAndDeleteParticleSystems::subtitle()
  93. {
  94. return "v1.1 test: every 2 sec 1 system disappear, 1 appears";
  95. }

(29)    ReorderParticleSystems

描述:

粒子系统的Z值重新排序。

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void ReorderParticleSystems::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景色为黑色。
  7. setColor(ccBLACK);
  8. //移除背景精灵并置空。
  9. removeChild(m_background ,true);
  10. m_background = NULL;
  11. //创建一个新的粒子系统的批次结点,渲染用的矩形信息容器的容量初始化为3000。
  12. m_pBatchNode = CCParticleBatchNode::create("Images/stars-grayscale.png" ,3000);
  13. //将粒子系统的批次结点放入到当前层结点下。
  14. addChild(m_pBatchNode, 1, 2);
  15. //使用for循环创建三个粒子系统。
  16. for (int i = 0; i<3; i++) {
  17. //创建第i个粒子系统。
  18. CCParticleSystemQuad* particleSystem = new CCParticleSystemQuad();
  19. //创建200个粒子。
  20. particleSystem->initWithTotalParticles(200);
  21. //取得批次结点的纹理设置为粒子系统的纹理。
  22. particleSystem->setTexture(m_pBatchNode->getTexture());
  23. //设置粒子系统一直调用Update
  24. particleSystem->setDuration(kCCParticleDurationInfinity);
  25. //设置粒子的运动方式为环型运动方式。
  26. particleSystem->setEmitterMode(kCCParticleModeRadius);
  27. //设置粒子系统的粒子起始角度为100。
  28. particleSystem->setStartRadius(100);
  29. particleSystem->setStartRadiusVar(0);
  30. //指定粒子系统的粒子结束角度与起始角度相同,即角度不变化。
  31. particleSystem->setEndRadius(kCCParticleStartRadiusEqualToEndRadius);
  32. particleSystem->setEndRadiusVar(0);    // not used when start == end
  33. // 设置粒子系统的环型运动速率为每秒45度。
  34. particleSystem->setRotatePerSecond(45);
  35. particleSystem->setRotatePerSecondVar(0);
  36. // 设置粒子系统的角度为90度。
  37. particleSystem->setAngle(90);
  38. particleSystem->setAngleVar(0);
  39. //设置粒子系统的位置为零点
  40. particleSystem->setPosVar(CCPointZero);
  41. //设置粒子初始化的生命值为4。
  42. particleSystem->setLife(4);
  43. particleSystem->setLifeVar(0);
  44. //设置粒子运动过程中自身不旋转。
  45. particleSystem->setStartSpin(0);
  46. particleSystem->setStartSpinVar(0);
  47. particleSystem->setEndSpin(0);
  48. particleSystem->setEndSpinVar(0);
  49. //设置粒子的起始和结束的颜色,这里通过一个float数组来表示R,G,B的值,通过索引设置相应色彩分量值表现红,绿,蓝三种颜色。
  50. float color[3] = {0,0,0};
  51. color[i] = 1;
  52. ccColor4F startColor = {color[0], color[1], color[2], 1.0f};
  53. particleSystem->setStartColor(startColor);
  54. ccColor4F startColorVar = {0, 0, 0, 0};
  55. particleSystem->setStartColorVar(startColorVar);
  56. ccColor4F endColor = startColor;
  57. particleSystem->setEndColor(endColor);
  58. ccColor4F endColorVar = startColorVar;
  59. particleSystem->setEndColorVar(endColorVar);
  60. // 设置粒子的起始大小。
  61. particleSystem->setStartSize(32);
  62. particleSystem->setStartSizeVar(0);
  63. particleSystem->setEndSize(kCCParticleStartSizeEqualToEndSize);
  64. //设置粒子系统发射粒子的速率。
  65. particleSystem->setEmissionRate(particleSystem->getTotalParticles()/particleSystem->getLife());
  66. // 设置粒子系统的位置,
  67. particleSystem->setPosition(ccp(i*10+120 ,200));
  68. //将粒子系统放入到批次结点下,设置粒子系统的运动方式为自由运动方式。
  69. m_pBatchNode->addChild(particleSystem);
  70. particleSystem->setPositionType(kCCPositionTypeFree);
  71. //使用批次结点进行渲染,粒子系统已经放入到批次结点之下,故不再占用粒子系统,所以可以在这里对其引用计数器减一操作。
  72. particleSystem->release();
  73. //[pBNode addChild:particleSystem z:10 tag:0);
  74. }
  75. //每2秒调用一下reorderSystem函数。
  76. schedule(schedule_selector(ReorderParticleSystems::reorderSystem), 2.0f);
  77. m_emitter = NULL;
  78. }
  79. //定时触发的函数。
  80. void ReorderParticleSystems::reorderSystem(float time)
  81. {
  82. //通过索引取得相应的批次系统结点,进行重新的Z值排序。
  83. CCParticleSystem* system = (CCParticleSystem*)m_pBatchNode->getChildren()->objectAtIndex(1);
  84. m_pBatchNode->reorderChild(system, system->getZOrder() - 1);
  85. }
  86. //更新函数。
  87. void ReorderParticleSystems::update(float dt)
  88. {
  89. //取得用于显示粒子数量的文字标签。
  90. CCLabelAtlas *atlas = (CCLabelAtlas*) getChildByTag(kTagParticleCount);
  91. //创建临时变量用于统计粒子数量。
  92. unsigned int count = 0;
  93. //取得批次结点
  94. CCNode* batchNode = getChildByTag(2);
  95. //定义临时CCObject指针变量用于遍历所有的粒子系统。
  96. CCObject* pObj = NULL;
  97. CCARRAY_FOREACH(batchNode->getChildren(), pObj)
  98. {
  99. //通过dynamic_cast将物体基类指针转化为粒子系统结点指针。
  100. CCParticleSystem* item = dynamic_cast<CCParticleSystem*>(pObj);
  101. if (item != NULL)
  102. {
  103. //更新粒子数量的计数器。
  104. count += item->getParticleCount();
  105. }
  106. }
  107. //写字。
  108. char str[100] = {0};
  109. sprintf(str, "%4d", count);
  110. atlas->setString(str);
  111. }
  112. //返回标题。
  113. std::string ReorderParticleSystems::title()
  114. {
  115. return "reorder systems";
  116. }
  117. //返回幅标题。
  118. std::string ReorderParticleSystems::subtitle()
  119. {
  120. return "changes every 2 seconds";
  121. }

(30)    PremultipliedAlphaTest

描述:

预乘aplha通道效果演示之一。什么是预乘?假设一个像素点,用RGBA 四个分量来表示,记做(R,G,B,A),那预乘后的像素就是(R*A,G*A,B*A, A),这里A的取值范围是[0,1]。所以,预乘就是每个颜色分量都与该像素的alpha分量预先相乘。可以发现,对于一个没有透明度,或者说透明度为1 的像素来说,预乘不预乘结果都是一样的。为什么要用预乘方式来表示像素?主要是这样会使公式更简单。而且实际上,在实际运算过程中,使用预乘像素进行运算在某些情况下效率会更高。

截图:

源码解析:

源码打印?
  1. //返回标题。
  2. std::string PremultipliedAlphaTest::title()
  3. {
  4. return "premultiplied alpha";
  5. }
  6. //返回副标题。
  7. std::string PremultipliedAlphaTest::subtitle()
  8. {
  9. return "no black halo, particles should fade out";
  10. }
  11. //当前层加载时调用的处理。
  12. void PremultipliedAlphaTest::onEnter()
  13. {
  14. //调用基类的相应函数。
  15. ParticleDemo::onEnter();
  16. //设置背景为蓝色。
  17. this->setColor(ccBLUE);
  18. //删除原来的背景精灵并置空。
  19. this->removeChild(m_background, true);
  20. m_background = NULL;
  21. //由PLIST文件创建一个粒子系统。
  22. m_emitter = CCParticleSystemQuad::create("Particles/BoilingFoam.plist");
  23. //占用它,所以对其引用计数器加一。
  24. m_emitter->retain();
  25. //设置ALPHA混合方案为方案。
  26. ccBlendFunc tBlendFunc = { GL_ONE, GL_ONE_MINUS_SRC_ALPHA };
  27. m_emitter->setBlendFunc(tBlendFunc);
  28. //提示纹理必须有ALPHA通道
  29. CCAssert(m_emitter->getOpacityModifyRGB(), "Particle texture does not have premultiplied alpha, test is useless");
  30. // Toggle next line to see old behavior
  31. //  this->emitter.opacityModifyRGB = NO;
  32. //设置粒子系统的粒子起始和结束的颜色。
  33. m_emitter->setStartColor(ccc4f(1, 1, 1, 1));
  34. m_emitter->setEndColor(ccc4f(1, 1, 1, 0));
  35. m_emitter->setStartColorVar(ccc4f(0, 0, 0, 0));
  36. m_emitter->setEndColorVar(ccc4f(0, 0, 0, 0));
  37. //将粒子系统加入到当前结点下。
  38. this->addChild(m_emitter, 10);
  39. }

(31)    PremultipliedAlphaTest2:

描述:

预乘aplha通道效果演示之二。

截图:

源码解析:

源码打印?
  1. //加载当前层时的处理。
  2. void PremultipliedAlphaTest2::onEnter()
  3. {
  4. //调用基类的相应函数。
  5. ParticleDemo::onEnter();
  6. //设置背景为黑色。
  7. this->setColor(ccBLACK);
  8. //删除原来的背景精灵并置空。
  9. this->removeChild(m_background, true);
  10. m_background = NULL;
  11. //由PLIST文件创建一个粒子系统。具体的ALPHA混合方案都由PLIST文件中的数据进行读取设置。
  12. m_emitter = CCParticleSystemQuad::create("Particles/TestPremultipliedAlpha.plist");
  13. //占用粒子系统,对其引用计数器加一。
  14. m_emitter->retain();
  15. //将粒子系统放入到当前结点下。
  16. this->addChild(m_emitter ,10);
  17. }
  18. //取得标题。
  19. std::string PremultipliedAlphaTest2::title()
  20. {
  21. return "premultiplied alpha 2";
  22. }
  23. //取得副标题。
  24. std::string PremultipliedAlphaTest2::subtitle()
  25. {
  26. return "Arrows should be faded";
  27. }

我去~,累死哥了。不过经过这么痛苦的注释之后,我相信大家会跟我一样越来越清楚Cocos2d-x里的粒子系统是什么原理以及怎样使用的.我们可以看到,PLIST作为Cocos2d-x粒子系统数据的的存储文件,它可以很方便的产生出粒子系统。在实际的游戏开发过程中,我们一般都会为粒子系统开发一个专用的编辑器,它应该具有Cocos2d-x粒子系统中的所用属性并能编辑后保存为PLIST文件以方便游戏使用。比如这样:

粒子系统深入分析三部曲结束了,恰逢新的一年到来之际,我衷心的祝愿各位同学能够2013身体健康,事业有成。下课!

Cocos2d-x2.0 各种粒子效果详解相关推荐

  1. Android 吸入动画效果详解(仿mac退出效果)

    转载自:http://m.blog.csdn.net/blog/leehong2005/9127095 [转]Android 吸入动画效果详解 1,背景 吸入(Inhale)效果,最初我是在iOS上面 ...

  2. mysql8.0日期类型_mysql8.0.19基础数据类型详解

    mysql基础数据类型 mysql常用数据类型概览 ![1036857-20170801181433755-146301178](D:\笔记\mysql\复习\1036857-201708011814 ...

  3. 微投抖的1080_抖出来的算真4K吗?DLP XPR抖动原理及效果详解

    抖出来的算真4K吗?DLP XPR抖动原理及效果详解 2019-03-28 16:17:30 69点赞 137收藏 61评论 相比4K电视的快速普及,4K投影的进度就慢太多了.原生4K家用投影主要是L ...

  4. marlin2.0.5.4配置详解——个人记录

    marlin2.0.5.4配置详解--个人记录 串口波特率 主板类型 挤出机数量 混色打印 温度传感器 最大温度 挤出机保护 双轴联动结构 限位开关上拉 限位开关信号 电机使能信号 禁用电机 电机运动 ...

  5. html5局部放大图片,js实现图片局部放大效果详解

    图片局部放大效果结合的知识点主要是DOM的操作,以及事件的应用,所以首先要对DOM的操作有一定了解,其次能对事件的应用有一定的累积. 如上图,可以看到,这是放大镜的基本效果,主要分成左右两个部分.左边 ...

  6. openlayers6【十九】vue HeatmapLayer热力图层实现热力图效果详解

    文章目录 1. 写在前面 2. Heatmap 类实现热力图 2.1 Heatmap 参数 2.2 实现热力图 3. 完整代码 4. 添加删除map图层的方法 5. 热力图自身的get,set方法 1 ...

  7. 关于android的4.2的0文件夹的详解

    关于android的4.2的0文件夹的详解 ---- android 4.0 ---- 在galaxy nexus(GN)手机上userdata分区很大,被挂在/data目录,用户的数据通常是放在sd ...

  8. mysql8.0.11 安装顺序_mysql 8.0.11 安装步骤详解

    本文为大家分享了mysql 8.0.11 安装步骤,供大家参考,具体内容如下 第一步:下载安装包 MYSQL官方下载地址:官方下载 这里第一项是在线安装,第二项是离线包安装,我选择的是第二项(不用管你 ...

  9. ASP.NET2.0 ObjectDataSource的使用详解

    介绍ObjectDataSource的使用,按照dudu的建议为了节省篇幅,做成连接,这里仅提供前三篇,后面还有几篇以后再补充吧 ASP.NET2.0 ObjectDataSource的使用详解(1) ...

  10. android ble蓝牙接收不到数据_Android蓝牙4.0 Ble读写数据详解 -2

    Android蓝牙4.0 Ble读写数据详解 -2 上一篇说了如何扫描与链接蓝牙 这篇文章讲讲与蓝牙的数据传输,与一些踩到的坑. 先介绍一款调试工具,专门调试Ble蓝牙的app.名字叫:nRF-Con ...

最新文章

  1. 步步为营 .NET 设计模式学习笔记 十四、Decorator(装饰模式)
  2. Flutter之Dart入门
  3. Elasticsearch聚合初探——metric篇
  4. Qt (5.10.0)for android
  5. Eclipse导入GitHub项目两处报错处理
  6. 什么是PermGen泄漏?
  7. innerHTML、innerText和outerHTML、outerText的区别
  8. OpenCV中反向投影
  9. 阿里云面向制造业推出防疫复工数字化方案 复工效率提升50%以上
  10. 外贸业务员会计算机知识,外贸业务员、电子商务
  11. [RL] 使用 dockerfile 构建 atari 环境
  12. 深入ASP.NET 2.0的提供者模型
  13. windows server 2012 AD 活动目录部署系列(三)加入域并创建域用户
  14. win11提示windows许可证即将过期
  15. HHL论文第二弹(基本过程)
  16. 有个exe文件删不掉怎么办
  17. 三峡大学校赛----十万桃花图(线性基)
  18. VScode 设置 背景图片
  19. 微信CRM六大模块详解
  20. Python requests库Proxy代理问题

热门文章

  1. maya中英转换插件1.3 更新发布及教程
  2. 计算机考试后进先出,事业单位考试计算机基础知识:建立单链表——后进先出表...
  3. 获取多边形的最大最小坐标
  4. 【服务器风扇静音】确定风扇线序定义的通用方法——以IBM SystemX 3630 M4为例
  5. NanoPi-NEO——初体验
  6. 概率统计及其应用第三章知识总结_高中数学130分,知识点最全总结,高分必看!...
  7. 微信小程序前端设计(超级实用哦)
  8. linux 股票指南针,Android 利用方向传感器实现 指南针
  9. linux下解压rpm包,linux下 各种解压文件使用方法
  10. 货币的时间价值及股票估值