参考:

  https://developer.android.com/training/appbar/index.html

1,自定义toolbar主题

2,在布局xml中使用toolbar

3,在代码中启用toolbar

4,添加菜单

5,处理菜单事件

6,向上导航事件

7,定义actionView

8,actionView的菜单展开/收起 事件

9,定义actionProvider

1,AppCompatActivity与常见的activity不同,要用 Theme.AppCompat.xxx系列中的一个不带actionbar的主题 。并可以自定义它。

 <resources>

     <!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar"> <!--设置每个菜单项及它选中时的背景色-->
<item name="android:itemBackground">#a4f5f6</item>
<!--<item name="android:background">#303F9F</item>--> <!--下面3行是ToolBar的状态栏沉浸效果-->
<!--<item name="android:windowTranslucentStatus">false</item>-->
<!--<item name="android:windowTranslucentNavigation">true</item>-->
<!--<item name="android:statusBarColor">#0176da</item>--> <!-- Toolbar风格 -->
<item name="toolbarStyle">@style/Theme.Toolbar.App.Style</item> <!--溢出菜单中的action间的分割线-->
<item name="android:dividerHeight">1dp</item>
<!--文本大小-->
<item name="android:textSize">20sp</item>
<!--文本颜色-->
<item name="android:textColorPrimary">#ffffff</item>
<!--设置菜单不遮挡actionbar-->
<item name="actionOverflowMenuStyle">@style/OverflowMenuStyle</item>
<!--配置Menu的图标-->
<item name="actionOverflowButtonStyle">@style/ToolBar.ActionButton.Overflow</item>
</style> <!--溢出菜单样式 -->
<style name="OverflowMenuStyle" parent="Widget.AppCompat.Light.PopupMenu.Overflow">
<!--溢出菜单的宽度-->
<item name="android:dropDownWidth">wrap_content</item>
<item name="android:paddingRight">5dp</item> <!--溢出菜单窗口的背景,它与菜单项的背景不同,如果所有菜单项加一起盖住了窗口,那么这个背景色看不到-->
<item name="android:popupBackground">#89a81d</item> <!--溢出菜单不遮挡ToolBar-->
<item name="overlapAnchor">false</item> <!--溢出菜单垂直偏移,水平偏移-->
<item name="android:dropDownVerticalOffset">5dip</item>
<item name="android:dropDownHorizontalOffset">0dip</item>
</style> <!--溢出按钮样式 -->
<style name="ToolBar.ActionButton.Overflow" parent="android:style/Widget.Holo.Light.ActionButton.Overflow">
<item name="android:src">@android:drawable/ic_menu_add</item>
</style> <!--=============下面是toolbar相关主题============-->
<!-- Toolbar样式 -->
<style name="Theme.Toolbar.App.Style" parent="@style/Widget.AppCompat.Toolbar">
<item name="android:background">#33B5E5</item>
<!--注意不要用android:titleTextAppearance,要用xmlns:app="http://schemas.android.com/apk/res-auto"下的,
不带前缀就是app:下的-->
<!--主标题-->
<item name="title">title</item>
<!--副标题-->
<item name="subtitle">subtitle</item> <!--logo-->
<item name="logo">@android:drawable/ic_menu_call</item>
<!--主标题样式-->
<item name="titleTextAppearance">@style/Theme.ToolBar.App.Title</item>
<!--副标题样式-->
<item name="subtitleTextAppearance">@style/Theme.ToolBar.App.Subtitle</item> <item name="android:minHeight">?attr/actionBarSize</item>
<item name="titleMargins">4dp</item>
<!--ToolBar的Home图标左侧间隙-->
<item name="contentInsetStart">16dp</item> <!--当home图标折叠时显示的图标-->
<item name="collapseIcon">@android:drawable/ic_menu_compass</item>
<item name="collapseContentDescription">collapseContentDescription</item>
<item name="android:paddingLeft">10dp</item>
<item name="android:paddingRight">10dp</item> </style> <!--设置toolbar标题主题-->
<style name="Theme.ToolBar.App.Title" parent="@style/TextAppearance.Widget.AppCompat.Toolbar.Title">
<item name="android:textSize">20sp</item>
<item name="android:textColor">#ffffff</item>
</style> <!--toolbar副标题主题-->
<style name="Theme.ToolBar.App.Subtitle" parent="@style/TextAppearance.Widget.AppCompat.Toolbar.Subtitle">
<item name="android:textSize">9sp</item>
<item name="android:textColor">#ff0000</item>
</style>
</resources>

