[cocos2d-x]场景动画切换过渡大全

简介: 各种各样比较炫的场景切换动画,废话少说,直接上代码: void StartScene::beginGame(){ CCLog("beginGame"); //CCTransitionScene *trans = CCTrans...

各种各样比较炫的场景切换动画,废话少说,直接上代码:

void StartScene::beginGame()
{
    CCLog("beginGame");
    
    //CCTransitionScene *trans = CCTransitionScene::create(2, level);
    //CCDirector::sharedDirector()->replaceScene(level);
    //场景切换
    CCTransitionScene *reScene = NULL;
    CCScene *s = LevelScene::scene();
    
    float t = 1.2f;
    
    //  CCTransitionJumpZoom
    //    作用: 创建一个跳动的过渡动画
    //    参数1:过渡动作的时间
    //    参数2:切换到目标场景的对象
    //    reScene = CCTransitionJumpZoom ::create(t , s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionProgressRadialCCW
    //    作用: 创建一个扇形条形式的过渡动画, 逆时针方向
    //    参数1:过渡动作的时间
    //    参数2:切换到目标场景的对象
    //    reScene = CCTransitionProgressRadialCCW::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionProgressRadialCW
    //    作用: 创建一个扇形条形式的过渡动画, 顺时针方向
    //    参数1:过渡动作的时间
    //    参数2:切换到目标场景的对象
    //    reScene = CCTransitionProgressRadialCW::create(t,s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionProgressHorizontal
    //    作用: 创建一个水平条形式的过渡动画,
    //    参数1:过渡动作的时间
    //    参数2:切换到目标场景的对象
    //    reScene = CCTransitionProgressHorizontal ::create(t,s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionProgressVertical
    //    作用: 创建一个垂直条形式的过渡动画,
    //    参数1:过渡动作的时间
    //    参数2:切换到目标场景的对象
    //    reScene = CCTransitionProgressVertical::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    
    //    CCTransitionProgressInOut
    //    作用: 创建一个由里向外扩展的过渡动画,
    //    参数1:过渡动作的时间
    //    参数2:切换到目标场景的对象
    //    reScene = CCTransitionProgressInOut::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionProgressOutIn
    //    作用: 创建一个由外向里扩展的过渡动画,
    //    参数1:过渡动作的时间
    //    参数2:切换到目标场景的对象
    //    reScene = CCTransitionProgressOutIn::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionCrossFade
    //    作用:创建一个逐渐透明的过渡动画
    //    参数1:过渡动作的时间
    //    参数2:切换到目标场景的对象
    //    reScene = CCTransitionCrossFade::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionPageTurn
    //    作用:创建一个翻页的过渡动画
    //    参数1:过渡动作持续的时间
    //    参数2:切换的目标场景的对象
    //    参数3:是否逆向翻页
    //    reScene = CCTransitionPageTurn::create(t, s, false);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionFadeTR
    //    作用:创建一个部落格过渡动画, 从左下到右上
    //    参数1:过渡动作持续的时间
    //    参数2:切换的目标场景的对象
    //    reScene =CCTransitionFadeTR::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionFadeBL
    //    作用:创建一个部落格过渡动画, 从右上到左下
    //    参数1:过渡动作持续的时间
    //    参数2:切换的目标场景的对象
    //    reScene = CCTransitionFadeBL::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionFadeUp
    //    作用:创建一个从下到上,条形折叠的过渡动画
    //    参数1:过渡动作持续的时间
    //    参数2:切换的目标场景的对象
    //    reScene= CCTransitionFadeUp::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(s);
    
    //    CCTransitionFadeDown
    //    作用:创建一个从上到下,条形折叠的过渡动画
    //    参数1:过渡动作持续的时间
    //    参数2:切换的目标场景的对象
    //    reScene = CCTransitionFadeDown::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionTurnOffTiles
    //    作用:创建一个随机方格消失的过渡动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
        reScene= CCTransitionTurnOffTiles::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionSplitRows
    //    作用:创建一个分行划分切换的过渡动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    reScene = CCTransitionSplitRows::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionSplitCols
    //    作用:创建一个分列划分切换的过渡动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    reScene = CCTransitionSplitCols::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionFade
    //    作用:创建一个逐渐过渡到目标颜色的切换动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    参数3:目标颜色
    //    reScene= CCTransitionFade::create(t, s, ccc3(255, 0, 0));
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionFlipX
    //    作用:创建一个x轴反转的切换动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    参数3:反转类型的枚举变量   左右上下
    //    kOrientationDownOver kOrientationLeftOver kOrientationRightOver  kOrientationUpOver
    //    reScene  = CCTransitionFlipX::create(t, s, kOrientationRightOver);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionFlipY
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    参数3:反转类型的枚举变量   左右上下
    //    reScene = CCTransitionFlipY::create(t, s
    //                                        , kOrientationDownOver);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionFlipAngular
    //    作用:创建一个带有反转角切换动画
    //        //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    参数3:反转类型的枚举变量   左右上下
    //    reScene = CCTransitionFlipAngular::create(t, s, kOrientationLeftOver);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionZoomFlipX
    //     作用:创建一个带有缩放的x轴反转切换的动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    参数3:反转类型的枚举变量   左右上下
    //    reScene=CCTransitionZoomFlipX::create(t, s, kOrientationLeftOver);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionZoomFlipY
    //     作用:创建一个带有缩放的Y轴反转切换的动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    参数3:反转类型的枚举变量   左右上下
    //    reScene=CCTransitionZoomFlipY::create(t, s, kOrientationDownOver);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionZoomFlipAngular
    //     作用:创建一个带有缩放 ,反转角切换的动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    参数3:反转类型的枚举变量   左右上下
    //    reScene=CCTransitionZoomFlipAngular::create(t, s, kOrientationRightOver);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionShrinkGrow
    //    创建一个放缩交替的过渡动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    reScene = CCTransitionShrinkGrow::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionRotoZoom
    // 创建一个旋转放缩交替的过渡动画
    // 参数1:过渡动作的持续时间
    // 参数2:切换的目标场景的对象
    //    reScene = CCTransitionRotoZoom::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionMoveInL
    //    作用:创建一个从左边推入覆盖的过渡动画
    // 参数1:过渡动作的持续时间
    // 参数2:切换的目标场景的对象
    //    reScene = CCTransitionMoveInL::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionMoveInR
    //    作用:创建一个从右边推入覆盖的过渡动画
    // 参数1:过渡动作的持续时间
    // 参数2:切换的目标场景的对象
    //    reScene = CCTransitionMoveInR::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionMoveInB
    //    作用:创建一个从下边推入覆盖的过渡动画
    // 参数1:过渡动作的持续时间
    // 参数2:切换的目标场景的对象
    //    reScene = CCTransitionMoveInB::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionMoveInT
    //    作用:创建一个从上边推入覆盖的过渡动画
    // 参数1:过渡动作的持续时间
    // 参数2:切换的目标场景的对象
    //    reScene = CCTransitionMoveInT::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionSlideInL
    //    作用:创建一个从左侧推入并顶出旧场景的过渡动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    reScene  =CCTransitionSlideInL::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionSlideInR
    //    作用:创建一个从右侧推入并顶出旧场景的过渡动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    reScene  =CCTransitionSlideInR::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    
    //    CCTransitionSlideInT
    //    作用:创建一个从顶部推入并顶出旧场景的过渡动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //    reScene  =CCTransitionSlideInT::create(t, s);
    //    CCDirector::sharedDirector()->replaceScene(reScene);
    
    //    CCTransitionSlideInB
    //    作用:创建一个从下部推入并顶出旧场景的过渡动画
    //    参数1:过渡动作的持续时间
    //    参数2:切换的目标场景的对象
    //reScene  =CCTransitionSlideInB::create(t, s);
    CCDirector::sharedDirector()->replaceScene(reScene);
}

==================== 迂者 丁小未 CSDN博客专栏=================

MyBlog:http://blog.csdn.net/dingxiaowei2013             MyQQ:1213250243

Unity QQ群:858550         cocos2dx QQ群:280818155

====================== 相互学习,共同进步 ===================

转载请注明出处:http://blog.csdn.net/dingxiaowei2013/article/details/12000113

欢迎关注我的微博: http://weibo.com/u/2590571922

相关文章
|
8月前
|
开发框架 API 开发者
Flutter的动画:实现方式与动画库的技术探索
【4月更文挑战第26天】探索Flutter动画机制与库:基础动画、自定义动画、物理动画及Lottie、AnimatedWidgets、EasyAnimations等库的应用,助开发者实现丰富动画效果,提升用户体验。同时,了解性能优化技巧,如避免重绘、利用离屏渲染和GPU加速,确保动画流畅。 Flutter为移动应用开发带来强大动画支持。
|
C++
Qt图片定时滚动播放器+透明过渡动画
解决:[QWidget::paintEngine: Should no longer be called QPainter::begin: Paint device returned engine == 0, type: 1] 需要在哪个控件上绘制,就要在哪个控件类中重写 paintEvent() ,所以本项目 需要使用自定义的MyQLabel继承QLabel
168 0
|
Java Spring
flutter系列之:使用AnimationController来控制动画效果
之前我们提到了flutter提供了比较简单好用的AnimatedContainer和SlideTransition来进行一些简单的动画效果,但是要完全实现自定义的复杂的动画效果,还是要使用AnimationController。 今天我们来尝试使用AnimationController来实现一个拖拽图片,然后返回原点的动画。
|
JavaScript 开发者
动画-使用过渡名实现动画|学习笔记
快速学习动画-使用过渡名实现动画
101 0
动画-使用过渡名实现动画|学习笔记
|
Dart 开发者
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(三)
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(三)
189 0
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(三)
|
JavaScript 开发工具 开发者
解决Electron应用中Lottie动画无法正常显示
我们用Flutter Web开发了一个应用,通过electron进行打包成可执行文件,但是在使用时发现了一个问题,Lottie动画无法显示。 通过console的日志可以看到,提示lottie是undifine的,lottie是sdk提供的一个全局的对象,通过lottie.loadAnimation(options)可以加载显示Lottie动画,但是我们明明在index.html中引入了Lottie的js文件,而且在浏览器上也是可以正常使用的,为什么通过Electron打包后执行就失效了?
435 0
|
前端开发
CSS样式更改——过渡、动画
CSS样式更改——过渡、动画
264 0
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(一)
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(一)
167 0
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(二)
【Flutter】Animation 动画 ( AnimatedBuilder 动画使用流程 | 创建动画控制器 | 创建动画 | 创建动画作用的组件 | 关联动画与组件 | 动画执行 )(二)
179 0
|
前端开发 容器
Flutter的AnimatedDefaultTextStyle实现文本样式的动画过渡切换效果
AnimatedDefaultTextStyle通过动画过渡的方式来切换文本的显示样式
Flutter的AnimatedDefaultTextStyle实现文本样式的动画过渡切换效果

热门文章

最新文章