当前位置: 首页>>代码示例>>C++>>正文


C++ ParticleBatchNode类代码示例

本文整理汇总了C++中ParticleBatchNode的典型用法代码示例。如果您正苦于以下问题:C++ ParticleBatchNode类的具体用法?C++ ParticleBatchNode怎么用?C++ ParticleBatchNode使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了ParticleBatchNode类的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: pause

void GameLevel::dieImpl() {
  mDieFlag = false;

  pause();

  // Camera effect.
  getGameLayer()->getBlockRoot()->runAction(CameraShake::create(0.3f, 10));

  auto hero = getHero();

  // Particle effect.
  ParticleSystem *ps = ParticleSystemQuad::create(DIE_FX_NAME);
  ParticleBatchNode *batch = ParticleBatchNode::createWithTexture(ps->getTexture());
  batch->addChild(ps);
  batch->setPosition(hero->getRenderer()->getPosition());
  batch->setCameraMask((unsigned short) CameraFlag::USER2);
  mGameLayer->getBlockRoot()->addChild(batch, ZORDER_DIE_FX, DIE_FX_TAG);

  hero->getRenderer()->getNode()->runAction(Sequence::create(ScaleTo::create(0.2, 0.1, 0.1),
                                                             CallFunc::create([this] {
    getHero()->getRenderer()->setVisible(false);
  }), nullptr));

  mGameLayer->runAction(Sequence::create(DelayTime::create(0.5), CallFunc::create([this] {
    enableGame(false);
    enableGame(true);
  }), nullptr));
}
开发者ID:wangyanxing,项目名称:JumpProject,代码行数:28,代码来源:GameLevel.cpp

示例2: loadFx

void GameLevel::loadFx() {
  for (auto i : mEffects) {
    ParticleSystem *ps = ParticleSystemQuad::create(i);
    ParticleBatchNode *batch = ParticleBatchNode::createWithTexture(ps->getTexture());
    batch->addChild(ps);
    mGameLayer->getBlockRoot()->addChild(batch, ZORDER_PARTICLE);
    batch->setCameraMask((unsigned short) CameraFlag::USER2);
    mFxNodes.push_back(batch);
  }
}
开发者ID:wangyanxing,项目名称:JumpProject,代码行数:10,代码来源:GameLevel.cpp

示例3: new

ParticleBatchNode* ParticleBatchNode::create(const std::string& imageFile, int capacity/* = kParticleDefaultCapacity*/)
{
    ParticleBatchNode * p = new (std::nothrow) ParticleBatchNode();
    if( p && p->initWithFile(imageFile, capacity))
    {
        p->autorelease();
        return p;
    }
    CC_SAFE_DELETE(p);
    return nullptr;
}
开发者ID:sebastianleecn,项目名称:Quick-Cocos2dx-Community,代码行数:11,代码来源:CCParticleBatchNode.cpp

示例4: ParticleBatchNode

ParticleBatchNode* ParticleBatchNode::create(const char* imageFile, unsigned int capacity/* = kParticleDefaultCapacity*/)
{
    ParticleBatchNode * p = new ParticleBatchNode();
    if( p && p->initWithFile(imageFile, capacity))
    {
        p->autorelease();
        return p;
    }
    CC_SAFE_DELETE(p);
    return NULL;
}
开发者ID:CryQ,项目名称:coclua,代码行数:11,代码来源:CCParticleBatchNode.cpp

示例5: setBatchNode

void ParticleSystemQuad::setBatchNode(ParticleBatchNode * batchNode)
{
    if( _batchNode != batchNode )
    {
        ParticleBatchNode* oldBatch = _batchNode;

        ParticleSystem::setBatchNode(batchNode);

        // NEW: is self render ?
        if( ! batchNode )
        {
            allocMemory();
            initIndices();
            setTexture(oldBatch->getTexture());
            if (Configuration::getInstance()->supportsShareableVAO())
            {
                setupVBOandVAO();
            }
            else
            {
                setupVBO();
            }
        }
        // OLD: was it self render ? cleanup
        else if( !oldBatch )
        {
            // copy current state to batch
            V3F_C4B_T2F_Quad *batchQuads = _batchNode->getTextureAtlas()->getQuads();
            V3F_C4B_T2F_Quad *quad = &(batchQuads[_atlasIndex] );
            memcpy( quad, _quads, _totalParticles * sizeof(_quads[0]) );

            CC_SAFE_FREE(_quads);
            CC_SAFE_FREE(_indices);

            glDeleteBuffers(2, &_buffersVBO[0]);
            memset(_buffersVBO, 0, sizeof(_buffersVBO));
            if (Configuration::getInstance()->supportsShareableVAO())
            {
                glDeleteVertexArrays(1, &_VAOname);
                GL::bindVAO(0);
                _VAOname = 0;
            }
        }
    }
}
开发者ID:253056965,项目名称:cocos2d-x-lite,代码行数:45,代码来源:CCParticleSystemQuad.cpp

