Cha*_*hna 7 android android-architecture-navigation
我有一个应用程序,它有一个底部菜单栏,用户可以使用它在 4 个主页选项卡之间切换。它工作正常,如下所示。
我遇到的唯一问题是当我在不同片段之间切换时它会显示后退按钮。由于所有这些片段都处于同一级别,我不希望它表现得那样。
这是我的实现。
主导航活动
class MainNavigationActivity : AppCompatActivity() {
private lateinit var navigationController: NavController
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
initialization()
}
private fun initialization(){
navigationController = Navigation.findNavController(this, R.id.hostFragment)
setSupportActionBar(toolbar)
NavigationUI.setupWithNavController(bottomNavigationBar,navigationController)
NavigationUI.setupActionBarWithNavController(this,navigationController)
}
override fun onBackPressed() {
onSupportNavigateUp()
}
Run Code Online (Sandbox Code Playgroud)
MainNavigationActivity 布局
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".activities.MainNavigationActivity">
<androidx.appcompat.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:background="@color/colorPrimary"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"/>
<fragment
android:id="@+id/hostFragment"
android:name="androidx.navigation.fragment.NavHostFragment"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_below="@id/toolbar"
android:layout_above="@id/bottomNavigationBar"
app:defaultNavHost="true"
app:navGraph="@navigation/main_navigation_graph" />
<com.google.android.material.bottomnavigation.BottomNavigationView
android:id="@+id/bottomNavigationBar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:background="@android:color/white"
app:menu="@menu/bottom_navigation_menu"
app:labelVisibilityMode="labeled"/>
</RelativeLayout>
Run Code Online (Sandbox Code Playgroud)
bottom_navigation_menu.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/navigation_home"
android:state_checked="true"
android:color="@color/colorPrimary"
android:title="@string/navigation_home"
android:icon="@drawable/ic_bottom_bar_menu_home"/>
<item
android:id="@+id/navigation_offers"
android:state_checked="false"
android:color="@color/gray"
android:title="@string/navigation_offers"
android:icon="@drawable/ic_bottom_bar_menu_offers"/>
<item
android:id="@+id/navigation_my_bookings"
android:state_checked="false"
android:color="@color/gray"
android:title="@string/navigation_my_bookings"
android:icon="@drawable/ic_bottom_bar_menu_bookings"/>
<item
android:id="@+id/navigation_my_account"
android:state_checked="false"
android:color="@color/gray"
android:title="@string/navigation_my_account"
android:icon="@drawable/ic_bottom_bar_menu_account"/>
</menu>
Run Code Online (Sandbox Code Playgroud)
Id 被赋予导航图中的片段,menu.xml 中的 id 是相同的。这就是它如何识别正确的片段并正确切换到该片段。
如何在主屏幕级别的工具栏上删除此后退按钮?
ian*_*ake 17
默认情况下,当用户位于导航图的顶级目的地时,导航按钮是隐藏的,而在任何其他目的地中显示为向上按钮。
如果您想自定义哪些目的地被视为顶级目的地,您可以改为将一组目的地 ID 传递给构造函数,如下所示:
val appBarConfiguration = AppBarConfiguration(setOf(
R.id.navigation_home, R.id.navigation_offers,
R.id.navigation_my_bookings, R.id.navigation_my_account))
Run Code Online (Sandbox Code Playgroud)
(请注意,此构造函数需要navigation-ui-ktx工件 - 替代方法是使用AppBarConfiguration.Builder)
您还可以使用扩展函数,AppBarConfiguration将底部导航菜单作为其参数,只是为了让事情变得更容易一些。检查这里
它将把底部导航栏中的所有片段设置为顶级目的地。
就这么简单:
val appBarConfiguration = AppBarConfiguration(bottomNavigationBar.menu)
setupActionBarWithNavController(navigationController, appBarConfiguration)
Run Code Online (Sandbox Code Playgroud)
而且正如 @ianhanniballake 所建议的,你需要让它navigation-ui-ktx发挥作用。
| 归档时间: |
|
| 查看次数: |
6458 次 |
| 最近记录: |