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)]
相关文章推荐
- NavigationView+DrawerLayout实现侧拉抽屉效果
- MaterialDesign之NavigationView和DrawerLayout实现侧滑菜单栏(抽屉)
- MaterialDesign学习笔记2:TabLayout+ViewPaper实现滑动切换
- NavigationView+DrawerLayout实现侧滑栏效果
- Android DrawerLayout+Toolbar+NavigationView(实现侧拉侧滑效果)
- Android实现侧滑抽屉菜单(DrawerLayout+NavigationView+toolbar)
- Kotlin实现侧滑抽屉菜单(DrawerLayout+NavigationView+Toolbar)
- Android DrawerLayout+ToolBar+NavigationView实现侧滑菜单效果,沉浸式状态栏
- MaterialDesign之NavigationView和DrawerLayout实现侧滑菜单栏
- Android中DrawerLayout+Toolbar实现侧滑效果[DrawerLayout+ToolBar+NavigationView]
- Android5.0之NavigationView的使用 。android组件之DrawerLayout(抽屉导航)-- 侧滑菜单效果
- 实现滑动菜单效果DrawerLayout+NavigationView
- Android-NavigationView+DrawerLayout实现抽屉菜单
- Android中利用DrawerLayout+NavigationView实现滑动菜单效果
- DrawerLayout实现网易新闻抽屉效果
- DrawerLayout实现网易新闻抽屉效果
- Material Design (一),NavigationView+DrawerLayout轻松实现侧拉菜单
- 学习笔记--View滑动效果的七种实现方式(一)
- Android DrawerLayout+NavigationView布局实现左右两边侧滑菜单
- toolbar+DrawerLayout+NavigationView的最佳实现