2,在layout.xml中添加toolbar

 <?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
tools:context="com.txw.e.toolbardemo.MainActivity"> <android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
/> <!--app:contentInsetStart="3dp"-->
<!--app:title="Title"-->
<!--app:subtitle="subtitle"-->
<!--app:logo="@android:drawable/ic_menu_directions"-->
<!--app:titleTextAppearance="@style/Theme.ToolBar.Base.Title"-->
<!--app:subtitleTextAppearance="@style/Theme.ToolBar.Base.Subtitle"--> <!--app:title等属性也可以定义在style.xml中,注意是app命名空间下的,不是android:title,后者不显示。
xmlns:app="http://schemas.android.com/apk/res-auto"
--> <TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/toolbar"
android:text="Hello toolbar!" /> </RelativeLayout>

3,在layout对应的activity或fragment的onCreate中:

下面是activity示例

 @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my);
Toolbar myToolbar = (Toolbar) findViewById(R.id.my_toolbar);
setSupportActionBar(myToolbar);
}

下面是fragment示例

 public class MainView extends Fragment {

     public Toolbar                 actionBar;
public void initActionBar(View rootView){
//用toolbar实现 actionbar
actionBar = (Toolbar) rootView.findViewById(R.id.toolbar);
Drawable overflow = actionBar.getResources().getDrawable(R.drawable.ab_overflow_btn); actionBar.setTitleTextColor(Color.WHITE);
actionBar.setOverflowIcon(overflow); AppCompatActivity aca = (AppCompatActivity) getActivity();
aca.setSupportActionBar(actionBar); }
//...
}

4,添加action item,注意其中的  app:showAsAction 不是android:showAsAction 其它与actionbar类似。

 <menu xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
tools:context="com.e.weixin.MainActivity"> <item
android:id="@+id/action_search"
android:icon="@android:drawable/ic_menu_search"
android:title="search"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="always|collapseActionView"/> <item android:id="@+id/action_share"
android:icon="@android:drawable/ic_menu_share"
android:title="share"
app:showAsAction="ifRoom"
app:actionProviderClass="android.support.v7.widget.ShareActionProvider"/>
<item
android:id="@+id/action_expand"
android:icon="@android:drawable/ic_menu_add"
android:title="展开/收起"
app:showAsAction="never|collapseActionView"/>
<item
android:id="@+id/action_home_as_up"
android:icon="@android:drawable/ic_menu_upload"
android:title="向上导航"
app:showAsAction="never"/>
<item
android:id="@+id/action_scan"
android:icon="@android:drawable/ic_menu_send"
android:title="scan"
app:showAsAction="never"/>
<item
android:id="@+id/action_get_money"
android:icon="@android:drawable/ic_menu_crop"
android:title="sq"
app:showAsAction="never"/>
<item
android:id="@+id/action_help_and_feedback"
android:icon="@android:drawable/ic_menu_help"
android:title="help"
app:showAsAction="never"/> </menu> 

5,处理事件与actionbar相似。

 @Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.action_settings:
// User chose the "Settings" item, show the app settings UI...
return true; case R.id.action_favorite:
// User chose the "Favorite" action, mark the current item
// as a favorite...
return true; default:
// If we got here, the user's action was not recognized.
// Invoke the superclass to handle it.
return super.onOptionsItemSelected(item); }

6,处理向上导航事件,先设置activity上下级,然后得到ActionBar,然后用它处理向上导航事件。

 <application ... >
... <!-- The main/home activity (it has no parent activity) --> <activity
android:name="com.example.myfirstapp.MainActivity" ...>
...
</activity> <!-- A child of the main activity -->
<activity
android:name="com.example.myfirstapp.MyChildActivity"
android:label="@string/title_activity_child"
android:parentActivityName="com.example.myfirstapp.MainActivity" > <!-- Parent activity meta-data to support 4.0 and lower -->
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="com.example.myfirstapp.MainActivity" />
</activity>
</application>

