14年Android开发者大会提出了Android5.0 系统以及 材料设置 Material Design。在 材料设计中推出了大量的UI效果,其中某些功能 已添加进 兼容包,所以可以在低版本中来实现一些材料设计效果。今天主要介绍的就是 ActionBar的替代品 Toolbar。Toolbar 是在V7包兼容的,所以需要下载最新的V7包。

使用ToolBar主要从以下3个步骤开始:

  1. 样式定义显示效果,属性
  2. 在布局中使用ToolBar
  3. 在代码中设置属性

 1.  首先,来看下如何设置样式。由于Toolbar是替代ActionBar的,还需要使用 ActionBar兼容的Theme,但是需要做一些简单修改。

a. 先把ActionBar隐藏,为了 方便修改可以將原本 AppTheme 的 parent 属性改为 AppTheme.Base,修改文件 res/values/styles.xml

  1. <resources>
  2. <style name="AppTheme.Base" parent="Theme.AppCompat.Light.DarkActionBar">
  3. <item name="windowActionBar">false</item>
  4. <item name="android:windowNoTitle">true</item>
  5. </style>
  6. <style name="AppTheme" parent="AppTheme.Base"/>
  7. </resources>

b. 同样,为统一风格,需要将  /res/values-v21/styles.xml  的样式 parent 属性设置为 AppTheme.Base

  1. <resources>
  2. <style name="AppTheme" parent="AppTheme.Base"></style>
  3. </resources>

2. 在 Activity 布局中 加入 Toolbar 组件。注意:为了向下兼容,要使用 V7包下的 Toolbar,并且去掉最外层布局的padding属性。为了确保Toolbar的高度,需要设置 最小高度为ActionBar高度 android:minHeight="?attr/actionBarSize"。

  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. tools:context=".MainActivity">
  6. <android.support.v7.widget.Toolbar
  7. android:layout_width="match_parent"
  8. android:layout_height="<span style="font-family: Arial, Helvetica, sans-serif;">?attr/actionBarSize</span><span style="font-family: Arial, Helvetica, sans-serif;">"</span>
  9. android:id="@+id/toolbar" />
  10. </RelativeLayout>

3. 在代码中设置Toolbar。需要Activity 继承 ActionBarActivity。通过setSupportActionBar()替代ActionBar,在OnCreate() 方法中加入以下代码。

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

完成之后,效果如下:

这个 效果不怎么好,需要对其进行简单的修改,改变一些颜色,修整修整就可以见人了。修改的颜色可以参见下图。

通过上图,不难发现,修改颜色主要从这几个方面开始:

  • 状态栏背景色  colorPrimaryDark 属性
  • 如果还是使用ActionBar,colorPrimary 属性设置背景  如果时Toolbar,布局中background 属性设置背景
  • 导航栏背景色 navigationBarColor 属性 ,需要在 5.0 才可以使用,所以属性只可以在 /res/values-v21/styles.xml  设置
  • 主界面背景色 windowBackground
 
如果要使用这些属性,需要从三个地方开始
a.  主样式中设置基本属性  res/values/styles.xml
  1. <style name="AppTheme.Base" parent="Theme.AppCompat.Light.DarkActionBar">
  2. <item name="windowActionBar">false</item>
  3. <item name="android:windowNoTitle">true</item>
  4. <item name="colorPrimary">#66cc99</item>
  5. <item name="colorPrimaryDark">#66cc99</item>
  6. <item name="android:windowBackground">@color/back</item>
  7. </style>
 
b.   v21中设置导航栏背景
  1. <style name="AppTheme" parent="AppTheme.Base">
  2. <item name="android:navigationBarColor">#66cc99</item>
  3. </style>
c.   布局中设置 Toolbar背景
  1. <android.support.v7.widget.Toolbar
  2. android:layout_width="match_parent"
  3. android:layout_height="wrap_content"
  4. android:id="@+id/toolbar"
  5. android:background="#339999"
  6. android:minHeight="?attr/actionBarSize" />

设置完成后,效果如下:

 

上一篇简单的介绍了如何简单使用Toolbar,这篇主要介绍Toolbar的进一步设置。

既然Toolbar要替代ActionBar,那么Toolbar的功能应该更为强大,在Toolbar上有一些默认的显示效果,先来看下。

通过上图,不难看出,我们其实是可以为Toolbar设置以下属性的:

  • 上级按钮 (upbutton)   setNavigationIcon
  • APP 的图标      setLogo
  • 主标题  setTitle
  • 副标题  setSubtitle
  • 设定菜单各按鈕的动作 setOnMenuItemClickListener

