【问题标题】:How to implement a bottom navigation bar in android?如何在android中实现底部导航栏?
【发布时间】:2017-04-05 11:30:29
【问题描述】:

我对 Android 开发非常陌生,所以我确定我在这里犯了初学者的错误。我正在尝试按照此处的指南来实现底部导航栏:https://segunfamisa.com/posts/bottom-navigation-view-android

我已经下载了演示项目,它可以工作。我现在正在尝试复制底部导航的代码并使其在另一个 android studio 项目中工作,并收到此错误。

我认为这个错误的原因是我的主要活动中的这段 xml,它引用了我试图显示的 bottom_nav_items:

<android.support.design.widget.BottomNavigationView
    android:id="@+id/navigation"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:layout_gravity="start"
    design:menu="@menu/bottom_nav_items" />

我认为这与我的文件夹结构有关。演示项目与我的项目具有不同的文件夹结构。

我创建的项目有这个文件夹结构。

我认为问题是当我在我的项目中添加文件夹时,该文件夹没有出现在包文件夹中,而在演示项目中就是这种情况。

编辑---------------

这是我的 buildgradle (Project Celebreak) 文件: 应用插件:'com.android.application'

android {
compileSdkVersion 25
buildToolsVersion "25.0.2"
defaultConfig {
    applicationId "com.lewisblack.celebreak"
    minSdkVersion 16
    targetSdkVersion 25
    versionCode 1
    versionName "1.0"
    testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}
buildTypes {
    release {
        minifyEnabled false
        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
    }
}

sourceSets {
    main {
        java.srcDirs = ['src/main/java', 'src/main/java/com/lewisblack/celebreak/model']
        res.srcDirs = ['src/main/res', 'src/main/res/menu']
    }
}
}

repositories {
    mavenCentral()
}

dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
    exclude group: 'com.android.support', module: 'support-annotations'
})

compile 'com.android.support:design:25.0.0'
compile 'com.android.support:appcompat-v7:25.3.0'
compile 'com.android.support.constraint:constraint-layout:1.0.2'
compile 'com.google.android.gms:play-services:10.2.1'
compile 'com.google.firebase:firebase-core:10.2.0'
compile 'com.facebook.android:facebook-android-sdk:[4,5)'
testCompile 'junit:junit:4.12'
}

apply plugin: 'com.google.gms.google-services'

【问题讨论】:

    标签: android xml android-layout android-fragments


    【解决方案1】:

    首先在布局中添加:

       <android.support.design.widget.BottomNavigationView
            android:id="@+id/bottom_navigation_view"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            app:itemBackground="@color/white"
            app:itemIconTint="@color/bottomdrawer"
            app:itemTextColor="@color/bottomdrawer"
            app:menu="@menu/bottom_navigation_main" />
    

    然后像这样添加菜单:

    <?xml version="1.0" encoding="utf-8"?>
    <menu xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto">
        <item
            android:id="@+id/action_life"
            android:enabled="true"
            android:icon="@drawable/ic_favorite_white_24dp"
            android:title="@string/bottom_main"
            app:showAsAction="always" />
        <item
            android:id="@+id/action_contact"
            android:enabled="true"
            android:icon="@drawable/ic_favorite_white_24dp"
            android:title="@string/bottom_contact"
            app:showAsAction="always" />
        <item
            android:id="@+id/action_social"
            android:enabled="true"
            android:icon="@drawable/ic_favorite_white_24dp"
            android:title="@string/bottom_social"
            app:showAsAction="always" />
        <item
            android:id="@+id/action_application"
            android:enabled="true"
            android:icon="@drawable/ic_favorite_white_24dp"
            android:title="@string/bottom_app"
            app:showAsAction="always" />
        <item
            android:id="@+id/action_menu"
            android:enabled="true"
            android:icon="@drawable/ic_favorite_white_24dp"
            android:title="@string/bottom_menu"
            app:showAsAction="always" />
    </menu>
    

    然后在你的 Activity 中实现这个:

    BottomNavigationView bottomNavigationView;
    

    【讨论】:

      【解决方案2】:

      不是design:menu="@menu/bottom_nav_items",应该是app:menu="@menu/bottom_nav_items"

      【讨论】:

      • 感谢您的回答。我根据你和 rafsanahmad007 的答案尝试了这个,我有一个新错误“没有为包 'android' 中的属性 'menu' 找到资源标识符。在旁注中,演示应用程序与设计一起工作,但我正在查看文档,因为我不明白这个的含义。
      【解决方案3】:

      您需要将 menu 创建为 Directory 而不是 Android 资源目录,然后将您的 bottom_nav_items.xml 粘贴到其中。

      【讨论】:

        【解决方案4】:

        应该是:

        xmlns:app="http://schemas.android.com/apk/res-auto"
        app:menu="@menu/bottom_nav_items"
        

        还要确保你在 Gradle 中有这个:

        compile 'com.android.support:design:25.0.0'
        

        更多BottomNavigationView的属性见Documentation

        【讨论】:

        • 感谢您的回答。尝试过这个后,我收到错误“在包 'android' 中找不到属性 'menu' 的资源标识符”。在我的模块应用程序的构建 gradle 中,我也有编译语句。
        • 是build.gradle(项目:项目名称)文件还是build.gradle(模块:App)文件?如果是项目文件,我应该在文件的哪个位置添加它?
        • 依赖项 { 编译 fileTree(dir: 'libs', include: ['*.jar']) androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2' ,{排除组:'com.android.support',模块:'support-annotations'})编译'com.android.support:design:25.0.0'编译'com.android.support:appcompat-v7:25.3。 0' 编译 'com.android.support.constraint:constraint-layout:1.0.2' testCompile 'junit:junit:4.12' }
        • 以上在我的build.gradle文件(项目:项目名称)文件中
        • 看起来没问题..请synch project with gradle file在顶部栏中按下它..然后清理构建项目..
        【解决方案5】:

        在 Android Studio 2.3 中,他们在新项目开始时提供了此功能。创建新项目并为项目的启动活动选择底部导航,并研究他们的代码,因为他们提供了完美的代码。

        您将获得其他代码,但谷歌会提供最好的。

        祝你好运!

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 2021-12-11
          • 2020-02-07
          • 1970-01-01
          • 2021-07-03
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多