cocos2d-x 使用action实现各种动画效果
2013-07-24 17:50
537 查看
做项目遇到了很多动画效果,基本大多数使用action实现的,当然也可以自己在每一帧的时候自己去实现,原理基本一样的。
1、使用CCMoveTo左右快速抖动。
[cpp] view
plaincopy
CCPoint pointL=pointBg;
CCPoint pointR=pointBg;
pointL.x-=3;
pointR.x+=3;
CCMoveTo* moveLeft=CCMoveTo::actionWithDuration(0.08, pointL);
CCMoveTo* moveRight=CCMoveTo::actionWithDuration(0.08, pointR);
CCFiniteTimeAction* action= CCSequence::actions(moveLeft,moveRight,NULL);
CCActionInterval* actionShake=CCRepeatForever::actionWithAction((CCActionInterval*)action);
skillBg->stopAllActions();
skillBg->runAction(reSkillAnim);
pointBg就是你需要左右抖动的sprite。
CCMoveTo就是移动到哪里去,参数是移动时间,目的坐标点。(CCMoveBy是在当前位置移动多少距离,有点区别。)
CCSequence前面就说了,你可以看作为执行一个action的队列,遇到NULL就结束了。
因为是要实现不同的左右移动,所以我将左右移动包装了一下,包装成一个CCRepeatForever的action,它是不停的重复播放这个action。
2、CCJumpTo从一个地方跳跃到另外一个地方。
[cpp] view
plaincopy
CCJumpTo* mJumpTo = CCJumpTo::actionWithDuration(0.2f, mToPosition, 30.0f, 1);
第一个参数是跳远的时间,第二个参数是跳跃的目的点,第三个参数是跳跃的最大高度,第四个参数是跳跃的次数。
3、CCDelayTime 可以用来作为暂停停多长时间。、
[cpp] view
plaincopy
CCDelayTime *waiting=CCDelayTime::actionWithDuration(0.2f);
暂停0.2秒。
4、CCScaleTo 缩小/放大到。(区别CCScaleBy,缩小/放大多少)
[cpp] view
plaincopy
CCScaleTo* scale=CCScaleTo::actionWithDuration(0.5, 0.2);
第一个参数时间,第二次参数缩放倍数,=1正常大小,>1放大,<1缩小
5、CCRotateTo旋转角度。和上面一样。角度0-360。
6、CCWaves 和CCShaky3D
[cpp] view
plaincopy
1、使用CCMoveTo左右快速抖动。
[cpp] view
plaincopy
CCPoint pointL=pointBg;
CCPoint pointR=pointBg;
pointL.x-=3;
pointR.x+=3;
CCMoveTo* moveLeft=CCMoveTo::actionWithDuration(0.08, pointL);
CCMoveTo* moveRight=CCMoveTo::actionWithDuration(0.08, pointR);
CCFiniteTimeAction* action= CCSequence::actions(moveLeft,moveRight,NULL);
CCActionInterval* actionShake=CCRepeatForever::actionWithAction((CCActionInterval*)action);
skillBg->stopAllActions();
skillBg->runAction(reSkillAnim);
pointBg就是你需要左右抖动的sprite。
CCMoveTo就是移动到哪里去,参数是移动时间,目的坐标点。(CCMoveBy是在当前位置移动多少距离,有点区别。)
CCSequence前面就说了,你可以看作为执行一个action的队列,遇到NULL就结束了。
因为是要实现不同的左右移动,所以我将左右移动包装了一下,包装成一个CCRepeatForever的action,它是不停的重复播放这个action。
2、CCJumpTo从一个地方跳跃到另外一个地方。
[cpp] view
plaincopy
CCJumpTo* mJumpTo = CCJumpTo::actionWithDuration(0.2f, mToPosition, 30.0f, 1);
第一个参数是跳远的时间,第二个参数是跳跃的目的点,第三个参数是跳跃的最大高度,第四个参数是跳跃的次数。
3、CCDelayTime 可以用来作为暂停停多长时间。、
[cpp] view
plaincopy
CCDelayTime *waiting=CCDelayTime::actionWithDuration(0.2f);
暂停0.2秒。
4、CCScaleTo 缩小/放大到。(区别CCScaleBy,缩小/放大多少)
[cpp] view
plaincopy
CCScaleTo* scale=CCScaleTo::actionWithDuration(0.5, 0.2);
第一个参数时间,第二次参数缩放倍数,=1正常大小,>1放大,<1缩小
5、CCRotateTo旋转角度。和上面一样。角度0-360。
6、CCWaves 和CCShaky3D
[cpp] view
plaincopy
相关文章推荐
- cocos2d-x 使用action实现各种动画效果 .
- cocos2d-x 使用action实现各种动画效果
- cocos2d-x 使用action实现各种动画效果
- cocos2d-x 使用action实现各种动画效果
- coco2d-x 使用Action中的Animate实现动画效果
- 推荐9款使用CSS3实现的超酷动画效果
- 使用 SVG 来实现波浪 (wave) 动画效果
- 使用CCSpriteBatchNode实现动画效果
- Android入门(34)——第十一章 使用ViewFlipper实现屏幕切换动画效果
- ViewPager的PageTransformer 实现各种Page变换动画效果分析
- 使用HTML5和jQuery插件Reel实现一个超酷的星际争霸2兵种动画360度预览效果
- 使用CALayer的Mask实现注水动画效果
- 使用silverlight中的Storyboard实现动画效果
- 使用CSS3实现超炫的Loading(加载)动画效果
- 在安卓中使用Animation类实现基础动画效果
- 使用ViewFlipper实现屏幕切换动画效果
- 使用ObjectAnimator实现视图的动画效果(平移)
- iOS使用UICountingLabel实现数字变化的动画效果
- 使用NSTimer与UIView的动画,实现飘雪效果