处理代码

 @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my_child); // my_child_toolbar is defined in the layout file
Toolbar myChildToolbar =
(Toolbar) findViewById(R.id.my_child_toolbar);
setSupportActionBar(myChildToolbar); // Get a support ActionBar corresponding to this toolbar
ActionBar ab = getSupportActionBar(); // Enable the Up button
ab.setDisplayHomeAsUpEnabled(true);
}

7,自定义 action view

在menu.xml对应有action项中

 <item
android:id="@+id/action_search"
android:icon="@android:drawable/ic_menu_search"
android:title="search"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="always|collapseActionView"/>

在代码中

 @Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.main_activity_actions, menu); MenuItem searchItem = menu.findItem(R.id.action_search);
SearchView searchView =
(SearchView) MenuItemCompat.getActionView(searchItem); // Configure the search info and add any event listeners... return super.onCreateOptionsMenu(menu);
}

8,响应action view 展开/收起 事件。要指定collapseActionView和app:actionViewClass。

 <item
android:id="@+id/action_expand"
android:icon="@android:drawable/ic_menu_add"
android:title="展开/收起"
app:actionViewClass="android.support.v7.widget.SearchView"
app:showAsAction="always|collapseActionView"/>

  指定了 collapseActionView 属性后,才可响应actionView的展开/收起事件。在按对应的item之前(action view展开之前),一直显示在android:icon="xxx" 中指定的图标。

  如果在activity中重写了onOptionsItemSelected() ,注意要调用 super.onOptionsItemSelected() 才能展开action view事件。

 @Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.options, menu);
// ... // Define the listener
OnActionExpandListener expandListener = new OnActionExpandListener() {
@Override
public boolean onMenuItemActionCollapse(MenuItem item) {
// Do something when action item collapses
return true; // Return true to collapse action view
} @Override
public boolean onMenuItemActionExpand(MenuItem item) {
// Do something when expanded
return true; // Return true to expand action view
}
}; // Get the MenuItem for the action item
MenuItem actionMenuItem = menu.findItem(R.id.myActionItem); // Assign the listener to that action item
MenuItemCompat.setOnActionExpandListener(actionMenuItem, expandListener); // Any other things you have to do when creating the options menu… return true;
}

9,添加及自定义action provider

 <item android:id="@+id/action_share"
android:icon="@android:drawable/ic_menu_share"
android:title="share"
app:showAsAction="ifRoom"
app:actionProviderClass="android.support.v7.widget.ShareActionProvider"/>

  For information about creating a custom action provider, see the ActionProvider reference. For information about configuring a ShareActionProvider, see the reference for that class.

