Toolbar 替换ActionBar(android MD 二)

Toolbar是Android 5.0推出的一个新的导航控件用于取代之前的ActionBar,由于其高度的可定制性、灵活性、具有Material Design风格等优点被大量采用。

兼容5.0以下版本:

加上依赖

compile 'com.android.support:appcompat-v7:25.+'

借用大佬的一张图

这里写图片描述

通过设置相应的主题属性得到的效果图

<style name="MainTheme" parent="Theme.AppCompat.Light.NoActionBar">
<item name="colorPrimary">@color/colorPrimary</item>
<item name="colorPrimaryDark">@color/colorAccent</item>
<item name="android:textColorPrimary">#ffffff</item>
<itemname="android:windowBackground">@color/colorAccent</item>
<item name="android:navigationBarColor">@color/colorPrimary</item>
</style>

这里写图片描述

注意事项

  1. Toolbar要指定 android:background=”?attr/colorPrimary”
  2. 要去掉之前的ActionBar,例子是用Theme.AppCompat.Light.NoActionBar这个主题去除,也可以用相应的方法;
<style name="Theme.AppCompat.Light.NoActionBar">
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
</style>

布局文件里添加Toolbar

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
    android:orientation="vertical"
    android:layout_height="match_parent" tools:context="com.example.toolbardemo.MainActivity">
    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:background="?attr/colorPrimary"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />

</LinearLayout>

Activity里找到Toolbar

Toolbar mToolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(mToolbar);

设置标题,导航icon等

     mToolbar.setTitle("我是大标题");
        mToolbar.setSubtitle("我是小标题");
        mToolbar.setLogo(R.mipmap.ic_launcher);

        setSupportActionBar(mToolbar);  //注意顺序
        mToolbar.setNavigationIcon(R.mipmap.ic_launcher_round);

这里写图片描述

设置菜单

  • 重写这个方法
 @Override
 public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.toolbar_menu, menu); //加载菜单
        return super.onCreateOptionsMenu(menu);
 }

toolbar_menu.xml

<?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="@mipmap/ic_launcher"
        app:showAsAction="ifRoom"/>
    <item android:id="@+id/action_notifications"
        android:title="notifications"
        android:icon="@mipmap/ic_launcher"
        app:showAsAction="ifRoom"/>
    <item android:id="@+id/action_ications"
        android:title="notiions"
        android:icon="@mipmap/ic_launcher"
        app:showAsAction="ifRoom"/>
    <item android:id="@+id/action_stings"
        android:title="sb"
        android:orderInCategory="100"
        android:icon="@mipmap/ic_launcher"
        app:showAsAction="never"/>
</menu>

设置菜单Item点击事件


@Override
public boolean onOptionsItemSelected(MenuItem item) {
        if (item.getItemId() == android.R.id.home) {
            Toast.makeText(this, "你点击了导航图标", Toast.LENGTH_SHORT).show();
        } else {
            Toast.makeText(MainActivity.this, "你点击了标题为 :" + item.getTitle() + " 的菜单", Toast.LENGTH_SHORT).show();
        }
        return super.onOptionsItemSelected(item);
}

改变系统默认的三个点的图片

        mToolbar.setOverflowIcon(getDrawable(R.mipmap.ic_launcher));  //替换三个点的图片

这里写图片描述

指定弹出菜单的主题

app:popupTheme="@style/Toolbar.Popup.Theme"

 <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:background="?attr/colorPrimary"
        app:popupTheme="@style/Toolbar.Popup.Theme"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />
@style/Toolbar.Popup.Theme

<style name="Toolbar.Popup.Theme" parent="@style/ThemeOverlay.AppCompat.Dark">
<item name="android:colorBackground">@color/colorPrimary</item>
<item name="android:textColorPrimary">#000000</item>
<item name="actionOverflowMenuStyle">@style/Toolbar.Popup.Position.Theme</item>
</style>

<style name="Toolbar.Popup.Position.Theme" parent="Widget.AppCompat.Light.PopupMenu.Overflow">
<item name="overlapAnchor">false</item>  <!--把该属性改为false即可使menu位置位于toolbar之下-->
</style>
  • android:textColorPrimary 指定弹出菜单的字体颜色
  • android:colorBackground指定弹出菜单的背景颜色
  • actionOverflowMenuStyle 设置弹出菜单的位置主题

暂时整理了这么多,后续会再更新!源码下载地址

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Android Studio中的ActionBar是一个应用程序栏,它提供了一些常用的操作,例如导航、搜索、设置等。它可以帮助用户更方便地使用应用程序,并提高用户体验。在Android Studio中,我们可以使用一些库来实现ActionBar,例如AppCompat库和Toolbar库。同时,我们也可以自定义ActionBar,以满足特定的需求。 ### 回答2: Android Studio是一个专门为Android系统开发者打造的集成开发环境。Action Bar是指Android应用程序顶部的工具栏,可以方便用户进行操作,包括菜单、工具等。它可以减少用户操作界面上的摆放,使其更加简洁。使用Android Studio进行开发过程中,可以通过设置和调用一些属性来配置Action Bar。 首先,在Android Studio中创建一个新的Activity,在XML布局文件中添加一个Toolbar组件,Toolbar组件可以被用作Action Bar。其次,在Java类中通过调用setSupportActionBar方法来显示ToolbarToolbar即可作为Action Bar在热身活动中使用。同时也可以设置菜单项和监听器。 在开发过程中,我们也可以调用Action Bar中的API。例如,setHomeButtonEnabled()方法可以控制左侧的Home图标是否可用,setDisplayHomeAsUpEnabled()方法可以控制左侧的返回键是否可见,setNavigationMode()方法可以控制Action Bar的显示模式,show()和hide()方法可以控制Action Bar的显示和隐藏。除此之外,通过改变Toolbar的主题,在Action Bar上增加背景图像,改变字体颜色、大小等属性,使得Action Bar更加美观。 总之,通过Android Studio来配置Action Bar可以使得应用程序更加方便操作、界面更加美观。它也是Android应用程序编程中的一个重要特性。 ### 回答3: Android Studio ActionBar是一种Android应用程序的界面元素,通常在顶部显示,用于显示应用程序的重要内容和操作。 Android Studio ActionBar 具有以下优点: 1. 提供可靠的用户体验:作为应用程序最常见的方式之一,Android Studio ActionBar 可以引导用户在应用程序中进行操作,提高应用程序的易用性和功能性。 2. 拥有自定义配置能力:开发人员可以轻松配置和自定义ActionBar,以使其符合应用程序的需求和主题。 3. 提供多种风格:Android Studio ActionBar 提供了许多样式和外观,以满足广泛的应用和用户需求。 4. 支持各种操作: Android Studio ActionBar 支持多种操作,例如搜索,导航,菜单,通知等,可以增强用户体验和应用程序功能。 5. 方便快捷:作为一个方便的快捷操作区域, Android Studio ActionBar 为用户提供了许多快速访问应用程序功能的方法。 总之,Android Studio ActionBar 是开发高效的应用程序以及提高应用程序用户体验的重要元素。它提供了各种优点,以满足开发人员和用户的不同需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值