Cocos2d-x   发布时间:2022-05-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了cocos2dx3.2 实现splash屏幕图片秀滚动大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

嘿,秀一下效果图:


让这四张美女图片,循环的向上滚动,那么如何做的呢?

首先准备四张图片分别命名:

Beauty1,Beauty2,Beauty3,Beauty4

然后在Splash类中添加_vcSprites,用来保存精灵


class SplashScene : public cocos2d::Scene

{

public:

CREATE_FUNC(SplashScene);

virtual bool init();

virtual void update(float dt);

void playerAction();

void beginGame();

private:

SplashScene();

virtual ~SplashScene();

Vector<Sprite*> _vcSprites;

int _index;

};


在init中将精灵创建,并push到 _vcSprites

this->schedule(schedule_SELEctor(SplashScene::update));

for (int j = 0; j < 2; ++j) //两分同样的精灵

{

for (int i = 0; i < 4; ++i)

{

auto filename = String::createWithFormat("Beauty%d.png",i + 1);

auto sp = Sprite::create(filename->getCString());

sp->setAnchorPoint(Vec2(0.5f,1.0f)); //设置锚点为上边中点

sp->setPosition(VisibleRect::top().x,VisibleRect::top().y - i * sp->getContentSize().height -j * sp->getContentSize().height * 4

);

this->addChild(sp);

_vcSprites.pushBACk(sp);

}

}


然后在SplashScene::update中,实现精灵坐标的转变:


void SplashScene::update(float dt)

{

for(auto it = _vcSprites.begin(); it != _vcSprites.end(); ++it)

{

y = (*it)->getPositionY() + 3;

(*it)->setPositionY(y);

if( (*it)->getPositionY() - (*it)->getContentSize().height > VisibleRect::top().y)

{

(*it)->setPositionY(VisibleRect::top().y - (*it)->getContentSize().height * 7);

//7代表的是最后一张精灵


}

}

}

ok.

大佬总结

以上是大佬教程为你收集整理的cocos2dx3.2 实现splash屏幕图片秀滚动全部内容,希望文章能够帮你解决cocos2dx3.2 实现splash屏幕图片秀滚动所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。