在MainActivity的OnCreate() 方法中加入以下代码:

  1. toolbar.setLogo(R.drawable.ic_launcher);
  2. toolbar.setNavigationIcon(R.drawable.ic_launcher);
  3. toolbar.setTitle(getResources().getString(R.string.app_name));
  4. toolbar.setSubtitle("ToolBar");
  5. toolbar.setOnMenuItemClickListener(this);
  6. toolbar.setTitleTextColor(0xffffffff);
  7. toolbar.setSubtitleTextColor(0xffffffff);

注意:setNavigationIcon(),setOnMenuItemClickListener() 需要放在 setSupportActionBar之后才会生效

Toolbar菜单效果与ActionBar的实现一样,都是OptionsMenu。需要在Menu中添加 item ,然后通过Toolbar显示出来。

res/menu/menu_main.xml

  1. <menu xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:app="http://schemas.android.com/apk/res-auto"
  3. xmlns:tools="http://schemas.android.com/tools"
  4. tools:context=".MainActivity">
  5. <item
  6. android:id="@+id/action_settings"
  7. android:title="@string/action_settings"
  8. android:orderInCategory="100"
  9. android:icon="@drawable/ic_launcher"
  10. app:showAsAction="always" />
  11. <item
  12. android:id="@+id/action_test"
  13. android:title="@string/action_settings"
  14. android:orderInCategory="10"
  15. android:icon="@drawable/ic_launcher"
  16. app:showAsAction="ifRoom" />
  17. </menu>

然后在MainActivity中添加以下代码

  1. @Override
  2. public boolean onCreateOptionsMenu(Menu menu) {
  3. getMenuInflater().inflate(R.menu.menu_main, menu);
  4. return true;
  5. }
  6. @Override
  7. public boolean onMenuItemClick(MenuItem menuItem) {
  8. Toast.makeText(this, menuItem.getTitle(), Toast.LENGTH_SHORT).show();
  9. return false;
  10. }

运行效果如下:

通过点击 菜单,可以发现能够触发 onMenuItemClick() 方法,但是,点击上级按钮 (upbutton)并没有触发该事件,因为它有自己独立的点击事件。

  1. toolbar.setNavigationOnClickListener(new View.OnClickListener() {
  2. @Override
  3. public void onClick(View v) {
  4. Toast.makeText(MainActivity.this, "HOME", Toast.LENGTH_SHORT).show();
  5. }
  6. });

在Android 原生样式应用中,有一个特别漂亮的效果,在使用抽屉布局的时候,展开或关闭抽屉时,Toolbar的 navigation drawer(upButton) 有一个动画,由三个横线旋转成箭头,大概如下:

静态图片展示不出来动画效果,请自行补脑!

这个效果其实是由 Toolbar+DrawerLayout 实现的。

可以通过以下几步实现:

  1. 在布局中加入DrawerLayout
  2. 在代码中找到DrawerLayout,将DrawerLayout 与 Toolbar关联
  3. 通过样式修改 navigation drawer 的颜色
1. 在布局中加入DrawerLayout   res/layout/activity_main.xml
  1. <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. tools:context=".MainActivity">
  6. <android.support.v7.widget.Toolbar
  7. android:layout_width="match_parent"
  8. android:layout_height="?attr/actionBarSize"
  9. android:id="@+id/toolbar"
  10. android:background="#339999" />
  11. <android.support.v4.widget.DrawerLayout
  12. android:layout_below="@+id/toolbar"
  13. android:id="@+id/drawerlayou"
  14. android:layout_width="match_parent"
  15. android:layout_height="match_parent">
  16. <!--Main Content-->
  17. <LinearLayout
  18. android:layout_width="match_parent"
  19. android:layout_height="match_parent"
  20. android:background="#123456">
  21. </LinearLayout>
  22. <!--DrawerLayout Content-->
  23. <LinearLayout
  24. android:layout_width="300dp"
  25. android:layout_height="match_parent"
  26. android:background="#345678"
  27. android:layout_gravity="start" />
  28. </android.support.v4.widget.DrawerLayout>
  29. </RelativeLayout>
 

2. 在MainActivity中找到DrawerLayout,将DrawerLayout 与 Toolbar关联

  1. final DrawerLayout drawerLayout = (DrawerLayout) findViewById(R.id.drawerlayou);
  2. ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawerLayout, R.string.app_name, R.string.app_name);
  3. toggle.syncState();
  4. drawerLayout.setDrawerListener(toggle);
  5. //通过 NavigationDrawer 打开关闭 抽屉
  6. toolbar.setNavigationOnClickListener(new View.OnClickListener() {
  7. @Override
  8. public void onClick(View v) {
  9. Toast.makeText(MainActivity.this, "HOME", Toast.LENGTH_SHORT).show();
  10. if (drawerLayout.isDrawerOpen(Gravity.START))
  11. drawerLayout.closeDrawer(Gravity.START);
  12. else
  13. drawerLayout.openDrawer(Gravity.START);
  14. }
  15. });
 