示例6: CCLOG

void GameScene::onTouchEnded(cocos2d::Touch *touch, cocos2d::Event *unused_event)
{
    Vec2 size = Director::getInstance()->getVisibleSize();
    
    auto HandAnimation = Animation::createWithSpriteFrames(mHandAnimations, 0.05);
    auto HandAnimate = Animate::create(HandAnimation);
    mHandSprite->runAction(HandAnimate);

    if (mKnife == nullptr) return;
    
    CCLOG ("%f\n", mKnife->getKnife()->getPositionY());
    if (mKnife->isInCutterEdge())
    {
        
        // 失败脸部表情
        auto FaceAnimation = Animation::createWithSpriteFrames(mFaceAnimationFail, 1);
        auto FaceAnimate = Animate::create(FaceAnimation);
        mFaceSprite->runAction(FaceAnimate);
        
        MusicButton::getInstance()->playCatchCutterEdge();
        
        // 停止刀子
        mKnife->getKnife()->getPhysicsBody()->setVelocity(Vec2(0, 0));
        mKnife->getKnife()->getPhysicsBody()->setGravityEnable(false);
        
        // 流血效果
        ParticleSystem* BloodPar = ParticleSystemQuad::create("blood.plist");
        BloodPar->retain();
        ParticleBatchNode* BloodNode = ParticleBatchNode::createWithTexture(BloodPar->getTexture());
        BloodNode->addChild(BloodPar);
        BloodNode->setAnchorPoint(Vec2::ZERO);
        BloodNode->setPosition(Vec2(250, 300));
        addChild(BloodNode, 10);
        BloodPar->release();
        
        // NG
        scheduleOnce(schedule_selector(GameScene::gameOver), 1);
    }
    else if (mKnife->isInHilt())
    {
        // 成功脸部表情
        auto FaceAnimation = Animation::createWithSpriteFrames(mFaceAnimationSucc, 0.5);
        auto FaceAnimate = Animate::create(FaceAnimation);
        mFaceSprite->runAction(FaceAnimate);
        
        MusicButton::getInstance()->playCatchHilt();
        
        // 刀子动作
        mKnife->getKnife()->getPhysicsBody()->setVelocity(Vec2(0, 0));
        mKnife->getKnife()->getPhysicsBody()->setGravityEnable(false);
        auto KnifeMove = MoveTo::create(0.3, Vec2(Vec2(size.x-140, size.y-82)));
        auto KnifeScale = ScaleTo::create(0.4, 0.1);
        auto KnifeSpa = Spawn::create(KnifeMove, KnifeScale, NULL);
        mKnife->getKnife()->runAction(KnifeSpa);
        
        scheduleOnce(schedule_selector(GameScene::gotKnife), 0.5);
    }
    else
    {
        // Miss表情
        auto FaceAnimation = Animation::createWithSpriteFrames(mFaceAnimationMiss, 0.2);
        auto FaceAnimate = Animate::create(FaceAnimation);
        mFaceSprite->runAction(FaceAnimate);
    }
}
开发者ID:DPC11,项目名称:Knifes-game,代码行数:65,代码来源:GameScene.cpp

示例7: addJointForHero

