【问题标题】:Background of a Navigation Drawer item导航抽屉项目的背景
【发布时间】:2018-09-29 07:35:17
【问题描述】:

我想为导航抽屉中的每个项目设置不同的背景。 我要实现

你们中的任何人都可以解释一下吗?

我的 Activity_main.xml

<android.support.design.widget.NavigationView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:menu="@menu/nav_menu"
        android:fitsSystemWindows="true"
        android:background="@android:color/black"
        app:itemTextColor="@android:color/white"
        android:layout_gravity="start"
        app:headerLayout="@layout/navigation_header"
        app:itemIconTint="@android:color/white"
        app:itemBackground="@drawable/header_background"
        />

【问题讨论】:

标签: android navigation-drawer


【解决方案1】:

创建一个自定义的 navigationView 布局并包含如下布局,

  <android.support.design.widget.NavigationView
        android:id="@+id/nav_view"
        android:layout_height="match_parent"
        android:layout_width="wrap_content"
        android:layout_gravity="end"
        android:fitsSystemWindows="true"
        app:headerLayout="@layout/nav_header_main">

        <include layout="@layout/custom_layout"></include>

    </android.support.design.widget.NavigationView>

custom_layout.xml 文件

 <?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.RecyclerView
    android:id="@+id/recyclerView"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
</android.support.v7.widget.RecyclerView>
</LinearLayout>

现在只需像这样塑造一个可绘制对象,(根据需要更改颜色)

btn_green_border.xml

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:color="@color/colorSkyBlue"
tools:targetApi="lollipop">
<item>
    <shape xmlns:android="http://schemas.android.com/apk/res/android"
        android:shape="rectangle">

        <solid android:color="@color/colorAccent" />
        <stroke
            android:width="@dimen/_1dp"
            android:color="@color/colorLightBlue"></stroke>
        <corners android:radius="@dimen/_30dp"></corners>
        <size
            android:width="@dimen/_50dp"
            android:height="@dimen/_100dp"></size>

    </shape>
</item>
</ripple>

并在 RecyclerView 项目的布局中使用此可绘制对象,如下所示

item_row.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/ll_card"
android:layout_width="match_parent"
android:layout_height="wrap_content">

<Button
    android:id="@+id/btn_refer"
    android:layout_width="200dp"
    android:layout_height="@dimen/_40dp"
    android:background="@drawable/btn_green_border"
    android:text="Navigation Item Name"
    android:textAllCaps="false"
    android:textColor="@color/colorPrimary" />

</LinearLayout>

你会得到你想要的。

谢谢

【讨论】:

  • 出色的答案妈妈,正是我正在寻找的答案!谢谢妈妈:)
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2013-06-10
  • 2023-03-08
  • 2019-11-25
相关资源
最近更新 更多