原文链接https://www.shanya.world/archives/39c4da83.html
前言
本例是基于AndroidStudio以Kotlin语言开发,实现Android应用中常见的侧边划出栏。
就像下面这样
接下来进入实现部分
首先新建一个工程
添加两个依赖
implementation 'androidx.navigation:navigation-ui:2.0.0'
implementation 'androidx.navigation:navigation-ui-ktx:2.0.0'
implementation 'androidx.navigation:navigation-fragment:2.0.0'
implementation 'androidx.navigation:navigation-fragment-ktx:2.0.0'
对 AndroidManifestest.xml 的一点改动
看图片标红部分
这里用到了res的style,直接将这个style的代码贴出,后续还有部分xml用到了
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<item name="colorAccent">@color/colorAccent</item>
</style>
<style name="AppTheme.NoActionBar">
<item name="windowActionBar">false</item>
<item name="windowNoTitle">true</item>
</style>
<style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" />
<style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" />
</resources>
新建一个xml显示我的首页内容
需要注意的是,这里还需要对这个xml进行一个设置,看下图标红处代码
处理完之后再看我们的图形化界面,多出一个标题栏
新建一个ToolBar
用系统自带的ActionBar会把侧边栏挡住(我的是这样,如果能解决请告诉我一下_)
我们先新建一个xml文件
添加一个 AppBarLayout
还需要将 content_mian.xml 这一文件 include 引入
直接放出xml代码,更加直观
<?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_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<com.google.android.material.appbar.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/AppTheme.AppBarOverlay">
<androidx.appcompat.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:popupTheme="@style/AppTheme.PopupOverlay">
</androidx.appcompat.widget.Toolbar>
</com.google.android.material.appbar.AppBarLayout>
<include layout="@layout/content_main" />
</androidx.coordinatorlayout.widget.CoordinatorLayout>
同样标红处需要关注一下,可能需要手动加入
制作侧边栏的表头
这里就是简单的 ImageView 和 TextView 的组合,就不详细赘述了,直接放出xml代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="176dp"
android:background="#91AD70"
android:gravity="bottom"
android:orientation="vertical"
android:paddingLeft="16dp"
android:paddingTop="16dp"
android:paddingRight="16dp"
android:paddingBottom="16dp"
android:theme="@style/ThemeOverlay.AppCompat.Dark">
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:contentDescription="Navgaton Header"
android:paddingTop="8dp"
app:srcCompat="@mipmap/ic_launcher_round" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="8dp"
android:text="Shanya"
android:textAppearance="@style/TextAppearance.AppCompat.Body1" />
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="shanyaliux@qq.com" />
</LinearLayout>
效果图如下
制作侧边栏的选项
先新建一个menu
这里仅仅是添加了几个MenuItem,直接贴出xml代码(这里为了好看一点,加了几个Vector Assert,这个就自行添加了,反正不重要)
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
tools:showIn="navigation_view">
<group android:checkableBehavior="single">
<item
android:id="@+id/nav_one"
android:icon="@drawable/ic_looks_one_black_24dp"
android:title="one" />
<item
android:id="@+id/nav_two"
android:icon="@drawable/ic_looks_two_black_24dp"
android:title="two" />
<item
android:id="@+id/nav_three"
android:icon="@drawable/ic_looks_3_black_24dp"
android:title="three" />
</group>
</menu>
这里的效果图就不好看了
activity_main.xml 的修改
首先,先把ConstraintLayout 改为 DrawerLayout
指定一个id,这个就随意了
然后,用include 把上面做的app_bar_main.xml 文件引入
再添加一个 NavigationView ,这就是放侧边栏的容器了
记得指定id,再为它添加表头xml,和menu(可以直接在属性栏哪里设置)
还有一些处理,直接放代码查看吧
<?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"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:openDrawer="start">
<include
layout="@layout/app_bar_main"
android:layout_width="match_parent"
android:layout_height="match_parent" />
<com.google.android.material.navigation.NavigationView
android:id="@+id/nav_view"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
android:fitsSystemWindows="true"
app:headerLayout="@layout/nav_header_main"
app:menu="@menu/drawer_menu" />
</androidx.drawerlayout.widget.DrawerLayout>
效果图
菜单选项页面
为了每一个菜单都有一个页面与之对应,建立三个 Fragment (简单Deomo ,使用BankFragment)
重复建立三个
在res添加一个navigatin
点击添加我们的 Fragment
切记一定把每一个Fragment的ID改成和其对应的Menu选项一致
在 content_main.xml 文件添加上 NavHostFragment
这里就不是一个铁憨憨,可以把那个TextView删除了
MainActivity 代码
package com.shanya.drawerdemo
import androidx.appcompat.app.AppCompatActivity
import android.os.Bundle
import android.view.Menu
import androidx.appcompat.widget.Toolbar
import androidx.drawerlayout.widget.DrawerLayout
import androidx.navigation.findNavController
import androidx.navigation.ui.AppBarConfiguration
import androidx.navigation.ui.navigateUp
import androidx.navigation.ui.setupActionBarWithNavController
import androidx.navigation.ui.setupWithNavController
import com.google.android.material.navigation.NavigationView
class MainActivity : AppCompatActivity() {
private lateinit var appBarConfiguration: AppBarConfiguration
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val toolbar: Toolbar = findViewById(R.id.toolbar)
setSupportActionBar(toolbar)
val drawerLayout: DrawerLayout = findViewById(R.id.drawer_layout)
val navView: NavigationView = findViewById(R.id.nav_view)
val navController = findNavController(R.id.nav_host_fragment)
appBarConfiguration = AppBarConfiguration(setOf(
R.id.nav_one, R.id.nav_two, R.id.nav_three), drawerLayout)
setupActionBarWithNavController(navController, appBarConfiguration)
navView.setupWithNavController(navController)
}
override fun onCreateOptionsMenu(menu: Menu): Boolean {
// Inflate the menu; this adds items to the action bar if it is present.
menuInflater.inflate(R.menu.main, menu)
return true
}
override fun onSupportNavigateUp(): Boolean {
val navController = findNavController(R.id.nav_host_fragment)
return navController.navigateUp(appBarConfiguration) || super.onSupportNavigateUp()
}
}