Android Toolbar,你想知道的都在这里了

Android 3.0之后,Google引入了ActionBar,想统一安卓应用的导航栏样式。但由于ActionBar难以定制,很大程度上限制了开发人员,比如标题文字大小、间距等不易实现个性化,很多开发者放弃了ActionBar的使用,而是使用普通的ViewGroup来封装自己的App Bar,或者使用JakeWharton大神的ActionBarSherlock库。

后来,自2014年Google I/O 上Material Design横空出世后,市场上的应用又逐步趋向了样式的风格统一,support library中很快就出来了Toolbar控件,一个定制化的ViewGroup,来完善ActionBar的使用,App Bar又迎来了春天。

基本使用

第一步,在Theme中隐藏现有的ActionBar,有以下两种方式:

<style name="AppTheme.Base" parent="Theme.AppCompat"><item name="windowActionBar">false</item><item name="android:windowNoTitle">true</item>......</style>

或者

<style name="AppTheme.Base" parent="heme.AppCompat.Light.NoActionBar">......</style>

第二步,在布局中添加v7包中的Toolbar控件(注意在builde.gradle文件中添加support.v7包的依赖:compile ‘com.android.support:appcompat-v7:23.3.0’),如:

 <android.support.v7.widget.Toolbar xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/tb_toolbar" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" app:title="@string/app_name" app:titleTextColor="@android:color/white" android:background="@color/colorPrimary"> </android.support.v7.widget.Toolbar>

第三步,在Activity代码中使用Toolbar对象替换ActionBar:

Toolbar mToolbarTb = (Toolbar) findViewById(R.id.tb_toolbar);setSupportActionBar(mToolbarTb);

效果如下:




诸如logo、title、subTitle、navigationIcon等,都可以通过app:xxx属性和Java代码来控制。titleTextAppearance、subtitleTextAppearance也可以用来控制标题颜色和大小,如:

<style name="Theme.ToolBar.Base.Title" parent="@style/TextAppearance.Widget.AppCompat.Toolbar.Title"><item name="android:textSize">18sp</item><item name="android:textColor">@android:color/white</item></style>
Options Menu

与ActionBar的用法一致,在menu资源目录下新建一个search.xml文件,添加menu内容,如:

<?xml version="1.0" encoding="utf-8"?><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:title="search" android:icon="@android:drawable/ic_menu_search" app:showAsAction="collapseActionView"/></menu>

在Java代码中添加为Toolbar添加对应的Menu Item,并设置点击事件,如:

 @Override public boolean onCreateOptionsMenu(Menu menu){ getMenuInflater().inflate(R.menu.search, menu); return super.onCreateOptionsMenu(menu); } @Override public boolean onOptionsItemSelected(MenuItem item){ switch (item.getItemId()) { case R.id.action_search: //TODO search break; } return super.onOptionsItemSelected(item); }

效果如下:




如图,溢出按钮的颜色是黑色,那么怎么修改成与主题色搭配的白色呢?可以通过修改Toolbar的theme和popupTheme属性来改变,在Toolbar中添加如下属性:

 <android.support.v7.widget.Toolbar ...... app:popupTheme="@style/ThemeOverlay.AppCompat.Light" app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> </android.support.v7.widget.Toolbar>

还有另一种方式,就是使用theme中的actionMenuTextColor属性设置Menu Item的字体颜色,如:

 <style name="OverFlowMenuTheme" parent="Theme.AppCompat.NoActionBar"> <item name="android:actionMenuTextColor">@android:color/white</item> <item name="overlapAnchor">false</item> </style>

Toolbar中的相关theme设置如下:

 <android.support.v7.widget.Toolbar ...... app:popupTheme="@style/OverFlowMenuTheme" app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"> </android.support.v7.widget.Toolbar>

一般也是采用这种做法,将Toolbar相关属性集中写到一个style中,比如:

 <style name="OverFlowMenuTheme" parent="Theme.AppCompat.NoActionBar"> <!-- 设置Menu菜单的背景色 --> <item name="android:itemBackground">@android:color/white</item> <!-- 设置Menu菜单的字体颜色 --> <item name="android:textColorPrimary">@android:color/black</item> <!-- 设置Menu窗口不覆盖Toolbar视图 --> <item name="overlapAnchor">false</item> </style>

这样设置下的效果如下图所示:



Up Enable

在二级界面等Activity中,通过如下设置可以在Toolbar左边显示一个返回按钮:

getSupportActionBar().setDisplayHomeAsUpEnabled(true);

然后通过android.R.id.home监听返回按钮的点击事件,比如可以返回上级Activity中:

 @Override public boolean onOptionsItemSelected(MenuItem item){ switch (item.getItemId()) { case android.R.id.home: finish(); break; } return super.onOptionsItemSelected(item); }

当然,也可以通过为Toolbar设置导航图标的点击事件来达到这个监听效果:

mToolbarTb.setNavigationOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v){finish();}});

显示效果如下:




至于导航返回按钮的图标,可以通过mToolbarTb.setNavigationIcon方法或者app:navigationIcon属性来修改。

标题居中

前面我们说过,Toolbar就是一个定制化的ViewGroup,所以可以在Toolbar里面放置一个TextView控件作为居中的标题来使用,再将Toolbar的Title隐藏起来即可实现Toolbar标题居中的效果,如:

 <android.support.v7.widget.Toolbar xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/tb_toolbar" android:layout_width="match_parent" android:layout_height="?attr/actionBarSize" app:popupTheme="@style/OverFlowMenuTheme" app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" android:background="@color/colorPrimary"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" android:text="SecondActivity" style="@style/TextAppearance.AppCompat.Widget.ActionBar.Title"/> </android.support.v7.widget.Toolbar>