3. 修改样式 为如下:

  1. <resources>
  2. <style name="AppTheme.Base" parent="Theme.AppCompat.Light.DarkActionBar">
  3. <item name="windowActionBar">false</item>
  4. <item name="android:windowNoTitle">true</item>
  5. <item name="colorPrimary">#66cc99</item>
  6. <item name="colorPrimaryDark">#66cc99</item>
  7. <item name="android:windowBackground">@color/back</item>
  8. <!-- 使用自定义样式-->
  9. <item name="drawerArrowStyle">@style/AppTheme.MyDrawerArrowStyle</item>
  10. </style>
  11. <style name="AppTheme" parent="AppTheme.Base" />
  12. <!--自定义 navigation drarwer 的样式-->
  13. <style name="AppTheme.MyDrawerArrowStyle" parent="Widget.AppCompat.DrawerArrowToggle">
  14. <item name="spinBars">false</item>
  15. <item name="color">#FFFFFF</item>
  16. </style>
  17. </resources>
 
其中:
spinBars  旋转效果      默认值为 true,有旋转效果 ;false则无旋转效果。
color navigation icon 的顏色

如果想要抽屉遮住 Toolbar,只需要改下布局,将Toolbar放入DrawerLayout的主界面即可:

  1. <android.support.v4.widget.DrawerLayout
  2. android:id="@+id/drawerlayou"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent">
  5. <!--Main Content-->
  6. <LinearLayout
  7. android:layout_width="match_parent"
  8. android:layout_height="match_parent"
  9. android:background="#123456">
  10. <!-- android:elevation="5dp" 加上阴影-->
  11. <android.support.v7.widget.Toolbar
  12. android:layout_width="match_parent"
  13. android:layout_height="?attr/actionBarSize"
  14. android:id="@+id/toolbar"
  15. android:elevation="5dp"
  16. android:background="#339999" />
  17. </LinearLayout>
  18. <!--DrawerLayout Content-->
  19. <LinearLayout
  20. android:layout_width="300dp"
  21. android:layout_height="match_parent"
  22. android:background="#345678"
  23. android:layout_gravity="start" />
  24. </android.support.v4.widget.DrawerLayout> 

    Toolbar 相对于 ActionBar的强大之处在于,ToolBar有更强大的自定义效果。因为ToolBar本身就是一个ViewGroup,可以往Toolbar中放入各种组件。

    1. <android.support.v7.widget.Toolbar
    2. android:layout_width="match_parent"
    3. android:layout_height="?attr/actionBarSize"
    4. android:id="@+id/toolbar"
    5. android:elevation="5dp"
    6. android:background="#339999">
    7. <RelativeLayout
    8. android:layout_width="match_parent"
    9. android:layout_height="match_parent"
    10. android:background="#F00">
    11. <Button
    12. android:id="@+id/toolbar_btn"
    13. android:layout_width="wrap_content"
    14. android:layout_height="match_parent"
    15. android:text="Button"/>
    16. <ImageView
    17. android:layout_width="20dp"
    18. android:layout_height="20dp"
    19. android:src="@drawable/ic_launcher"
    20. android:layout_centerInParent="true" />
    21. <TextView
    22. android:layout_alignParentRight="true"
    23. android:layout_centerVertical="true"
    24. android:layout_width="wrap_content"
    25. android:layout_height="wrap_content"
    26. android:text="邓紫棋" />
    27. </RelativeLayout>

    可以根据自己的需求,设置各种效果。但是,左边的边距一直去不了,如果知道的朋友,请给我留言,谢谢!

