深入理解Android 5.0中的Toolbar

发布时间 - 2026-01-10 22:47:57    点击率:

环境说明:

  • Android Studio 2.0
  • V7包版本:com.android.support:appcompat-v7:23.4.0
  • compileSdkVersion 23
  • buildToolsVersion "24.0.0"

Toolbar 引入使用

XML布局中加入:

<android.support.v7.widget.Toolbar
 android:id="@+id/toolbar"
 android:layout_width="match_parent"
 android:layout_height="?attr/actionBarSize"/>

主题改为隐藏ActionBar:

Theme.AppCompat.Light.NoActionBar

Activity代码中加入:

 setContentView(R.layout.activity_main);
 Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
 setSupportActionBar(toolbar);

此时运行效果:

添加背景色

android:background="@color/colorPrimary"

此时运行效果:

基本属性设置

<android.support.v7.widget.Toolbar
 android:id="@+id/toolbar"
 android:layout_width="match_parent"
 android:layout_height="?attr/actionBarSize"
 android:background="@color/colorPrimary"
 app:navigationIcon="@mipmap/title_bar_back"//左侧图标
 app:subtitle="子标题"
 app:subtitleTextColor="#fff" //标题颜色
 app:title="标题"
 app:titleTextColor="#fff"/> //子标题颜色

运行效果:

添加选项菜单

第一步创建菜单文件

 <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=".MainActivity">
 <item
 android:id="@+id/action_settings"
 android:icon="@mipmap/ic_launcher"
 android:orderInCategory="100"
 android:title="settings"
 app:showAsAction="never"/>
 <item
 android:id="@+id/action_share"
 android:icon="@mipmap/ic_action_share"
 android:orderInCategory="100"
 android:title="settings"
 app:showAsAction="ifRoom"/>
 <item
 android:id="@+id/action_search"
 android:icon="@mipmap/ic_action_search"
 android:orderInCategory="100"
 android:title="settings"
 app:showAsAction="ifRoom"/>
 </menu>

第二部在代码中重写onCreateOptionsMenu方法加载菜单文件

@Override
public boolean onCreateOptionsMenu(Menu menu) {
 getMenuInflater().inflate(R.menu.menu_main, menu);
 return true;
}

此时效果:

个性设置

左侧返回箭头

想要显示自带的返回箭头,需要去掉之前设定的属性:

app:navigationIcon="@mipmap/title_bar_back"

然后在代码中添加:

getSupportActionBar().setHomeButtonEnabled(true); //设置返回键可用
getSupportActionBar().setDisplayHomeAsUpEnabled(true);

此时效果:

溢出图标颜色

在style文件中添加:

 <!-- 溢出菜单图标颜色-->
<item name="colorControlNormal">@android:color/white</item>

此时效果:

自定义右侧溢出图标

在Style文件中添加:

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
 <!-- Customize your theme here. -->
 <item name="colorPrimary">@color/colorPrimary</item>
 <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
 <item name="colorAccent">@color/colorAccent</item>
 <!-- 溢出菜单图标颜色-->
 <item name="colorControlNormal">@android:color/white</item>
 <!-- 溢出菜单图标自定义-->
 <item name="android:actionOverflowButtonStyle">@style/OverflowButtonStyle</item>
 </style>

 <style name="OverflowButtonStyle" parent="android:Widget.ActionButton.Overflow">
 <item name="android:src">@mipmap/ic_action_add</item>
 </style>

此时运行效果:

更改弹出菜单背景

在Style文件中添加样式:



在布局文件中添加使用主题:

app:popupTheme="@style/ToolbarPopupTheme"

此时运行效果:

更改弹出菜单文字颜色

添加样式文件:

<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
  <!-- Customize your theme here. -->
  <item name="colorPrimary">@color/colorPrimary</item>
  <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
  <item name="colorAccent">@color/colorAccent</item>
  <!-- 溢出菜单图标颜色-->
  <item name="colorControlNormal">@android:color/white</item>
  <item name="android:actionOverflowButtonStyle">@style/OverflowButtonStyle</item>
  <!-- 溢出菜单文字颜色-->
  <item name="textAppearanceLargePopupMenu">@style/Overflow_Menu_Text_style</item>
 </style>
 <!--溢出菜单文字颜色-->
 <style name="Overflow_Menu_Text_style" parent="@style/TextAppearance.AppCompat.Widget.PopupMenu.Large">
  <item name="android:textColor">#fff</item>
 </style>

