Cocos2d-x built-in Particle System

Source: Internet
Author: User

Cocos2d-x built-in Particle System
From the class diagram, we can see that the Cocos2d-x has built-in 11 particles, the attributes of these particles are pre-defined, we can also modify some attributes in the program code, these attributes have been set in the instance in the previous section. Built-in Particle System

The built-in 11 particle system is described as follows:

You can call this operation to create a project. The particle blast effect belongs to the radius mode.

You can call this operation to create a project. Flame particle effect, which belongs to the gravity path mode.

You can call this operation to create a project. Fireworks particle effect, which belongs to the gravity mode.

. The particle effect is a gravity mode.

The sample code is as follows. Galaxy particle effect, which belongs to the radius mode.

You can call this operation to perform the following operations. Meteor particle effect, which belongs to the gravity mode.

You can call this operation to create a project. Vortex particle effect, which belongs to the radius mode.

The name of the object. The snow particle effect belongs to the gravity mode.

. Smoke particle effect, which belongs to the gravity mode.

. The effect of the Sun particles belongs to the gravity mode.

You can call this operation to perform operations on the object. Rain particle effect, which belongs to the gravity mode.

Each of these 11 particle systems has the following two create functions, which allow you to create particle objects.

Static participant explosion * create ()

Static maid (int numberofparticipant)

The numberofparticipant in the createwithtotalparticipant function is the number of particles initialized.

The attributes of these 11 kinds of particles vary depending on their emission modes.

Example: built-in Particle System

The following example shows the 11 built-in particle systems. In this example, the left figure shows an operation menu scenario. You can select the menu to go to the action scenario. In the action scenario, the effect of the selected particle system is displayed. Click the return button in the lower right corner to return to the menu scenario.

Next let's take a look at the specific program code. First, let's take a look at the HelloWorldScene. h file. Its code is as follows:

#ifndef __HELLOWORLD_SCENE_H__#define __HELLOWORLD_SCENE_H__ #include "cocos2d.h"#include "MyActionScene.h" typedef enum①{     kExplosion = 1    ,kFire    ,kFireworks    ,kFlower    ,kGalaxy    ,kMeteor    ,kRain    ,kSmoke    ,kSnow    ,kSpiral    ,kSun    } ActionTypes; ②  class HelloWorld : public cocos2d::Layer{public:    static cocos2d::Scene* createScene();    virtual bool init();      void OnClickMenu(cocos2d::Ref* pSender);        CREATE_FUNC(HelloWorld);}; #endif // __HELLOWORLD_SCENE_H__

Code ① ~ ② Define an enumeration type ActionTypes. 11 constants are defined in the enumeration type ActionTypes. These 11 constants correspond to 11 menu items.

Next let's take a look at the next scenario MyActionScene. Its MyActionScene. h code is as follows:

#ifndef __MYACTION_SCENE_H__#define __MYACTION_SCENE_H__ #include "cocos2d.h"#include "HelloWorldScene.h" class MyAction : public cocos2d::Layer{cocos2d::LabelBMFont* pLabel;① public:static cocos2d::Scene* createScene();    virtual bool init();virtual void onEnterTransitionDidFinish();②        CREATE_FUNC(MyAction);     void backMenu (cocos2d::Ref* pSender);③}; #endif // __MYACTION_SCENE_H__

In the header file, line ① defines the LabelBMFont member variable, which is used to display the name of the Particle System in the scene. The Code in line ② declares the onEnterTransitionDidFinish callback function, which overwrites the parent class function and will return it after the scenario appears. The Code in line ③ declares a callback function for the return menu.

The implementation code of MyActionScene: MyActionScene. ccp file. Its main code is as follows:

bool MyAction::init(){    if ( !Layer::init() )    {        return false;    }        Size visibleSize = Director::getInstance()->getVisibleSize(); auto pItmLabel = Label::createWithBMFont("fonts/fnt8.fnt", "
 
  setPosition(Point(visibleSize.width - 100, 100)); Menu* mn = Menu::create(backMenuItem,  NULL);mn->setPosition(Point::ZERO);this->addChild(mn); pLabel =  Label::createWithBMFont("fonts/fnt8.fnt", "");pLabel->setPosition(Point(visibleSize.width / 2, visibleSize.height - 50));this->addChild(pLabel, 3);     return true;} void MyAction::onEnterTransitionDidFinish(){   Layer::onEnterTransitionDidFinish(); ParticleSystem* system;        switch (this->getTag()) {①case kExplosion:            system = ParticleExplosion::create();            pLabel->setString("Explosion ");break;case kFire:            system = ParticleFire::create();            pLabel->setString("Fire");break;case kFireworks:            system = ParticleFireworks::create();            pLabel->setString("Fireworks");break;case kFlower:            system = ParticleFlower::create();            pLabel->setString("Flower");break;case kGalaxy:            system = ParticleGalaxy::create();            pLabel->setString("Galaxy");            break;case kMeteor:            system = ParticleMeteor::create();            pLabel->setString("Meteor");break;case kRain:            system = ParticleRain::create();            pLabel->setString("Rain");break;case kSmoke:            system = ParticleSmoke::create();            pLabel->setString("Smoke");break;        case kSnow:            system = ParticleSnow::create();            pLabel->setString("Snow");break;case kSpiral:            system = ParticleSpiral::create();            pLabel->setString("Spiral");break;case kSun:            system = ParticleSun::create();②            pLabel->setString("Sun");break;    }     Size visibleSize = Director::getInstance()->getVisibleSize();system->setPosition(Point(visibleSize.width / 2, visibleSize.height / 2));     this->addChild(system);}
 

In the initialization scenario of the MyAction: init () function, create a particle system object in the MyAction: onEnterTransitionDidFinish () function, instead of creating a particle system object in the MyAction: onEnter () function, this is because the scenario is not displayed when the MyAction: onEnter () function is called. If an explosion is created in the function, the particle system is displayed once. When the scenario is displayed, the explosion is over, and we will not see the effect.

Code ① ~ Line 2 creates 11 particle systems. Here, their default attribute values are used when creating particle systems. The pLabel-> setString ("xxx") function is used to set the content of the tag in the scenario, so that the name of the particle system is displayed after entering the scenario.



For more information, please refer to the first domestic Swift book "Swift development guide" for discussion. Website: http://www.51work6.com/swift.phpwelcome to the swifttechnology discussion group: 362298.pdf

Welcome to Zhijie iOS public classroom Platform


Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.