我需要浏览一堆片段,然后使用工具栏的后退按钮进行后退。我可以覆盖按下以设置自定义动画的后退按钮,例如滑出吗?
这里是工具栏的代码。
private fun setupToolbar() {
val appBarConfiguration = AppBarConfiguration(navController.graph, drawer_layout)
val toolbar = toolbar as Toolbar
setSupportActionBar(toolbar)
toolbar.setupWithNavController(navController, appBarConfiguration)
val ab: ActionBar? = supportActionBar
ab?.setDisplayShowTitleEnabled(false) // disable the default title element here (for centered title)
setupSearchQueryListener()
}
在您的设置代码中,还需要做一件事:
toolbar.setNavigationOnClickListener {
onBackPressedDispatcher.onBackPressed()
}
在您的片段中,您可以这样做:
protected lateinit var backPressedCallback: OnBackPressedCallback
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
backPressedCallback = requireActivity().onBackPressedDispatcher.addCallback(this) {
// your code
}
}
上面的内容使您能够统一拦截向后导航并执行有问题的代码(您甚至可以通过播放backPressedCallback.isEnabled
标志来阻止/取消阻止它)。以上已测试。说到设置导航动画,我只是在玩xml定义的基于动作的动画:
<action
android:id="@+id/toYourDest"
app:destination="@+id/yourDest"
app:enterAnim="@anim/your_slide_in_right"
app:exitAnim="@anim/your_slide_out_left"
app:popEnterAnim="@anim/your_slide_in_left"
app:popExitAnim="@anim/your_slide_out_right" />