出处:http://www.jianshu.com/p/d2b1689a23bf

Android Material Design Library 推出了很长时间,越来越多的APP使用了符合Library 包的控件,DrawerLayout绝对是热门之一,Material Design定义了一个抽屉导航应该有何种外观和感受,统一了侧滑菜单和样式。在Android原生手机上对DrawerLayout+NavigationView更是使用到了极致,如Gmail,Google Map

关于DrawerLayout和NavigationView的使用介绍博客有很多,这里主要是实现一些使用上的介绍,如让NavigationView在Toolbar下方,不显示Toolbar左侧按钮等。

下面开始看下DrawerLayout的如何使用,首先在build.gradle中引入Design包

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

(一)、基本使用

新建一个Activity,这里我们选择使用Android Studio提供的模板,选择NavgationDrawer Activity

QQ截图20161118143554.jpg

查看下界面的xml文件

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayoutandroid:id="@+id/drawer_layout"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"android:fitsSystemWindows="true"tools:openDrawer="start"><includelayout="@layout/app_bar_drawer_layout__one"android:layout_width="match_parent"android:layout_height="match_parent"/><android.support.design.widget.NavigationViewandroid: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_drawer_layout__one"app:menu="@menu/activity_drawer_layout__one_drawer"/></android.support.v4.widget.DrawerLayout>

可以看到我们的最外层是DrawerLayout,包含了两个内容:include为显示内容区域,NavigationView为侧边抽屉栏。

NavigationView有两个app属性,分别为app:headerLayout和app:menu,eaderLayout用于显示头部的布局(可选),menu用于建立MenuItem选项的菜单。

headerLayout就是正常的layout布局文件,我们查看下menu.xml

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"><group android:checkableBehavior="single"><itemandroid:id="@+id/nav_camera"android:icon="@drawable/ic_menu_camera"android:title="Import"/><itemandroid:id="@+id/nav_gallery"android:icon="@drawable/ic_menu_gallery"android:title="Gallery"/><itemandroid:id="@+id/nav_slideshow"android:icon="@drawable/ic_menu_slideshow"android:title="Slideshow"/><itemandroid:id="@+id/nav_manage"android:icon="@drawable/ic_menu_manage"android:title="Tools"/></group><item android:title="Communicate"><menu><itemandroid:id="@+id/nav_share"android:icon="@drawable/ic_menu_share"android:title="Share"/><itemandroid:id="@+id/nav_send"android:icon="@drawable/ic_menu_send"android:title="Send"/></menu></item>
</menu>

menu可以分组,group的android:checkableBehavior属性设置为single可以设置该组为单选

Activity主题必须设置先这两个属性

    <style name="AppTheme.NoActionBar"><item name="windowActionBar">false</item><item name="windowNoTitle">true</item></style>

未设置Activity主题会爆出错误信息:

vCaused by: java.lang.IllegalStateException: This Activity
already has an action bar supplied by the window decor.
Do not request Window.FEATURE_SUPPORT_ACTION_BAR
and set windowActionBar to false in your theme to use a Toolbar instead.

设置主题为android:theme="@style/AppTheme.NoActionBar"

最后java代码

Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
drawer.setDrawerListener(toggle);
toggle.syncState();NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
navigationView.setNavigationItemSelectedListener(this);

效果图:

GIF.gif

(二)、监听和关闭NavigationView

NavigationView监听通过navigationView.setNavigationItemSelectedListener(this)方法去监听menu的点击事件

@SuppressWarnings("StatementWithEmptyBody")
@Override
public boolean onNavigationItemSelected(MenuItem item)
{// Handle navigation view item clicks here.int id = item.getItemId();DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);drawer.closeDrawer(GravityCompat.START);return true;
}

每次点击一个Menu关闭DrawerLayout,方法为drawer.closeDrawer(GravityCompat.START);

通过onBackPressed方法,当点击返回按钮的时候,如果DrawerLayout是打开状态则关闭

    @Overridepublic void onBackPressed(){DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);if (drawer.isDrawerOpen(GravityCompat.START)) {drawer.closeDrawer(GravityCompat.START);} else {super.onBackPressed();}}

(三)、NavigationView在Toolbar下方

大多数的APP都是使用NavigationView都是全屏的,当我们想让NavigationView在Toolbar下方的时候应该怎么做呢
xml布局如下图,DrawerLayout在Toolbar的下方

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"android:id="@+id/sample_main_layout"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><android.support.v7.widget.Toolbarandroid:id="@+id/toolbar"android:layout_width="match_parent"android:layout_height="?attr/actionBarSize"android:background="?attr/colorPrimary"app:theme="@style/ThemeOverlay.AppCompat.Dark" /><android.support.v4.widget.DrawerLayoutandroid:id="@+id/drawer_layout"android:layout_width="match_parent"android:layout_height="match_parent"><FrameLayoutandroid:id="@+id/container"android:layout_width="match_parent"android:layout_height="match_parent" ><TextViewandroid:padding="16dp"android:text="NavigationView在Toolbar下方"android:gravity="center"android:layout_width="match_parent"android:layout_height="match_parent" /></FrameLayout><android.support.design.widget.NavigationViewandroid: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_drawer_layout_one"app:menu="@menu/activity_drawer_layout_one_drawer"/></android.support.v4.widget.DrawerLayout>
</LinearLayout>

