Cocos2dx 3.0 过渡篇(十三) action的用法从一个故事说起

本篇博客来自star特530,转载请注明出处。http://blog.csdn.net/start530/article/details/20153367
-------------
动作到底该怎么玩?说的也就是runAction这货了。
如果你觉得本文还是在写像MoveTo,SacleTo这类动作的用法的话,那你就错了。那样不够厚道。当然了,像Sequence,Spawn这类的东西多少也是会涉及到一点的。那到底要写什么呢?我们的故事从这里开始。

首先我们创建俩精灵,就命名为boy 和 girl 吧。

[cpp] view
plain
copy

  1. auto size = Director::getInstance()->getWinSize();  
  2.     
  3. auto boy = Sprite::create("boy.png");  
  4. boy->setPosition(Point(0,size.height/2));//将boy的位置设置在最左边  
  5. this->addChild(boy,1);  
  6.   
  7. auto girl = Sprite::create("girl.png");  
  8. girl->setPosition(Point(size.width,size.height/2));//将girl的位置设置在最右边  
  9. this->addChild(girl,1);  

(故事的开始,boy 和 girl互相都不认识,直到有一天,俩人相遇了)
boy 和 girl 同时运动到场景中间

[cpp] view
plain
copy

  1. boy->runAction(MoveTo::create(1.0f,Point(size.width/2-20,size.height/2)));//boy的速度明显比girl的快。  
  2. girl->runAction(MoveTo::create(1.5f,Point(size.width/2 +10,size.height/2)));  

(boy看到girl的那一刻,惊呆了。他知道,她就是他一直在寻找的那个人。这,就是一见钟情)
boy用原地旋转360 + 全身血液膨胀来表达他的激动心情。表现方式有两种:

[cpp] view
plain
copy

  1. //1、边旋转边全身膨胀  
  2. boy->runAction(Spawn::create(RotateBy::create(1.0f,360),ScaleTo::create(1.0f,1.2f),NULL));  
  3.   
  4. //2、先旋转完再全身膨胀  
  5. boy->runAction(Sequence::create(RotateBy::create(1.0f,360),ScaleTo::create(1.0f,1.2f),NULL));  

(girl 看到 膨胀后的 boy,不禁觉得 boy好是高大威风(吐槽!),于是芳心暗许)
这里表现的动作就是 girl要在boy旋转+放大的动作做完后,才表现出她的...额,她的什么来着?对了,女的比较活泼,应该跳起来。恩,于是girl跳了起来。

[cpp] view
plain
copy

  1. //这里的重点是girl应该怎样才能在boy做完action后执行她的动作呢?有以下几种办法  
  2. //1、用延迟的DelayTime来实现,也就是boy运动完后延迟几秒,然后让girl运动  
  3.   
  4. //延迟2.5s,用1s时间跳了3次,跳跃高度100像素,并且向右移动了30像素  
  5. girl->runAction(Sequence::create(DelayTime::create(2.5f),JumpBy::create(1.0f,Point(30,0),100,3),NULL));  
  6.   
  7.   
  8. //2、用回调函数实现,当boy完成后,写一个lambda表达式来实现girl要做的动作(lambda表达式的使用可以参考我上一篇博客)  
  9.   
  10. boy->runAction(Sequence::create(RotateBy::create(1.0f,360),ScaleTo::create(1.0f,1.2f),  
  11.         CallFunc::create([=]()  
  12.         {  
  13.             //用1s时间跳了3次,跳跃高度100像素,并且向右移动了30像素  
  14.             girl->runAction(JumpBy::create(1.0f,Point(30,0),100,3));  
  15.         }),NULL));  
  16.   
  17.           
  18. //3、用现成的接口TargetedAction();  
  19.   
  20. auto jump = JumpBy::create(1.0f,Point(30,0),100,3);//先写一个跳跃的动作  
  21. auto targetAct = TargetedAction::create(girl,jump);//写一个目标动作,将动作执行人girl和要执行的动作jump放入其中  
  22. //将girl的目标动作放入boy的sequence里去  
  23. boy->runAction(Sequence::create(RotateBy::create(1.0f,360),ScaleTo::create(1.0f,1.2f),targetAct,NULL));    

(最后的剧情就是俩人很快的就在一起了,虽然认识时间不长,但他俩有足够的时间来认识对方,了解对方。用四年的时间来证明自己的眼光是对的)
有情人终成眷属,故事的最后,允许我用一颗闪烁的心来表达对他们的祝福。希望他们能永远在一起!!!

[cpp] view
plain
copy

  1. //创建逐帧动画          
  2. auto spriteFrameCache = SpriteFrameCache::sharedSpriteFrameCache();    
  3. spriteFrameCache->addSpriteFramesWithFile("heart.plist");  //将动画图片的plist放入缓存中  
  4.   
  5. SpriteFrame* frame = NULL;  
  6. auto frameArray = Array::create();  
  7.   
  8. for(int i=0;i<10;i++)  
  9. {  
  10.     frame = spriteFrameCache->spriteFrameByName(CCString::createWithFormat("%s%d.png","heart",i)->getCString());  
  11.     frameArray->addObject(frame);  
  12. }  
  13.   
  14. auto animation = Animation::createWithSpriteFrames(frameArray,0.15f);  
  15. auto animate = Animate::create(animation);//创建一个动画  
  16.   
  17. auto heard_sp = Sprite::create("heart.png");  
  18. heard_sp->setPosition(Point(size.width/2,size.height-200));  
  19. heard_sp->runAction(animate);//播放动画  
  20. this->addChild(heard_sp,2);  

