cocos2d-x 3.6版连连看开始界面动画,cocos2d-x3.6

  次阅读 来源:互联网(转载协议) 2015-09-28 11:21 我要评论(0)

cocos2d-x 3.6版连连看开始界面动画,cocos2d-x3.6

我的博客:http://blog.csdn.net/dawn_moon

上一篇文章讲了开始界面的几个主要元素,背景,白云,倒影,岛及其倒影,沙滩等。里面稍微难一点的就是序列帧动画,延时动作序列,比如船的动画效果。船的来回游荡的动画稍微有一点复杂,里面由很多动作组成一个序列,比如翻转,移动,移动的逆动作,序列包装,无限重复动作包装等。不过代码很清晰,看不懂的可以下面留言。

这一篇讲几个比较高难度的动作,学完之后一定充满了快感。哈哈~~

首先是海浪的动画,然后是海鸥的动画,然后是一个play按钮和回调。

可能看起来很简单,但是其实还是有很多知识点的。网上有一篇文章,他实现的方式是用一个动画接一个回调,回调函数里面是另一个动作来完成的。我这里不这么做,我就纯动作序列。

这个海浪有点特别,它的动画是两个纹理来完成的,潮起的时候是一个纹理,潮落的时候是另一个纹理。那么怎么样用两个精灵来做一个动画呢,有方法吗。

当然是有的,不然我就不讲了。

这里用到一个比较高级的动作,叫做TargetedAction,这个动作有连个参数,一个是动作,另一个是要执行这个动作的目标。好了,有了这个东西就好办了。

思路是这样,海浪1执行一个动作序列,序列里面有一个TargetedAction动作,这个TargetedAction动作的执行者是海浪2,它又会执行自己的一个动作序列,那么连起来就是一个潮涨潮落的动作了。看代码

// 海浪1

auto wave = Sprite::createWithTexture(textureCache->getTextureForKey(s_backgound_sea1));

wave->setOpacity(0);

wave->setPosition(wSize.width / 2 , 140 * 2);

addChild(wave);

// 海浪2

auto wave2 = Sprite::createWithTexture(textureCache->getTextureForKey(s_backgound_sea2));

wave2->setPosition(wSize.width / 2 , 100 * 2);

wave2->setOpacity(0);

addChild(wave2);

// 两组动画,知识点比较多

auto waveMoveBy = MoveBy::create(4.0, Vec2(0, -80));

// 由暗到明

auto fadeIn = FadeIn::create(3.0);

// 由明到暗

auto fadeOut = FadeOut::create(1.0);

// 放到初始位置

auto place1 = Place::create(Vec2(wSize.width / 2 , 140 * 2));

// 同时进行动作,时间长度由最长的动作决定

auto spawn = Spawn::create(waveMoveBy, Sequence::create(fadeIn, fadeOut, nullptr), nullptr);

// 海浪2的动作

auto spawn2 = Spawn::create(waveMoveBy->clone()->reverse(), Sequence::create(fadeIn->clone(), fadeOut->clone(), nullptr), nullptr);

// 海浪2的初始位置

auto place2 = Place::create(Vec2(wSize.width / 2 , 100 * 2));

// target 动作,指定tartget的动作

auto targetAction = TargetedAction::create(wave2, Sequence::create(spawn2, place2,nullptr));

// 延迟2s

auto delay = DelayTime::create(2.0);

wave->runAction(RepeatForever::create(Sequence::create(spawn, targetAction, place1, delay, nullptr)));

每一行都加了注释,里面的动作比较多,有Place,FadeIn,FadeOut,MoveBy,Spawn,TargetedAction,RepeatForever。知识点蛮多的哈。

这一套组合起来效果还不错,有疑问可以留言。

然后再来看海鸥的动作。

本站部分文章来源于网络以及网友投稿,本站只负责对文章进行整理、排版、编辑,是出于传递更多信息之目的,并不意味着赞同其观点或证实其内容的真实性。如果您有什么意见或建议,请联系QQ28-1688-302!

人工智能实验室
相关文章相关文章
  • Oculus公布原型机,大幅度提升可视角,能实现140°的视场水平

    Oculus公布原型机,大幅度提升可视角,能实现140°的视场水平

  • teamLab创始人猪子寿之: 抛去衣食住行,我还剩下什么?

    teamLab创始人猪子寿之: 抛去衣食住行,我还剩下什么?

  • 2018深圳国际人工智能展览会 2018 shenzhen International Artif

    2018深圳国际人工智能展览会 2018 shenzhen International Artif

  • Michael I. Jordan带你解读百万奖金ATEC蚂蚁人工智能大赛

    Michael I. Jordan带你解读百万奖金ATEC蚂蚁人工智能大赛

网友点评网友点评
阅读推荐阅读推荐

据外媒报道,STEER打造了首款完全自动驾驶停车技术,旨在使常规车辆转变为无人驾驶车辆。STEER的首款技术应用是4级自动驾驶及网络安全停车...

近日,美国软性机器抓手制造商 Soft Robotics 宣布,获得 2000 万美元的融资,本轮投资者包括 Scale Venture Partners,Calibrate Ventures...

据外媒报道,加州车管局发布了《2017自动驾驶脱离报告(California Autonomous Vehicle Disengagement Reports)》,其中谈及了脱离的具体...

用人机语音交互,来解决智能家居适老的问题;通过家庭门禁与安防套件、空气净化套件、可燃气体与有害气体监控套件等相互联动,在不同生活情...