效果如图:

NavigationView在Toolbar下方.gif

(四)、Toolbar上不显示Home旋转开关按钮

上图可以看到我们点击Home旋转开关按钮,显示和隐藏了侧滑菜单。那么如果我们想要不通过按钮点击,只能右划拉出菜单需要怎么做呢。
我们先看下带Home旋转开关按钮的代码是如何写的:

DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
//这是带Home旋转开关按钮
ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
drawer.setDrawerListener(toggle);
toggle.syncState();

这个Home旋转开关按钮实际上是通过ActionBarDrawerToggle代码绑定到toolbar上的,ActionBarDrawerToggle是和DrawerLayout搭配使用的,它可以改变android.R.id.home返回图标,监听drawer的显示和隐藏。ActionBarDrawerToggle的syncState()方法会和Toolbar关联,将图标放入到Toolbar上。
进入ActionBarDrawerToggle构造器可以看到一个不传Toolbar参数的构造器

public ActionBarDrawerToggle(Activity activity, DrawerLayout drawerLayout,@StringRes int openDrawerContentDescRes,@StringRes int closeDrawerContentDescRes) {this(activity, null, drawerLayout, null, openDrawerContentDescRes,closeDrawerContentDescRes);
}

那么不带Home旋转开关按钮的代码如下

//这是不带Home旋转开关按钮
ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawer,R.string.navigation_drawer_open, R.string.navigation_drawer_close);

当然我们把上面带Home旋转开关按钮的代码删除也是可以的。

效果如图:

Toolbar上不显示Home旋转开关按钮.gif

(五)、不使用NavigationView,使用DrawerLayout+其他布局

APP实际开发中往往不能完全按照Materialdesign的规则来,如网易云音乐的侧滑,底部还有两个按钮。这时候我们可以通过+其他布局来实现特殊的侧滑布局。

我们可以参考鸿杨大神的博客
Android 自己实现 NavigationView [Design Support Library(1)]

我们自己实现个简单的,DrawerLayout包裹了一个FrameLayout和一个RelativeLayout,FrameLayout是我们的显示内容区域,RelativeLayout是我们的侧边栏布局。

<android.support.v4.widget.DrawerLayoutandroid:id="@+id/drawer_layout"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"android:fitsSystemWindows="true"tools:openDrawer="start"><FrameLayoutandroid:id="@+id/container"android:layout_width="match_parent"android:layout_height="match_parent"><android.support.v7.widget.Toolbarandroid:id="@+id/toolbar"android:layout_width="match_parent"android:layout_height="?attr/actionBarSize"android:background="?attr/colorPrimary"app:popupTheme="@style/AppTheme.PopupOverlay"/><TextViewandroid:layout_width="match_parent"android:layout_height="match_parent"android:gravity="center"android:padding="16dp"android:text="@string/title_activity_drawer_layout_other"/></FrameLayout><RelativeLayoutandroid:id="@+id/nav_view"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_gravity="start"android:background="@android:color/white"android:fitsSystemWindows="true"><Buttonandroid:layout_width="match_parent"android:layout_height="wrap_content"android:text="这是顶部按钮"/><Buttonandroid:layout_width="match_parent"android:layout_height="wrap_content"android:layout_centerInParent="true"android:text="这是中间的按钮"/><Buttonandroid:layout_width="match_parent"android:layout_height="wrap_content"android:layout_alignParentBottom="true"android:text="这是底部按钮"/></RelativeLayout>
</android.support.v4.widget.DrawerLayout>

如果需要监听DrawerLayout的侧滑状态监听,那么代码如下:

mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout);/*** 也可以使用DrawerListener的子类SimpleDrawerListener,* 或者是ActionBarDrawerToggle这个子类*/mDrawerLayout.setDrawerListener(new DrawerLayout.SimpleDrawerListener() {@Overridepublic void onDrawerClosed(View drawerView) {super.onDrawerClosed(drawerView);}@Overridepublic void onDrawerOpened(View drawerView) {super.onDrawerOpened(drawerView);}});

效果图如下:

DrawerLayout+其他布局.gif

最后上github地址

https://github.com/itdais/MaterialDesignDing

												