Androd Toolbar 的简单使用(转)的更多相关文章

  1. Android ToolBar 的简单封装

    使用过 ToolBar 的朋友肯定对其使用方法不陌生,由于其使用方法非常easy.假设对 ActionBar 使用比較熟练的人来说.ToolBar 就更easy了!只是,相信大家在使用的过程中都遇到过 ...

  2. 【Android - V】之Toolbar的使用

    Toolbar是Android V7包中的一个控件,用来代替Action Bar作为界面的头部标题栏布局.Toolbar相对于Action Bar的特点是更加灵活,可以显示在任何位置. 首先先来看To ...

  3. 商城项目实战 | 2.1 Android 仿京东商城——自定义 Toolbar (一)

    前言 本文为菜鸟窝作者刘婷的连载."商城项目实战"系列来聊聊仿"京东淘宝的购物商城"如何实现. 现在很多的 APP 里面都有自己的自定义风格,特别是京东商城中自 ...

  4. [置顶] xamarin android toolbar(踩坑完全入门详解)

    网上关于toolbar的教程有很多,很多新手,在使用toolbar的时候踩坑实在太多了,不好好总结一下,实在浪费.如果你想学习toolbar,你肯定会去去搜索androd toolbar,既然你能看到 ...

  5. 第三十篇-ToolBar的使用

    效果图: 创建标题栏,将原本的Title隐藏,并在菜单栏中设置选项. 一.拖入一个ToolBar组件,并在res/values/styles.xml中将原本的标题栏隐藏,添加<item name ...

  6. 【Android - 控件】之V - Toolbar的使用

    Toolbar是Android V7包中的一个控件,用来代替Action Bar作为界面的头部标题栏布局.Toolbar相对于Action Bar的特点是更加灵活,可以显示在任何位置. 首先先来看To ...

  7. Android 之 ToolBar 踩坑笔记

    写在前面 •前言 这两天,学完了 Fragment 的基础知识,正准备跟着<第一行代码>学习制作一个简易版的新闻应用: 嘀嘀嘀~~~ 一声消息传来,像往常一样,打开 QQ,当我看到 QQ ...

  8. Android中通过ActionBar为标题栏添加搜索以及分享视窗

    在Android3.0之后,Google对UI导航设计上进行了一系列的改革,其中有一个非常好用的新功能就是引入的ActionBar,他用于取代3.0之前的标题栏,并提供更为丰富的导航效果.Action ...

  9. Android开发新手学习总结(六)——android开发目录结构【图文版】

    转载链接:http://bbs.itcast.cn/thread-87059-1-1.html?rss 既然已经搭建好环境了,那就对Android Studio中项目目录结构做个简单的了解了,这里以最 ...

随机推荐

  1. SpringBoot系列四:SpringBoot开发(改变环境属性、读取资源文件、Bean 配置、模版渲染、profile 配置)

    声明:本文来源于MLDN培训视频的课堂笔记,写在这里只是为了方便查阅. 1.概念 SpringBoot 开发深入 2.具体内容 在之前已经基本上了解了整个 SpringBoot 运行机制,但是也需要清 ...

  2. NPOI 2.1.1 系列(2) 使用NPOI读取List或者datatable数据生成 Excel文档 ;Npoi生成 xlsx 2007以上文档

    结合上一篇文章  NPOI 2.1.1 系列(1) 使用NPOI读取 Excel文档 ;NpoiExcelHelper 导入导出 2003格式 2007格式的 Excel; Npoi 导出 xlsx ...

  3. linux stat命令参数及用法详解

    功能说明:显示inode内容.语 法:stat [文件或目录]补充说明:stat以文字的格式来显示inode的内容. ls 命令及其许多参数提供了一些非常有用的文件信息.另一个不太为人所熟知的命令 s ...

  4. Bioperl 解析blast的输出结果

    用bioperl 解析blast的默认输出结果, 整理成-m8格式的输出 #!/usr/bin/perl use Bio::SearchIO; my ($blast) = @ARGV; my $sea ...

  5. linux网络配置练习

    查看网卡是否正常安装 命令:lspci |grep Ether 1.修改网卡配置 命令: vi /etc/sysconfig/network-scripts/ifcfg-eth0 DEVICE=eth ...

  6. PCL(Point Cloud Library)的第三方库简单介绍(boost,eigen,flann,vtk,qhull)

    PCL由于融合了大量的第三方开源库,导致学习成本升高~在学习之前我们最好还是了解一下这些库都是干嘛的,以便有的放矢.在之后更好的使用 boost: C++的标准库的备用版,擅长从数学库到智能指针,从模 ...

  7. linux 内存分页

    内存是计算机的主存储器.内存为进程开辟出进程空间,让进程在其中保存数据.我将从内存的物理特性出发,深入到内存管理的细节,特别是了解虚拟内存和内存分页的概念. 内存 简单地说,内存就是一个数据货架.内存 ...

  8. Thinkphp5笔记一:项目部署

    系统:window 7 64位 Thinkphp版本:5.0.5 环境:wampserver集成 笔记分为两大部分,配置篇与数据库篇 一.虚拟主机部署/本地部署 在网站根目录下建立文件index.ph ...

  9. 如何在IntelliJ IDEA中快速配置Tomcat

    近来使用idea编写java代码的人越来越多,最关键的就是idea强大的代码提示功能,能极高的提升程序员的开发效率,但是毕竟各有所长,idea中tomcat的配置就没有eclipse那么轻松,这里简单 ...

  10. 6. go数组与冒泡排序

    include 数组的概念 如何定义数组 数组常用的用法 数组如何指定下标设值 二维数组 冒泡排序 数组 定义数组的格式:var [n] , n>=0 数组长度也是类型的一部分,因此具有不同的长 ...