此时运行效果:

修改标题文字大小

添加配置:

 app:titleTextAppearance="@style/ToolbarTitleSize"

添加style:

 <!-- toolbar标题文字大小 -->
 <style name="ToolbarTitleSize" parent="@style/TextAppearance.Widget.AppCompat.Toolbar.Title">
  <item name="android:textSize">28sp</item>
 </style>

此时运行效果:

子标题文字大小类似,添加配置然后定义style文件(此处省略):

app:subtitleTextAppearance="@style/ToolbarTitleSize"

修改弹出菜单位置

修改配置使弹出菜单显示在Toolbar下方:

首先重新设置属性:(在界面布局文件Toolbar中)

app:popupTheme="@style/OverflowMenuStyle"

在Style文件中添加:

<style name="OverflowMenuStyle">
  <!-- 是否覆盖锚点,默认为true,即盖住Toolbar -->
  <item name="overlapAnchor">false</item>
  <item name="android:dropDownWidth">wrap_content</item>
  <item name="android:paddingRight">5dp</item>
  <!-- 弹出层背景颜色 -->
  <item name="android:colorBackground">#FFCC99</item>
  <!-- 弹出层垂直方向上的偏移,即在竖直方向上距离Toolbar的距离,值为负则会盖住Toolbar -->
  <item name="android:dropDownVerticalOffset">5dp</item>
  <!-- 弹出层水平方向上的偏移,即距离屏幕左边的距离,负值会导致右边出现空隙 -->
  <item name="android:dropDownHorizontalOffset">0dp</item>
  <!-- 设置弹出菜单文字颜色 -->
  <item name="android:textColor">#0099CC</item>
 </style>

此时运行效果:

事件处理

返回按钮事件

添加监听

toolbar.setNavigationOnClickListener(new View.OnClickListener() {
   @Override
   public void onClick(View v) {
    Toast.makeText(getApplicationContext(), "点击了返回箭头", Toast.LENGTH_LONG).show();
   }
  });

菜单项点击事件

重写方法

 @Override
 public boolean onOptionsItemSelected(MenuItem item) {
  switch (item.getItemId()) {
   case R.id.action_settings:
    break;
   case R.id.action_search:
    break;
   case R.id.action_share:
    break;
  }
  return true;
 }

自定义Toolbar

Toolbar下面可以嵌套布局,直接将自己定义好的布局放到Toolbar下面即可

<android.support.v7.widget.Toolbar
  android:layout_width="match_parent"
  android:layout_height="?attr/actionBarSize">

  <RelativeLayout
   android:layout_width="match_parent"
   android:layout_height="match_parent">
   ......
   </RelativeLayout>
 </android.support.v7.widget.Toolbar>

Toolbar 和 DrawerLayout 左滑菜单

 <?xml version="1.0" encoding="utf-8"?>
 <android.support.v4.widget.DrawerLayout 
 xmlns:android="http://schemas.android.com/apk/res/android"
 android:id="@+id/drawer_left"
 android:layout_width="match_parent"
 android:layout_height="match_parent">
 <!--侧滑菜单-->
 <LinearLayout
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:layout_gravity="start"
  android:background="#CCCCFF"
  android:orientation="vertical">

  <TextView
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:padding="10dp"
   android:text="选项一"
   android:textSize="18sp"/>

  <TextView
   android:layout_width="match_parent"
   android:layout_height="wrap_content"
   android:padding="10dp"
   android:text="选项二"
   android:textSize="18sp"/>
 </LinearLayout>
</android.support.v4.widget.DrawerLayout>

添加左滑布局文件:

在主布局文件中引入:(在Toolbar下方)

<!--DrawerLayout-->
<include layout="@layout/custom_drawerlayout"/>

在代码中添加关联:

