Android Compose页面切换动画怎么实现
导读:本文共2612.5字符,通常情况下阅读需要9分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 开始尝试其实 Compose 中的 Navigation 就是之前 Jetpack 中的 Navigation 改的,所以之前的 api 还是存在的,然后用上试试呗!navController.navigate(route){anim{enter=R.anim.in_from_rightexit=R.anim.out_to_leftpopEnter=R.... ...
目录
(为您整理了一些要点),点击可以直达。其实 Compose
中的 Navigation
就是之前 Jetpack 中的 Navigation
改的,所以之前的 api 还是存在的,
然后用上试试呗!
然后就有了上面的代码进行尝试,其实写的时候也想过不行,因为在 Compose
中动画有自己的一套实现方式,并不是像之前那样放在 anim 文件夹下的 xml 文件,但还是抱着试一试的态度,最后发现。。。果然不行。。。
于是开始一顿乱找,后来发现在官方文档中已经写明了:
注意:anim
块不能与 Navigation Compose 一起使用。系统会在此功能请求中跟踪 Navigation Compose 中的转换动画。
然后就没有然后了,就开始等。。。。这一等就是好久。(其实这篇文章是之前写的,但一直没发)
终于在前段时间,这个问题有了眉目,Google 并没有将这个功能放到 Navigation
库中,而是重新创建了一个库:navigation-animation
,使用的时候同时引入即可进行使用。
首先需要做的肯定是添加依赖:
现在应用级的 build.gradle 中添加:
然后在 Module 级的 build.gradle 中添加:
接下来需要做的是迁移之前写的 Navigation
的代码,先来看看之前的写法吧:
需要做的迁移有:
替换rememberNavController()
为rememberAnimatedNavController()
替换NavHost
为AnimatedNavHost
替换import androidx.navigation.compose.navigation
为import com.google.accompanist.navigation.animation.navigation
替换import androidx.navigation.compose.composable
为import com.google.accompanist.navigation.animation.composable
那就来吧:
下面就来看看如何使用这个库为页面之间切换添加动画吧:
上面这段代码是 navigation-animation
库中的源码,可以看到除了之前 Navigation
库中的一些参数外还多了几个参数用来设置动画,来具体看看吧:
**enterTransition:**在此 NavGraph 中定义目的地的输入转换动画
**exitTransition:**在此 NavGraph 中为目的地定义退出转换动画
**popEnterTransition:**在此 NavGraph 中定义目的地的弹出输入转换动画
**popExitTransition:**在此 NavGraph 中为目的地定义弹出退出转换动画
再来看看具体使用吧:
Android Compose页面切换动画怎么实现的详细内容,希望对您有所帮助,信息来源于网络。