故事简单,过程却没那么容易,结局也没想象的那么美好。

本篇博客来自star特530,转载请注明出处。http://blog.csdn.net/start530/article/details/20153367

时间: 2024-10-28 02:36:14

Cocos2dx 3.0 过渡篇(十三) action的用法从一个故事说起的相关文章

Cocos2dx 3.0 过渡篇(十五)帧动画的存储播放

前两篇博文用恶搞的形式写了action的相关使用,这算是自己的一种尝试,也可以说是心情的发泄.本篇是action三板斧的最后一板,经过深思熟虑后,我决定就用正常人的方式写吧... 这次主要介绍动画的创建即存储,要实现的功能有:1.创建四组动画,并存放至Array中: 2.创建四个虚拟方向按钮,控制精灵移动与播放相应方向的动画: -------------------------------------------------------------------------------------

Cocos2dx 3.0 过渡篇(四) 创建项目

尊重原创,转载请注明来自:star特530的CSDN博客 http://blog.csdn.net/start530/article/details/18620001 前天参加同学的婚礼,喝酒喝得差点没把胃都给吐出来.昨天一天 请假在家里休养.今早原地满血复活,觉得有必要再写篇博客,告诉大家,我又回来啦. 话说应该写点什么内容呢?干脆写个在3.0Alpha1版本上创建项目的流程吧,就当做笔记. 在Cocos2dx 3.0 Beta版本创建项目的方式已经更改,由于我近阶段都是用Alpha1版本开发

Cocos2dx 3.0 过渡篇(十二) lambda表达式的使用

本篇博客来自star特530,转载请注明出处.http://blog.csdn.net/start530/article/details/19913611 Cocos2dx 3.0 版本后加入了lambda表达式,或者说C++ 11终于引入了lambda表达式,那么,什么是lambda表达式呢? 例如调用<algorithm>中的std::sort,ISO C++ 98 的写法是要先写一个compare函数: [cpp] view plaincopy bool compare(int &

Cocos2dx 3.0 过渡篇(二) 事件回调

尊重原创,转载请注明来自:star特530的CSDN博客 http://blog.csdn.net/start530/article/details/18216679 3.0 后的事件回调函数接口都不一样了,例如按钮的menu_selector(),update的 schedule_selector等,都已成明日黄花.而新的回调接口,则由四个CC_CALLBACK取代. 下面先举例一些不同的调用方法: 1.按钮:CC_CALLBACK1 [cpp] view plaincopy 2.0   Me

Cocos2dx 3.0 过渡篇(五) 随机数的获取

本来上午是要转载一篇看起来还不错的博客,被cocos2dx官方微博推荐过.谁知道早上打开链接时那篇博客已经转为私密了.早知道昨晚就应该复制一下内容,今天厚脸皮的来篇原创岂不妙哉.哈哈. 1.简单的随机数用法:CCRANDOM_0_1 示例如下: [cpp] view plaincopy int HelloWorld::getRand(int start,int end)   {    float i = CCRANDOM_0_1()*(end-start+1)+start;  //产生一个从st

Cocos2dx 3.0 过渡篇(十)资源加载进度条Loading...

尊重原创,转载请注明来自:star特530的CSDN博客 http://blog.csdn.net/start530/article/details/19420317 本来这篇博文是昨晚就要写的,可是因为今早要去参加考驾照相关的体检,而我最害怕的就是视力没能达到5.0,毕竟这阶段对着屏幕的时间过久. 所以呢,昨晚我几乎没碰电脑,没玩手机,早睡早起.体检顺利通过! 首先,我要说的是:这次我要写的主题是进度条. 额,等等,先收起你手里愤怒的西瓜刀.我也才知道TestCpp也有这个例子啊.不过Test

Cocos2dx 3.0 过渡篇(三) 触摸机制

尊重原创,转载请注明来自:star特530的CSDN博客 http://blog.csdn.net/start530/article/details/18325493 本来在中午休息时间打算大展拳脚,好好写一篇新触摸机制相关的博文,结果,等真正下手的时候才发现无从下手,很多地方自己都说不清,赶紧看了下testCpp,才发现原来是这样,还可以这样,哦?这样都行?哎,我还是太年轻了.   咱也只能挑简单的讲了. 假设要实现拖动一个精灵移动,那我们的步骤是: 1. 创建一个精灵sprite: 2.一个

Cocos2dx 3.0 过渡篇(九)浅谈容器Map

尊重原创,转载请注明来自:star特530的CSDN博客 http://blog.csdn.net/start530/article/details/19284301 本篇接着上一篇的容器继续唠叨,了解上一篇:http://blog.csdn.net/start530/article/details/19170853 既然Vector是对比Array,那么Map就对比Dictionary吧.1.创建 [cpp] view plaincopy auto sp1 = Sprite::create("

Cocos2dx 3.0 过渡篇(十一) xml文档的读取与调用

尊重原创,转载请注明来自:star特530的CSDN博客 http://blog.csdn.net/start530/article/details/19632869 这阶段很忙,灰常忙,人又感冒了.前两天去报了驾校,所以下班回家后都在突击科目一,争取下周就去考.话说我们这边驾校报名费要六千,全国还有其他地方有这么高的吗? -------------------------------- 前天有人问我beta2 要如何读取xml文档,我刚要说用array的相关接口去读取,才想起beta之后早没有