(1)简介
Toolbar 是 Android 5.0 推出的一个 Material Design 风格的导航控件 ,用来取代之前的 Actionbar 。与 Actionbar 相比,Toolbar 明显要灵活的多。它不像 Actionbar 一样,一定要固定在Activity的顶部,而是可以放到界面的任意位置。
(2)修改主题
当我们新建一个工程时,我们发现默认是有导航栏的, 如图:
data:image/s3,"s3://crabby-images/d0e32/d0e32acb90d9e2887fb672babc57f1453ffa15f5" alt=""
那是因为默认app主题自带了导航栏
data:image/s3,"s3://crabby-images/3e8e4/3e8e48c585034d91e6649df49847de7092672802" alt=""
data:image/s3,"s3://crabby-images/e5127/e512760797c2d66dde7c7c56bb8e036678b19bf6" alt=""
我们发现,系统自带的是一个actionBar,那么我们就换一个主题
data:image/s3,"s3://crabby-images/328e7/328e7d1c8a10f61400fd8dba1dbb18ccf8e62552" alt=""
三种主题任意选择一个即可。
现在开始添加一个ToolBar。
(3)Toolbar导包选择
data:image/s3,"s3://crabby-images/6a836/6a836c5d4347480358ef26e5d6921f10fc8d274c" alt=""
如图所示,Toolbar有两种导包,建议使用v7的那个,因为第二种只支持Android5.0以上的手机。
(4)Toolbar基本代码
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar_normal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:collapseIcon="@mipmap/ic_launcher"
app:buttonGravity="bottom"
app:navigationIcon="@mipmap/ic_launcher"
app:popupTheme="@style/Animation.AppCompat.Dialog"
app:logoDescription="asdasdasd"
app:maxButtonHeight="50dp"
app:navigationContentDescription="tttttt"
app:title="Title"
app:titleTextColor="#ffffff"
android:background="@color/colorPrimaryDark"
app:subtitle="SubTitle"
app:subtitleTextColor="#ffffff"
app:logo="@mipmap/ic_launcher">
</android.support.v7.widget.Toolbar>
(5)基本属性
- background 设置背景色
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar_normal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimaryDark">
</android.support.v7.widget.Toolbar>
data:image/s3,"s3://crabby-images/3a0f2/3a0f24d045bb31320130a93f7da7417637792dda" alt=""
目前发现,设置toolbar背景色之后,状态栏也会随之变化。
- navigationIcon 添加返回按钮
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar_normal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimaryDark"
app:navigationIcon="@mipmap/back">
</android.support.v7.widget.Toolbar>
data:image/s3,"s3://crabby-images/54fc8/54fc87d0cb163a6a7fb607374e96577df7161053" alt=""
- logo 添加logo
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar_normal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimaryDark"
app:navigationIcon="@mipmap/back"
app:logo="@mipmap/ic_launcher">
</android.support.v7.widget.Toolbar>
data:image/s3,"s3://crabby-images/8bc86/8bc86f860ca9b52fec8c9a97d1fd776193b84e37" alt=""
- title和subtitle 添加标题和子标题
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar_normal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimaryDark"
app:navigationIcon="@mipmap/back"
app:logo="@mipmap/ic_launcher"
app:title="ToolBar标题"
app:subtitle="ToolBar子标题">
</android.support.v7.widget.Toolbar>
data:image/s3,"s3://crabby-images/ec2a6/ec2a6b1f78fa16fd2b6e40a211fd74e005a465c6" alt=""
- titleTextColor和subtitleTextColor 修改标题和子标题的颜色
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar_normal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimaryDark"
app:navigationIcon="@mipmap/back"
app:logo="@mipmap/ic_launcher"
app:title="ToolBar标题"
app:subtitle="ToolBar子标题"
app:titleTextColor="#ffffff"
app:subtitleTextColor="#ffffff">
</android.support.v7.widget.Toolbar>
data:image/s3,"s3://crabby-images/fc2f2/fc2f2152af25b22563900051014e9e806108756b" alt=""
- collapseIcon 设置折叠视图的图标
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar_normal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimaryDark"
app:navigationIcon="@mipmap/back"
app:logo="@mipmap/ic_launcher"
app:title="ToolBar标题"
app:collapseIcon="@mipmap/back"
app:subtitle="ToolBar子标题"
app:titleTextColor="#ffffff"
app:subtitleTextColor="#ffffff">
data:image/s3,"s3://crabby-images/e033d/e033d213167794f3d5ffd2666fe633fda2f744d8" alt=""
这个后面有详细介绍。
(6)添加菜单
通过inflateMenu可以添加toolbar的菜单
toolbar_normal.inflateMenu(R.menu.toolbar_menu);
菜单布局是
<menu
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/action_search"
android:icon="@mipmap/back"
android:title="按钮1"
app:showAsAction="ifRoom" />
<item
android:id="@+id/action_notification"
android:icon="@mipmap/back"
android:title="按钮2"
app:showAsAction="ifRoom" />
<item
android:id="@+id/action_item_one"
android:title="按钮3"
app:showAsAction="never" />
<item
android:id="@+id/action_item_two"
android:title="按钮4"
app:showAsAction="never" />
</menu>
效果如下:
data:image/s3,"s3://crabby-images/95942/95942e5d267e4b30dabb5e1f9fd31e048124f585" alt=""
data:image/s3,"s3://crabby-images/d8931/d8931536f72e055e2e0703ab7ddd0c7701e31fae" alt=""
每个菜单都可以设置特有的属性
- orderInCategory
设置菜单项的排列顺序,必须设置大于等于0的整数值。数值小的排列在前,如果值相等,则按照xml中的顺序展现。 - title
菜单项的标题。 - icon
菜单项的图标。 - showAsAction
该属性有五个值,可以混合使用。
always:总是显示在Toolbar上。
ifRoom:如果Toolbar上还有空间,则显示,否则会隐藏在溢出列表中。
never:永远不会显示在Toolbar上,只会在溢出列表中出现。
withText:文字和图标一起显示。
collapseActionView:声明了这个操作视窗应该被折叠到一个按钮中,当用户选择这个按钮时,这个操作视窗展开。一般要配合ifRoom一起使用才会有效。
这里重点介绍一下collapseActionView
属性,利用collapseActionView
属性实现“点击按钮展开成搜索框”
第一步:设置折叠视图图标
data:image/s3,"s3://crabby-images/efb2c/efb2c91d55455bd92050b6c1268638275c88c03e" alt=""
第二步:修改菜单属性
data:image/s3,"s3://crabby-images/94ddf/94ddfeeabc160d4dd43ff9367db4a65d492ac3d8" alt=""
这样的话就可以实现下图的效果
data:image/s3,"s3://crabby-images/0d4fe/0d4fe5de157335a9bfaa5101790634a2f7edf2a8" alt=""
(7)setOnMenuItemClickListener
设置Item的点击事件
toolbar_normal.setOnMenuItemClickListener(new Toolbar.OnMenuItemClickListener() {
@Override
public boolean onMenuItemClick(MenuItem menuItem) {
switch (menuItem.getItemId()){
case R.id.action_item_one:
break;
case R.id.action_item_two:
break;
case R.id.action_notification:
break;
case R.id.action_search:
break;
}
return true;
}
});
(8)setNavigationOnClickListener
设置返回键点击事件
toolbar_normal.setNavigationOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
}
});
(9)SearchView
有关SearchView,前面已经介绍过怎么展示了,下面介绍怎么去设置监听
SearchView searchView = (SearchView) menuItem.getActionView();
searchView.setQueryHint("搜索");
//((ImageView)searchView.findViewById(R.id.search_button)).setImageResource(R.mipmap.shennvguo2);
searchView.setOnSearchClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//当点击搜索编辑框的时候执行,刚进入时默认点击搜索编辑框
}
});
searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String s) {
//点击软键盘搜索的时候执行
return false;
}
@Override
public boolean onQueryTextChange(String s) {
//搜索框文本发生改变的时候执行
return false;
}
});
searchView.setOnQueryTextFocusChangeListener(new View.OnFocusChangeListener() {
@Override
public void onFocusChange(View v, boolean hasFocus) {
//当得到焦点和失去焦点的时候执行
}
});
menuItem.setOnActionExpandListener(new MenuItem.OnActionExpandListener() {
@Override
public boolean onMenuItemActionExpand(MenuItem item) {
//展开时回调
return true;
}
@Override
public boolean onMenuItemActionCollapse(MenuItem item) {
//收起来时回调
return true;
}
});
(10)Overflow
修改overflow的图标
//设置overflow图标
toolbar_normal.setOverflowIcon(ContextCompat.getDrawable(this,R.mipmap.overflow));
data:image/s3,"s3://crabby-images/341d7/341d749bd8e97038e52facc7091c5e173b087637" alt=""
(11)overflow popup主题
data:image/s3,"s3://crabby-images/20707/20707a5bb882a25062eacdb8ccb4992aef90f09f" alt=""
溢出菜单就不介绍了,目前没有什么好办法可以自定义布局。
data:image/s3,"s3://crabby-images/2adbc/2adbc06c5d5f756599713b0ed666bc56fd1fc4f6" alt=""
(12)添加子布局
data:image/s3,"s3://crabby-images/6f7ab/6f7ab79f633b9af28e2a2c9e608a393a0b3c7828" alt=""
Toolbar的父类是ViewGroup,我们常用的线性布局和相对布局的父类也是ViewGroup,所以Toolbar也同样可以添加子布局,看以下代码
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar_normal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/colorPrimaryDark"
app:navigationIcon="@mipmap/back"
app:popupTheme="@style/OverflowMenuStyle"
app:collapseIcon="@mipmap/back">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/colorAccent"
android:text="标题"
android:layout_gravity="center"
android:textSize="20sp"/>
</android.support.v7.widget.Toolbar>
我们添加一个标题,使它居中
data:image/s3,"s3://crabby-images/4bf53/4bf53f88a899628b0613db4edb8299ff50ce8866" alt=""
[本章完...]
网友评论