Android Material风格的应用(三)--DrawerLayout

添加抽屉导航

Android Material风格的应用(一)--AppBar TabLayout
Android Material风格的应用(二)--RecyclerView
Android Material风格的应用(三)--DrawerLayout
Android Material风格的应用(四)--FloatActionButton
Android Material风格的应用(五)--CollapsingToolbar

DrawerLayout

工程源码

  • 创建导航菜单
    res/menu/menu-natigation.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android">
  <group android:checkableBehavior="single">
      <item android:icon="@drawable/ic_home_black_24dp"
          android:tint="@color/button_grey"
          android:title="One" />
      <item android:icon="@drawable/ic_favorite_black_24dp"
          android:tint="@color/button_grey"
          android:title="Two"/>
      <item android:icon="@drawable/ic_bookmark_border_black_24dp"
          android:tint="@color/button_grey"
          android:title="Three"/>
  </group>
</menu>

创建导航的布局 res/layout/navigation.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical" android:layout_width="match_parent"
  android:layout_height="@dimen/navheader_height"
  android:background="?attr/colorPrimaryDark"
  android:padding="@dimen/md_keylines">
</LinearLayout>

activity_main.xml中加入DrawerLayout ,是DrawerLayout作为对顶层,使CoordinatorLayout作为它的
子级

<android.support.v4.widget.DrawerLayout
  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="match_parent"
  android:fitsSystemWindows="true">
    ......
  </android.support.v4.widget.DrawerLayout>

CoordinatorLayout的同一级添加NavigationView

<android.support.design.widget.NavigationView
  android:layout_width="wrap_content"
  android:layout_height="match_parent"
  android:id="@+id/nav_view"
  android:layout_gravity="start"
  android:fitsSystemWindows="true"
  app:headerLayout="@layout/nav_header"
  app:menu="@menu/menu_navigation">

MainActivity.javaonCreate中添加相关的逻辑

NavigationView navigationView = (NavigationView)findViewById(R.id.nav_view);
mDrawerLayout = (DrawerLayout)findViewById(R.id.drawer);
ActionBar supportActionBar = getSupportActionBar();
if(supportActionBar != null){
    supportActionBar.setHomeAsUpIndicator(R.drawable.ic_menu_white_24dp);
    supportActionBar.setDisplayHomeAsUpEnabled(true);
}
navigationView.setNavigationItemSelectedListener(new NavigationView.OnNavigationItemSelectedListener() {
    @Override
    public boolean onNavigationItemSelected(@NonNull MenuItem item) {
        item.setChecked(true);
        mDrawerLayout.closeDrawers();;
        return true;
    }
});

相应左上角的menu,打开导航

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    int id = item.getItemId();
    if(id == android.R.id.home){
        mDrawerLayout.openDrawer(GravityCompat.START);
    }
    return super.onOptionsItemSelected(item);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Toolbar 1.使用Toolbar,首先需要将系统的ActionBar隐藏,打开res/values/s...
    figure_ai阅读 4,744评论 1 3
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,707评论 25 709
  • 侧滑菜单这种设计,在很多 APP 上面都有看到,例如大版本3.0之前的知乎、网易新闻、滴滴打车等。有些热衷于 An...
    GinkWang阅读 26,109评论 2 35
  • 第四十三颗:一个能控制住不良情绪的人才是强大的;水深则流缓,语迟则人贵;我们花了两年时间学说话,却要花数十年时间学...
    水淼㵘爷阅读 1,618评论 0 0
  • 我出生于85年。于2017年的今日而言,我早已过了而立之年。这是一个人稳定进取的年纪。 在这个年纪,...
    秋石宁阅读 1,605评论 0 0