美文网首页
MD系列之Toolbar和NavigationView快速入门

MD系列之Toolbar和NavigationView快速入门

作者: ustcmio | 来源:发表于2017-01-17 17:26 被阅读0次

一、快速使用

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

    <style name="AppTheme.noActionbar" parent="Theme.AppCompat.Light.NoActionBar">
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>

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

 <application 
        android:theme="@style/AppTheme.noActionbar"
        ...>

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

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"  
        android:background="?attr/colorPrimary"
        android:theme="@style/ThemeOverlay.AppCompat.ActionBar"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light">
    </android.support.v7.widget.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的布局文件(如果没有,新建)
    <menu xmlns:tools="http://schemas.android.com/tools"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <item
    android:id="@+id/action_ball"
    android:title="篮球"
    android:showAsAction="never"
    tools:ignore="AppCompatResource"
    android:orderInCategory="80"/>
    <item .../>
    其中: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-->
<android.support.v4.widget.DrawerLayout...>
      <!-- content部分,可以通过include添加内容,Toobar在activity_main中 -->
      <include layout="@layout/activity_main"... />
      <!-- navigationView部分 -->
      <android.support.design.widget.NavigationView.../>
</android.support.v4.widget.DrawerLayout>

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

<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:id="@+id/drawerLayout"
    >

*** NavigationView部分 ***

<!--
1、layout_gravity属性:必须设置,指明导航栏的位置;不指定的话,将全屏
2、app:menu属性:必须设置。 指明导航栏菜单布局文件(res/menu/下),格式如下:
      <menu>
          <group>
              <item/>导航栏中的选项
              ...
          </group>
      </menu>
3、app:headerLayout属性:可选。指明布局文件,一般为导航栏添加头像和说明
-->
<android.support.design.widget.NavigationView
        android:id="@+id/navigationView" 
        android:layout_width="match_parent"
        android:layout_height="match_parent"        
        android:layout_gravity="start"
        app:menu="@menu/navigation_menu"
        app:headerLayout="@layout/header_layout">
    </android.support.design.widget.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快速入门

      本文链接:https://www.haomeiwen.com/subject/iepmbttx.html