开启生长之旅!这是我参与「日新方案 2 月更文挑战」的第 18 天,点击检查活动概况

前言

日新方案可真头疼,每天更文养成习气是好,但有时分没思路就很烦,回到正题,本篇回到很久之前的组件学习(安卓UI设计开发——Material Design(BottomSheetDialogFragment篇) – ()),这次咱们来看看许多APP首页常用的NavigationView——滑动菜单如何运用。

2/22 更正:NavigationView为导航视图,DrawerLayout为抽屉布局,一起组合成滑动菜单(完成侧滑交互体验)

安卓组件学习——NavigationView导航视图

正篇

首要,运用NavigationView前咱们先创立一个新项目,我这儿为了学习这些组件,命名为MaterialDemo,作为咱们学习Materia组件的项目,然后由于要运用Material库的NavigationView,所以咱们项目的app目录下的build.gradle文件中的dependencies闭包中增加下面依赖:

implementation 'com.google.android.material:material:1.8.0'
implementation 'de.hdodenhof:circleimageview:3.1.0'

其间第二个依赖是咱们导入的开源项目CircleImageView,这能够让咱们更容易完成图片圆形化,也便是这个滑动菜单栏上圆形头像的构成。

当然,新建的是Kotlin安卓空Activity项目,咱们采用了ViewBinding,所以同时也要在该文件下启用ViewBinding,位置在android闭包中:

buildFeatures {
    viewBinding = true
}

sync Gradle(同步 Gradle)完成后,咱们再把res/values/theme.xml文件AppThemeparent主题换为Theme.MaterialComponents.Light.NoActionBar,用来适配咱们的Material库组件:

安卓组件学习——NavigationView导航视图

咱们还得事先准备几张图片备用(按钮,头像等),这儿我放在了drawable-xxhdpi目录下,当然如果有需求能够到文末我的Github项目中找:

安卓组件学习——NavigationView导航视图

接着,咱们在res目录下创立新的名为menu文件夹(和之前文章安卓开发基础——Menu菜单的运用 – ()一样):

安卓组件学习——NavigationView导航视图

安卓组件学习——NavigationView导航视图

再在这个文件夹上右击->New->Menu resource file ,创立一个nav_menu.xml文件,增加下面的代码:

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">
    <group android:checkableBehavior="single">
        <item
            android:id="@+id/navCall"
            android:icon="@drawable/nav_call"
            android:title="Call" />
        <item
            android:id="@+id/navFriends"
            android:icon="@drawable/nav_friends"
            android:title="Friends" />
        <item
            android:id="@+id/navLocation"
            android:icon="@drawable/nav_location"
            android:title="Location" />
        <item
            android:id="@+id/navMail"
            android:icon="@drawable/nav_mail"
            android:title="Mail" />
        <item
            android:id="@+id/navTask"
            android:icon="@drawable/nav_task"
            android:title="Tasks" />
    </group>
</menu>

上面代码中咱们加了一个group标签,并把其间的checkableBehavior特点设置为single,这样就能让菜单项变为只能够单选。 然后咱们就能预览到这个菜单样式,这便是咱们即将用的详细的菜单项:

安卓组件学习——NavigationView导航视图

但NavigationView样式不是这个预览到的,由于有菜单项这样仍是不行的,咱们还需求准备一个herderLayout用于显示NavigationView的头部布局,这个布局能够按照需求来定制,这儿咱们就构建了头像、用户名和邮箱地址这三项,这个布局咱们直接在layout目录正常创立布局文件就行,咱们这儿创立一个名为nav_header的XML布局文件:

安卓组件学习——NavigationView导航视图
该文件代码如下:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="180dp"
    android:padding="10dp"
    android:background="?attr/colorPrimary">
    <de.hdodenhof.circleimageview.CircleImageView
        android:id="@+id/iconImage"
        android:layout_width="70dp"
        android:layout_height="70dp"
        android:src="@drawable/nav_icon"
        android:layout_centerInParent="true" />
    <TextView
        android:id="@+id/mailText"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:text="tonygreendev@gmail.com"
        android:textColor="#FFF"
        android:textSize="14sp" />
    <TextView
        android:id="@+id/userText"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_above="@id/mailText"
        android:text="Tony Green"
        android:textColor="#FFF"
        android:textSize="14sp" />
</RelativeLayout>

咱们运用了相对布局(RelativeLayout)作为最外层布局,其间CircleImageView便是之前加依赖说到的开源控件,将咱们的图片圆形化,和ImageView用法一样,这儿咱们用于构建圆形的头像图片,且设为居中,还有两个TextView别离便是咱们的用户名和邮箱地址,用相对布局特点定位即可。

这些做完后,咱们的准备阶段就完成了,接下来咱们开始运用NavigationView控件:

咱们先把布局增加NavigationView:

<?xml version="1.0" encoding="utf-8"?>
<androidx.drawerlayout.widget.DrawerLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/drawerLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <FrameLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <androidx.appcompat.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
            app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
    </FrameLayout>
    <com.google.android.material.navigation.NavigationView
        android:id="@+id/navView"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_gravity="start"
        app:menu="@menu/nav_menu"
        app:headerLayout="@layout/nav_header"/>
</androidx.drawerlayout.widget.DrawerLayout>

Activity中:

package com.example.materialdemo
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import com.example.materialdemo.databinding.ActivityMainBinding
class MainActivity : AppCompatActivity() {
    lateinit var binding: ActivityMainBinding
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        binding = ActivityMainBinding.inflate(layoutInflater)
        setContentView(binding.root)
        setSupportActionBar(binding.toolbar)
        supportActionBar?.let {
            it.setDisplayHomeAsUpEnabled(true)
            it.setHomeAsUpIndicator(R.drawable.ic_menu)
        }
        binding.navView.setCheckedItem(R.id.navCall)
        binding.navView.setNavigationItemSelectedListener {
            binding.drawerLayout.closeDrawers()
            true
        }
    }
}

最终作用:

安卓组件学习——NavigationView导航视图

这儿一开始忘掉加我的项目地址了,现在补上:GitHub – ObliviateOnline/MaterialDemo: Material库组件学习

总结

今天学了NavigationView,结果忘掉写前面的滑动菜单DrawerLayout和标题栏Toolbar控件了,下一篇就把前面的构建过程给理一遍。