bool GameScene::init()
{
    if (!Layer::init()) {
        return false;
    }
    Size winSize =Director::getInstance()->getWinSize();
    ParticleSystemQuad* qual = ParticleSystemQuad::create("res/effect/dots_birth.plist");
    ParticleBatchNode* bNode = ParticleBatchNode::createWithTexture(qual->getTexture());
    bNode->addChild(qual);
    this->addChild(bNode);
    qual->setPosition(Vec2(320,568));
    auto spawnHero = CallFunc::create([=]()
    {
        m_hero = Hero::create();
        this->addChild(m_hero);
        addJointForHero();
        bNode->removeFromParent();
    });
    auto spawnMobs = CallFunc::create([=]()
    {
        Enemy* enemy = Enemy::create();
        enemy->setPosition(Vec2(400,200));
        addChild(enemy);
        enemy->moveToHero(m_hero->getCurMovingNode()->getPosition());
    });
    auto spawnHeroSequ = Sequence::create(DelayTime::create(0.8),spawnHero,spawnMobs,NULL);
    runAction(spawnHeroSequ);
    EventListenerTouchOneByOne* listenner = EventListenerTouchOneByOne::create();
    listenner->onTouchBegan = [=](Touch* touch,Event* evt)
    {
        m_hero->swapCircle();
        Vec2 pos = m_hero->getCurMovingNode()->getPosition();
        if( shoudMoveCameraPos(pos) )
            m_camera->runAction(MoveTo::create(0.3,pos));
//        m_hero->changeState();
        return true;
    };
    _eventDispatcher->addEventListenerWithSceneGraphPriority(listenner,this);


    Sprite* bg = Sprite::create("res/bg_1.png");
    addChild(bg,-1);
    bg->setPosition(winSize/2);
    bg->setScale(2,3);

    auto edge = Node::create();
    edge->setPosition(winSize/2);
    PhysicsBody* edgeBody = PhysicsBody::createEdgeBox(winSize*1.3,PhysicsMaterial(PHYSICS_INFINITY,0,0),10,Vec2(0,0));
    edge->setPhysicsBody(edgeBody);
    edgeBody->setDynamic(true);
    addChild(edge);
    edgeBody->setCategoryBitmask(0xFFFFFFFF);
    edgeBody->setCollisionBitmask(0xFFFFFFFF);
    edgeBody->setContactTestBitmask(0X00001000);
    EventListenerPhysicsContact* physicsListenner = EventListenerPhysicsContact::create();
    physicsListenner->onContactBegin=[=](PhysicsContact& contact)
    {
        //英雄和墙发生碰撞
        if ((contact.getShapeA()->getContactTestBitmask()|contact.getShapeB()->getContactTestBitmask()) == 0x11001000)
        {
            m_hero->reverse();
        }
        //英雄和食物发生碰撞
        else if ((contact.getShapeA()->getContactTestBitmask()|contact.getShapeB()->getContactTestBitmask()) == 0x11000100)
        {
            exchangeSide();
            if ((contact.getShapeA()->getContactTestBitmask()) == 0x00000100)
            {
                contact.getShapeA()->getBody()->getNode()->setVisible(false);
            }
            else if((contact.getShapeB()->getContactTestBitmask()) == 0x00000100)
            {
                contact.getShapeB()->getBody()->getNode()->setVisible(false);
            }
        }
        //英雄和怪物发生碰撞
        else if ((contact.getShapeA()->getContactTestBitmask()|contact.getShapeB()->getContactTestBitmask())== 0x11000110)
        {
            Vec2 contactPos = contact.getContactData()->points[0];
            ParticleSystemQuad* quad = ParticleSystemQuad::create("res/effect/die.plist");
            quad->setPosition(contactPos);
            ParticleBatchNode* batch = ParticleBatchNode::createWithTexture(quad->getTexture());
            batch->addChild(quad);
            addChild(batch);
            auto removeFunc = CallFunc::create([=](){
                batch->removeFromParent();
            });
            Sequence* sequ = Sequence::create(DelayTime::create(0.8f),removeFunc,NULL);
            runAction(sequ);
        }
        return true;
    };
    physicsListenner->onContactPreSolve = [=](PhysicsContact& contact,PhysicsContactPreSolve& preSlove)
    {
        CCLOG("PreSlove");
        return false;
    };
    physicsListenner->onContactPostSolve = [=](PhysicsContact& contact,const PhysicsContactPostSolve& postSlove)
    {
        CCLOG("PostSlove");
//.........这里部分代码省略.........
开发者ID:LOL808,项目名称:TwoDots,代码行数:101,代码来源:GameScene.cpp


注:本文中的ParticleBatchNode类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。