ToolBar教程:AppCompatActivity下用toolbar当actionbar用的更多相关文章

  1. 自定义toolbar教程

    1.写toolbar的布局文件 ,toolbar.xml <?xml version="1.0" encoding="utf-8"?> <Re ...

  2. winsock教程- windows下的socket编程(c语言实现)

    winsock教程- windows下的socket编程(c语言实现) 使用winsock进行socket 编程     这是一个学习windows下socket编程(c语言)的快速指南.这是因为一下 ...

  3. 【秒懂】号称最为简明实用的Django上手教程(下)

    号称最为简明实用的Django上手教程(下) 作者:白宁超 2017年8月25日08:51:58 摘要:上文号称[最为简明实用的Django上手教程]介绍了django基本概念.配置和相关操作.相信通 ...

  4. 使用Keil语言的嵌入式C编程教程(下)

    使用Keil语言的嵌入式C编程教程(下) 用8051单片机进行定时器/计数器的计算与编程 延迟是应用软件开发中的重要因素之一.然而,在实现定时延迟的过程中,正常的延迟并不能给出克服这一问题的宝贵结果. ...

  5. DevExpress中barManager下的toolbar如何在panel中显示

    如题,我的Dev Toolbar需要在一个pannel中显示,并且居于最顶部.可是好像默认情况下toolbar都是在窗体的最顶部的,如何设置才能使其位于一个panel的最顶部呢? 解决方案:经过测试, ...

  6. [个人翻译]Redis 集群教程(下)

    [个人翻译]Redis 集群教程(上) [个人翻译]Redis 集群教程(中) 官方原文地址:https://redis.io/topics/cluster-tutorial 水平有限,如果您在阅读过 ...

  7. 微信小程序教学第三章第四节(含视频):小程序中级实战教程:下拉更新、分享、阅读标识

    下拉更新.分享.阅读标识 本文配套视频地址: https://v.qq.com/x/page/h0554i4u5ob.html 开始前请把 ch3-4 分支中的 code/ 目录导入微信开发工具 这一 ...

  8. 低版本系统兼容的ActionBar(三)自定义Item视图+进度条的实现+下拉导航+透明ActionBar

           一.自定义MenuItem的视图 custom_view.xml (就是一个单选按钮) <?xml version="1.0" encoding="u ...

  9. Unity入门教程(下)

    一.概要 在 Unity入门教程(上) 中我们创建了一个游戏项目,并且创建了玩家角色和小球这些游戏对象,还通过添加游戏脚本实现了小方块的弹跳.虽然功能比较简单,但是完整地表现了使用Unity开发游戏的 ...

随机推荐

  1. Linux下汇编语言学习笔记56 ---

    这是17年暑假学习Linux汇编语言的笔记记录,参考书目为清华大学出版社 Jeff Duntemann著 梁晓辉译<汇编语言基于Linux环境>的书,喜欢看原版书的同学可以看<Ass ...

  2. Python基础之 一

    语言分类:编译型(运行前先编译)和解释型(直接运行),静态语言(需要声明变量类型)和动态语言(不需要声明),强类型定义语言(定义好类型不做强制转换就不可修改类型)和弱类型定义语言(数据类型可以被忽略) ...

  3. python类变量以及应用场景

    类变量是python 中class 的变量,区别于实例的变量.我们通过一些例子具体了解一下 先看下面的例子 >>> class Demo(object): ... v1 = 1 .. ...

  4. 数据库可视化操纵软件有navicat和sqlyog

    数据库可视化操纵软件有navicat和sqlyog 数据库可视化操纵软件有navicat和sqlyog

  5. [52ABP系列] - 001、SPA免费项目模版搭建教程

    前言 这个项目是基于 ABP ASPNetCore 免费版,整合 NG-Alian 和 NG-Zorro 的项目,所以比较适合熟悉 ABP 和 Angular2+ 的开发人员, 如果你是新手,学习的话 ...

  6. Spark修炼之道(基础篇)——Linux大数据开发基础:第二节:Linux文件系统、文件夹(一)

    本节主要内容 怎样获取帮助文档 Linux文件系统简单介绍 文件夹操作 訪问权限 1. 怎样获取帮助文档 在实际工作过程其中,常常会忘记命令的使用方式.比如ls命令后面能够跟哪些參数,此时能够使用ma ...

  7. 使用Swift模拟Window-LFU

    今天參加了某公司2015的校招的机试,大题开放题比較多.有一道大题是Window-LFU比較有意思,当时题目搞了半天没搞明确让干啥- -题目大概是这种:实现一个Window-LFU缓存(事实上就是用数 ...

  8. xib或者storyboard设置颜色偏问题(与代码设置颜色不一致)

    选中xib中的label,在右边栏的第三个标签页中第三项是User Defined Runtime Attributes 添加一个keyPath,keyPath值为layer.borderWidth, ...

  9. 仅仅需一步教你解决Win10下Android Studio terminal无法使用的问题

    Android Studio集成和加入了一些有用的工具.当中一个便是terminal. 在Windows平台下Android Studio中的terminal在原理上实际使用的是window中的cmd ...

  10. @Override用在哪儿

            帮朋友改一段代码,看到好多红叉都是指向@Override.         是这样,他代码里写了一个接口.方法都用抽象函数声明在接口类里.然后在继承自这个接口的实现类里写详细方法的空壳 ...