这里给TextView设置了style属性,与ActionBar.Title保持一致,然后还需要去除Toolbar自有的Title,在布局中使用app:title=""是不会起作用的,会显示ActionBar的标题,所以在代码中隐藏ActionBar的标题即可:

getSupportActionBar().setDisplayShowTitleEnabled(false);

效果如下:



Fragment中使用

有时候需要在Fragment中使用Toolbar,比如Activity中不同的Tab显示不同的Fragment,同时每个Tab的Toolbar标题、Menu均不相同,这时在Activity中使用同一个Toolbar就相当不方便了。我们可以在每个Fragment的布局中添加各自的Toolbar,然后在Fragment中单独控制。
与Activity中使用Toolbar有所不同。替换ActionBar时,需要给setSupportActionBar方法添加作用对象:

((AppCompatActivity)getActivity()).setSupportActionBar((Toolbar) mContentView.findViewById(R.id.tb_toolbar));

添加Options Menu时,需要额外调用setHasOptionsMenu(true);方法,确保onCreateOptionsMenu()方法得以调用,并且onCreateOptionsMenu()方法多了一个MenuInflater参数:

@Overridepublic void onCreateOptionsMenu(Menu menu, MenuInflater inflater){super.onCreateOptionsMenu(menu, inflater);inflater.inflate(R.menu.search, menu);}
相关知识

关于Toolar的更多介绍可以从官网中学习借鉴,链接为:Adding the App Bar | Android Developers。从其使用上可以看出,Toolbar是ActionBar的一种替代解决方案,所以很多用法均可参考ActionBar,大家可以从郭神的译文中掌握ActionBar的相关用法:

Android ActionBar完全解析,使用官方推荐的最佳导航栏(上)
Android ActionBar完全解析,使用官方推荐的最佳导航栏(下)

文章标签:

相关阅读

  • 真实经历:九块九包邮的紫砂壶你们会用吗
  • 现在市面上的紫砂壶几十到几十万的价格不等,甚至有那种几块钱的紫砂壶。今天有一个壶友加了小编,问起有没有套装的紫砂壶,小编说可以帮他配。这位壶友说要便宜点的接着就把

  • 9.9元包邮,返70%佣金,告诉你为什么会有微信、
  • 为什么会有这么多微信群、QQ群,向你不断得推送淘宝、天猫上的产品信息? 无无利不起早,你是否想过他们的动力在哪里? 这些向你推荐信息的,在行业内我们称为【淘宝客】 淘宝

  • 淘宝优惠卷是真的吗?
  • 生活中你可能会碰到一些分享淘宝天猫优惠券的群或者是公众号,他们会天天分享一些商品在群里或者公众号上,因为有优惠券的原因,这些商品的价格都很诱人。很多人就开始怀疑这些

  • 【淘宝优惠券】乐天网上免税店优惠券-Android客户
  • 乐天网上免税店优惠券-Android客户端 车美汇淘宝人工投诉电话内部优惠券怎么赚钱聚划算淘宝商城陆婷应援会,球星卡论坛淘宝飞猪西财考研网,永源汽车配件卡通充气小登老妖精意外

  • |双十一|狂送代金券!优惠不止50%!带你shop
  • 双十一 一场酣战 自然是要早早列好购物清单 精挑细选,生怕自己比别人买贵了 为了给大家提供一个超值的双十一 小爱更是夜夜加班 看着日渐后移的发际线 于是决定趁着双十一,多囤

  • 重磅!网购福利!教你网购怎样才能更省钱,内
  • 现在几乎每个人的生活, 都离不开淘宝, 无论你想买什么, 在淘宝上都能搜到, 价格也能比实体店便宜不少。 买买买使我快乐, 但也让我的心一直滴血 每当我打开已买到的宝贝清单

  • 「干货分享」你朋友圈的淘宝优惠券是怎么回事
  • 淘宝优惠券 当我提笔写第二篇赚钱稿件的时候,我的心在颤抖,因为我正在依靠淘宝优惠券赚取工作以外的收入,而且每个月收入还不错。而我身边想要了解的朋友,我一般都会倾力帮

  • 淘宝,天猫优惠券难道是骗局吗,不看你可能还
  • 我们时常会看到或者在某个平台看到广告,网购不领券,白花冤枉钱,这句话给我来了很大的洗脑,哈哈,那么这些所谓的大额优惠券是真的吗? 为了一探究竟小编打算以身试险(说的

  • 西班牙自由行最新游玩美食攻略-西班牙特色美食
  • 你是否有这样的困扰,有一颗想随时环游世界的心,却被自己的中国胃束缚住脚步。 作为我大天朝的吃货般的存在,怎么可以容忍在外吃不好的情况出现? 如果你也是这样的吃货星人

  • 看完双宋蜜月旅行, 你也许会明白, 西班牙成为新
  • 对望、牵手、整理头纱,爱一个人,眼神不会骗人。 我们说,36岁的乔妹,是嫁给了爱情。 话说回来,双宋婚礼过后,很多人都在猜,他们会不会去希腊度蜜月,扎金索斯沉船湾,那个

优惠券资讯优惠券常识