您的位置:首页 > 其它

MaterialDesign学习笔记1:DrawerLayout+NavigationView实现抽屉效果

2016-09-24 16:24 465 查看

DrawerLayout+NavigationView实现抽屉效果

Google I/O 2015 给大家带来了Android Design Support Library,一直对Material Design感兴趣,最近开始学习MD风格控件,在使用的时候顺便整理成笔记。

效果图如下:



涉及到的控件:

1. DrawerLayout

2. NavigationView

3. Toolbar

首先在
build.gradle
导入相对应的包:

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


布局

布局文件如下:

<android.support.v4.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" />

<android.support.design.widget.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=
4000
"@menu/activity_main_drawer" />

</android.support.v4.widget.DrawerLayout>


···

DrawerLayout

DrawerLayout
用于实现抽屉效果,里面嵌套了两个内容。

第一个子元素是主要内容,即抽屉没有打开时显示的布局。

第二个子元素是抽屉中的内容,即抽屉布局。这里采用了
NavigationView
,但不限于此,可以使用
ListView
代替。

NavigationView

NavigationView
作为
DrawerLayout
第二个子元素,实现导航栏。导航栏主要有两个内容,可以根据实际删减。

app:headerLayout
导航栏的头部布局

app:menu
导航栏的菜单条目

ps:默认的颜色很多是从当前的主题中提取的,比如icon的stateColor,当然你也可以通过以下属性修改部分样式:

app:itemIconTint=""
app:itemBackground=""
app:itemTextColor=""


···

NavigationView HeaderLayout 布局如下:

<?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="@dimen/nav_header_height"
android:background="@drawable/side_nav_bar"
android:gravity="bottom"
android:orientation="vertical"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:theme="@style/ThemeOverlay.AppCompat.Dark">

<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingTop="@dimen/nav_header_vertical_spacing"
android:src="@android:drawable/sym_def_app_icon" />

<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="@dimen/nav_header_vertical_spacing"
android:text="Android Studio"
android:textAppearance="@style/TextAppearance.AppCompat.Body1" />

<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="android.studio@android.com" />

</LinearLayout>


NavigationView menu 菜单如下:

<?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/nav_camera"
android:icon="@drawable/ic_menu_camera"
android:title="Import" />
<item
android:id="@+id/nav_gallery"
android:icon="@drawable/ic_menu_gallery"
android:title="Gallery" />
<item
android:id="@+id/nav_slideshow"
android:icon="@drawable/ic_menu_slideshow"
android:title="Slideshow" />
<item
android:id="@+id/nav_manage"
android:icon="@drawable/ic_menu_manage"
android:title="Tools" />
</group>

<item android:title="Communicate">
<menu>
<item
android:id="@+id/nav_share"
android:icon="@drawable/ic_menu_share"
android:title="Share" />
<item
android:id="@+id/nav_send"
android:icon="@drawable/ic_menu_send"
android:title="Send" />
</menu>
</item>

</menu>


分割线
<item android:title="Communicate">
下面的项目,

点击后不能选中?可以添加
android:checkable="true"


代码

package com.tangvim.drawernavigation;

import android.os.Bundle;
import android.support.design.widget.NavigationView;
import android.support.v4.view.GravityCompat;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.MenuItem;

public class MainActivity extends AppCompatActivity
implements NavigationView.OnNavigationItemSelectedListener {

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

// Toolbar 的定义
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
final ActionBar ab = getSupportActionBar();
ab.setHomeAsUpIndicator(R.drawable.ic_menu);    //设置导航键图片
ab.setDisplayHomeAsUpEnabled(true);     //显示导航键
// 关联导航键
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);
}
}


抽屉的打开,需要设置监听
drawer.setDrawerListener(toggle)
,

监听的内容
ActionBarDrawerToggle
, 最后调用
toggle.syncState()
方法初始化。

点击导航栏也需要设置监听
navigationView.setNavigationItemSelectedListener(this)
,

具体实现如下:

@SuppressWarnings("StatementWithEmptyBody")
@Override
public boolean onNavigationItemSelected(MenuItem item) {
// Handle navigation view item clicks here.
int id = item.getItemId();

if (id == R.id.nav_camera) {
// Handle the camera action
} else if (id == R.id.nav_gallery) {

} else if (id == R.id.nav_slideshow) {

} else if (id == R.id.nav_manage) {

} else if (id == R.id.nav_share) {

} else if (id == R.id.nav_send) {

}

DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
drawer.closeDrawer(GravityCompat.START);    //点击后关闭
return true;
}


抽屉的几钟常见用法

设置导航栏头部布局的方法

View view = navigationView.getHeaderView(0);
ImageView header = (ImageView)view.findViewById(R.id.imageView);


获取 menu 初始位置的 ID

LastItemId = navigationView.getMenu().getItem(0).getItemId();


设置 item 选中状态

item.setChecked(true);  //设置为选中状态


参考资料:

Android 自己实现 NavigationView [Design Support Library(1)]
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: