MD系列之Toolbar和NavigationView快速入门

一、快速使用

第一步:导包
compile 'com.android.support:design:25.1.0'
第二步:取消原有Actionbar,不然会报已有Actionbar的错误:
(1)自定义没有Actionbar的风格

    

(2)在AndroidManifest.xml中设置给Activity

 

第三部:布局文件中添加Toolbar

    
    

第四步:在Activity中设置Toolbar

        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

这样就完成了自定义Toolbar的添加。

二、Toolbar上的元素

  • 标题和子标题(title and subtitle)
    setTitle(String title)
    setSubTitle(String title)
    ** 必须要在setSupportActionBar(toolbar)之前设置**

  • Logo图标
    setLogo(int resId)

  • 组件 View
    因为Toolbar继承于ViewGroup本身是一个容器,可以添加View组件,可以在布局文件里面添加。可以用于添加搜索栏(后续补充)

  • Action Menu 设置菜单
    1、menu配置文件
    在res/menu中增加menu的布局文件(如果没有,新建)

    xmlns:android="http://schemas.android.com/apk/res/android">
    android:id="@+id/action_ball"
    android:title="篮球"
    android:showAsAction="never"
    tools:ignore="AppCompatResource"
    android:orderInCategory="80"/>

    其中:showAsAction属性,
    可选always(总是显示)、
    never(不显示)、
    ifRoom(有空间就显示)

      2、设置关联
      在activity中重写onCreateOptionMenu(Menu menu)
          @Override
          public boolean onCreateOptionsMenu(Menu menu) {
              getMenuInflater().inflate(R.menu.action_menu,menu);
          return true;
    
      3、重写回调函数
      toolbar.setOnMenuItemClickListener(
          new Toolbar.OnMenuItemClickListener() {
          @Override
          public boolean onMenuItemClick(MenuItem item) {}
          );
    
  • Navigation Button 导航按钮
    使用DrawerLayout + NavigationView + Toolbar实现侧滑导航栏

三、DrawerLayout + NavigationView + Toolbar实现侧滑导航栏

  • 第一步:布局文件
    一般整体布局文件如下:


      
      
      
      


下面来看每个部分的属性:
*** DrawerLayout部分 ***


*** NavigationView部分 ***



    
  • 第二步:activity中构建组件并设置监听
        //Toolbar组件
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        //抽屉布局组件
        DrawerLayout drawerLayout = (DrawerLayout) findViewById(R.id.drawerLayout);
        //构建对应的拖拽监听,5个参数:上下文、DrawerLayout、Toolbar、open字符串、close字符串
        ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
              this,drawerLayout,toolbar,R.string.open,R.string.close);
        //绑定监听
        drawerLayout.addDrawerListener(toggle);
        toggle.syncState();
  • 第三步:导航栏点击、关闭事件监听和回调函数
    为NavigationView的Menu添加监听
//设置监听
setNavigationItemSelectedListener(NavigationView.OnNavigationItemSelectedListener())
//重写回调方法
@Override
public boolean onNavigationItemSelected(@NonNull MenuItem item) {
    drawerLayout.closeDrawer(GravityCompat.START);//关闭导航栏
    //其他时间响应操作
    return false;
}
//通过onBackPressed()来关闭
if(drawerLayout.isDrawerOpen(GravityCompat.START)) {
   drawerLayout.closeDrawer(GravityCompat.START);
}else{
   super.onBackPressed();
   }        

为HeaderView添加监听
使用mNavigationView.getHeaderView(0);获取对象,再单独添加监听

你可能感兴趣的:(MD系列之Toolbar和NavigationView快速入门)