一、快速使用
第一步:导包
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);
获取对象,再单独添加监听