NavigationView使用详解相关推荐

  1. Android Material Design 系列之 BottomNavigationView + ViewPager + Fragment + BadgeView 开发详解

    前言 BottomNavigationView 是 Material Design 提供的一个标准底部导航栏的实现,可以轻松的实现导航栏菜单之间的切换与浏览.底部导航使用户更方便的查看和切换最高层级的 ...

  2. Material Design系列之BottomNavigationView详解

    Material Design系列之BottomNavigationView详解 Material Design官方文档Bottom navigation的介绍 BottomNavigationVie ...

  3. DrawerLayout的导航图标详解

    前言 DrawerLayout是Google官方推出的一个应用于侧滑菜单的工具类,遵循Google提出的Material Design设计风格.而DrawerLayout与Toolbar之间的图标联动 ...

  4. 从命令行到IDE,版本管理工具Git详解(远程仓库创建+命令行讲解+IDEA集成使用)

    首先,Git已经并不只是GitHub,而是所有基于Git的平台,只要在你的电脑上面下载了Git,你就可以通过Git去管理"基于Git的平台"上的代码,常用的平台有GitHub.Gi ...

  5. JVM年轻代,老年代,永久代详解​​​​​​​

    秉承不重复造轮子的原则,查看印象笔记分享连接↓↓↓↓ 传送门:JVM年轻代,老年代,永久代详解 速读摘要 最近被问到了这个问题,解释的不是很清晰,有一些概念略微模糊,在此进行整理和记录,分享给大家.在 ...

  6. docker常用命令详解

    docker常用命令详解 本文只记录docker命令在大部分情境下的使用,如果想了解每一个选项的细节,请参考官方文档,这里只作为自己以后的备忘记录下来. 根据自己的理解,总的来说分为以下几种: Doc ...

  7. 通俗易懂word2vec详解词嵌入-深度学习

    https://blog.csdn.net/just_so_so_fnc/article/details/103304995 skip-gram 原理没看完 https://blog.csdn.net ...

  8. 深度学习优化函数详解(5)-- Nesterov accelerated gradient (NAG) 优化算法

    深度学习优化函数详解系列目录 深度学习优化函数详解(0)– 线性回归问题 深度学习优化函数详解(1)– Gradient Descent 梯度下降法 深度学习优化函数详解(2)– SGD 随机梯度下降 ...

  9. CUDA之nvidia-smi命令详解---gpu

    nvidia-smi是用来查看GPU使用情况的.我常用这个命令判断哪几块GPU空闲,但是最近的GPU使用状态让我很困惑,于是把nvidia-smi命令显示的GPU使用表中各个内容的具体含义解释一下. ...

最新文章

  1. AI一分钟 | Facebook或将面临2万亿美元罚款;大疆寻求新一轮融资,估值150亿美元
  2. Mysql中S 锁和 X 锁的区别
  3. Springmvc配置定时任务注解开发
  4. 【面向对象】第一单元总结——表达式求导
  5. mysql 5.7 的组复制
  6. 理解SQLNET.AUTHENTICATION_SERVICES参数|转|
  7. 新建虚拟机update时出现不能得到锁问题
  8. Redis缓存雪崩、缓存穿透、热点Key解决方案和分析
  9. linux 写一个包含test的脚本程序,linux的test命令及相关shell脚本详解
  10. 木瓜蛋白酶改性金纳米粒修饰淀粉/二氧化硅复合微球/硒化镉/聚苯乙烯荧光二氧化硅微球的研究
  11. 打印机扫描显示服务器没有响应,打印机扫描一体机能够打印却不能扫描,提示缺少WIA的驱动程序...
  12. vue 的ui组件库
  13. Android 10 添加第三方输入法为系统默认输入法
  14. 失焦事件及取消失焦事情
  15. Python爬取童程童美TTS网站知识点图片
  16. error LNK1120: 1 个无法解析的外部命令。
  17. [IDEA]~idea快捷键及Eclipse和Idea快捷键对比
  18. 【Rust日报】2022-10-09 出于什么原因,您应该选择 rust 进行后端开发而不是其他选项?...
  19. 工业互联网方兴未艾,做好工业现场数据管理是破局关键
  20. 大学生生涯规划1000字计算机专业,我的职业生涯规划计算机专业1000字

热门文章

  1. 「面经分享」小米java岗二面面经,已拿offer
  2. 从小康到极狐,华为的“造好车”答卷,你准备打几分?
  3. 了解TypeScript装饰器
  4. linux运行python
  5. 痛苦的对接体验——软工第一次结对作业
  6. 母亲节不能陪在妈妈身边,我用css和js给妈妈做了一个爱心飘落
  7. java 安全警告_java忽略安全警告注解@SuppressWarnings
  8. Java培训完能不能就业?
  9. 去掉goland中间的令人烦躁的竖线
  10. 丘成桐:人类生活在十维宇宙里