DrawerLayout mDrawerLayout = (DrawerLayout) findViewById(R.id.drawer_left);
 ActionBarDrawerToggle mDrawerToggle = new ActionBarDrawerToggle(this, mDrawerLayout, toolbar, R.string.open, R.string.close);
 mDrawerToggle.syncState();
 mDrawerLayout.setDrawerListener(mDrawerToggle);

此时运行效果:

新版本studio,在新建Activity的时候可以选择对应的模板,会自动创建好DrawerLayout并关联Toolbar.

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。


# android  # 5.0  # toolbar  # android中toolbar  # Android ToolBar控件详解及实例  # Android Support Library 标题栏(Toolbar)滚动效果实现方法  # Android动态修改ToolBar的Menu菜单示例  # Android折叠式Toolbar使用完全解析(CollapsingToolbarLayout)  # Android ToolBar整合实例使用方法详解  # Android中Toolbar随着ScrollView滑动透明度渐变效果实现  # Android自定义Toolbar使用方法详解  # Android自定义ActionProvider ToolBar实现Menu小红点  # Android5.0+ CollapsingToolbarLayout使用详解  # ToolBar使用方法详解  # 弹出  # 自定义  # 重写  # 这篇文章  # 第二部  # 可以选择  # 自带  # 则会  # 新版本  # 即在  # 值为  # 背景色  # 默认为  # 菜单项  # 加载  # 有疑问  # fff  # title  # subtitleTextColor  # public 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  Laravel Fortify是什么,和Jetstream有什么关系  什么是JavaScript解构赋值_解构赋值有哪些实用技巧  免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?  什么是javascript作用域_全局和局部作用域有什么区别?  用v-html解决Vue.js渲染中html标签不被解析的问题  如何在香港免费服务器上快速搭建网站?  JavaScript如何实现倒计时_时间函数如何精确控制  Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知  如何快速搭建高效WAP手机网站?  奇安信“盘古石”团队突破 iOS 26.1 提权  昵图网官方站入口 昵图网素材图库官网入口  ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集  java中使用zxing批量生成二维码立牌  Laravel Blade模板引擎语法_Laravel Blade布局继承用法  Laravel如何实现数据导出到PDF_Laravel使用snappy生成网页快照PDF【方案】  Laravel如何自定义分页视图?(Pagination示例)  js实现点击每个li节点,都弹出其文本值及修改  Laravel怎么解决跨域问题_Laravel配置CORS跨域访问  如何用PHP快速搭建CMS系统?  edge浏览器无法安装扩展 edge浏览器插件安装失败【解决方法】  晋江文学城电脑版官网 晋江文学城网页版直接进入  网站建设保证美观性,需要考虑的几点问题!  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  Midjourney怎么调整光影效果_Midjourney光影调整方法【指南】  油猴 教程,油猴搜脚本为什么会网页无法显示?  实例解析angularjs的filter过滤器  WEB开发之注册页面验证码倒计时代码的实现  北京网站制作公司哪家好一点,北京租房网站有哪些?  Python自动化办公教程_ExcelWordPDF批量处理案例  Laravel怎么上传文件_Laravel图片上传及存储配置  如何快速重置建站主机并恢复默认配置?  C++时间戳转换成日期时间的步骤和示例代码  如何为不同团队 ID 动态生成多个独立按钮  网页设计与网站制作内容,怎样注册网站?  nodejs redis 发布订阅机制封装实现方法及实例代码  西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?  Laravel如何使用Scope本地作用域_Laravel模型常用查询逻辑封装技巧【手册】  Win11怎么关闭透明效果_Windows11辅助功能视觉效果设置  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  JS弹性运动实现方法分析  如何快速上传自定义模板至建站之星?  高性能网站服务器部署指南:稳定运行与安全配置优化方案  制作旅游网站html,怎样注册旅游网站?  Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能  Laravel如何生成API文档?(Swagger/OpenAPI教程)  IOS倒计时设置UIButton标题title的抖动问题  Laravel如何与Vue.js集成_Laravel + Vue前后端分离项目搭建指南  html5如何实现懒加载图片_ intersectionobserver api用法【教程】