如何使用 material.BottomNavigationView 设置 Jetpack 导航

Posted

技术标签:

【中文标题】如何使用 material.BottomNavigationView 设置 Jetpack 导航【英文标题】:How to Setup Jetpack Navigation with material.BottomNavigationView 【发布时间】:2018-12-02 23:33:51 【问题描述】:

我无法使用 com.google.android.material.bottomnavigation.BottomNavigationView 设置导航组件,它给出了错误。

这是我尝试使用的代码

 // Setup bottom navigation view
    NavigationUI.setupWithNavController(
            bottom_navigation_view,
            findNavController(R.id.main_nav_host_fragment)
    )

当我打开 NavigationUI 类时,我注意到它只接受旧的 android.support.design.widget.BottomNavigationView 但我想使用新的 com.google.android.material.bottomnavigation.BottomNavigationView 类。有什么想法吗?

[2019 年 14 月 11 日更新]

这是一个错误,已在 Android Gradle 插件(~3.2.0-rc-01 和 3.3.0-alpha-04)中修复。您可以在以下链接中查看问题跟踪器:https://issuetracker.google.com/issues/110692942

【问题讨论】:

【参考方案1】:

我正在使用这些库

implementation 'androidx.appcompat:appcompat:1.0.0-beta01'
// Architecture Components
def nav_version = "1.0.0-alpha02"
implementation "android.arch.navigation:navigation-fragment-ktx:$nav_version"
// use -ktx for Kotlin
implementation "android.arch.navigation:navigation-ui-ktx:$nav_version"

这是我的活动

NavigationUI.setupWithNavController(bottomNavView, 
Navigation.findNavController(this, R.id.nav_host_fragment))

这是我的布局

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout  xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_
tools:context=".ui.main.ActivityMain">

<fragment
    android:id="@+id/nav_host_fragment"
    android:name="androidx.navigation.fragment.NavHostFragment"
    android:layout_
    android:layout_
    app:defaultNavHost="true"
    app:navGraph="@navigation/nav_graph" />

<com.google.android.material.bottomnavigation.BottomNavigationView
    android:id="@+id/bottomNavView"
    android:layout_
    android:layout_
    android:layout_gravity="bottom"
    app:menu="@menu/menu_nav_drawer" />

<com.google.android.material.floatingactionbutton.FloatingActionButton
    style="@style/Widget.MaterialComponents.FloatingActionButton"
    android:layout_
    android:layout_
    android:layout_gravity="bottom|end"
    android:layout_marginEnd="@dimen/dimen_16"
    android:layout_marginBottom="72dp"
    app:fabSize="normal"
    tools:srcCompat="@drawable/ic_add_white" />

</androidx.coordinatorlayout.widget.CoordinatorLayout>

【讨论】:

对我来说仍然无法正常工作。它只需要到主页,当我点击其他选项卡时,它不会到那里。【参考方案2】:

请更新“android.arch.navigation:navigation-ui:1.0.0-alpha03”来解决这个问题

NavigationUI updated

【讨论】:

【参考方案3】:

查看导航文档:https://developer.android.com/topic/libraries/architecture/adding-components#navigation 截至 2018 年 6 月 29 日。

上面写着:

块引用 导航类已经在 androidx.navigation 包中,但目前依赖于 Support Library 27.1.1 和相关的 Arch 组件版本。未来会发布带有 AndroidX 依赖的 Navigation 版本。

我想你现在别无选择,只能等待 Navigation 包的“未来”版本。

目前,正如@Levi Albuquerque 所建议的,您需要使用com.android.support:design:28.0.0-alpha3。 它的工作方式应该与com.google.android.material:material:1.0.0-alpha3 相同。

【讨论】:

以上是关于如何使用 material.BottomNavigationView 设置 Jetpack 导航的主要内容,如果未能解决你的问题,请参考以下文章

如何使用本机反应创建登录以及如何验证会话

如何在自动布局中使用约束标识符以及如何使用标识符更改约束? [迅速]

如何使用 AngularJS 的 ng-model 创建一个数组以及如何使用 jquery 提交?

如何使用laravel保存所有行数据每个行名或相等

如何使用 Math.Net 连接矩阵。如何使用 Math.Net 调用特定的行或列?

WSARecv 如何使用 lpOverlapped?如何手动发出事件信号?