AppCompat样式背景传播到ToolBar中的Image

时间:2014-10-21 15:11:45

标签: android android-appcompat android-toolbar

上下文

我正在使用最新的AppCompat v7 lib(21.0.0),我已将我的应用程序从ActionBar迁移到ToolBar

问题

  1. 工具栏中的图像会自动获得与工具栏相同的背景
  2. 目前SearchBox是在操作栏上设置的自定义视图(来自之前的实现)我打算将if切换到SearchView并相应地设置它,但我仍然对我现在面临的问题非常感兴趣。 / p>

    Img background

    1. 长按工具栏中的菜单项时,会出现提示文本的吐司,并且文本与工具栏的背景相同。
    2. Toast background

      我该如何避免这种情况?

      这是我的工具栏布局和风格&主题

      layout v_toolbar.xml

      <?xml version="1.0" encoding="utf-8"?>
      <android.support.v7.widget.Toolbar
          xmlns:android="http://schemas.android.com/apk/res/android"
          xmlns:app="http://schemas.android.com/apk/res-auto"
          android:id="@+id/my_awesome_toolbar"
          android:layout_width="match_parent"
          android:layout_height="wrap_content"
          app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
          app:theme="@style/MyActionBarStyle"/>
      

      值/ styles.xml

      <style name="MyActionBarStyle" parent="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
          <item name="android:background">@color/green</item>
          <item name="android:windowActionBarOverlay">true</item>
      
          <!-- Support library compatibility -->
          <item name="background">@color/green</item>
          <item name="windowActionBarOverlay">true</item>
      </style>
      

      主题

      <style name="MyTheme" parent="AppBaseTheme">
          <!-- Here we setting appcompat’s actionBarStyle -->
          <!-- <item name="actionBarStyle">@style/MyActionBarStyle</item> -->
      
          <item name="windowActionBar">false</item>
          <!-- ...and here we setting appcompat’s color theming attrs -->
          <item name="colorPrimary">@color/green</item>
          <item name="colorPrimaryDark">@color/green_dark</item>
      </style>
      

      问题1的解决方法1

      第一个问题的解决方法是在ImageView上设置透明背景

      android:background="@color/transparent"
      

      这不能解决问题。

      解决这两个问题

      我为ToolBar设置背景

      <?xml version="1.0" encoding="utf-8"?>
      <android.support.v7.widget.Toolbar
          xmlns:android="http://schemas.android.com/apk/res/android"
          xmlns:app="http://schemas.android.com/apk/res-auto"
          android:id="@+id/my_awesome_toolbar"
          android:layout_width="match_parent"
          android:layout_height="wrap_content"
          android:background="@color/green"
          app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
          app:theme="@style/MyActionBarStyle"/>
      

      我不再为主题设置背景了。

      <style name="MyActionBarStyle" parent="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
          <item name="android:windowActionBarOverlay">true</item>
          <!-- Support library compatibility -->
          <item name="windowActionBarOverlay">true</item>
      </style>
      

      正如Chris Banes指出的那样,可以为工具栏创建一个样式,而不是声明android:background。

      这解决了我的问题,但后来我似乎还有另一个问题,即popupTheme未应用,而我的ShareActionMenuItem下拉列表没有带黑色文本的白色背景。 请在此处查看另一个问题:AppCompat ToolBar popupTheme not used in the ShareAction MenuItem

      也许这是appcompat库中的一个错误。

2 个答案:

答案 0 :(得分:46)

您不应该像这样使用theme

  • style =工具栏的本地
  • 主题=全局到工具栏中充斥的所有内容

解决方法2,正如您所说的那样,是一种正确的方法。如果要将某些值提取到样式中,可以这样做:

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

风格:

<style name="MyDarkToolbarStyle" parent="Widget.AppCompat.Toolbar">
    <item name="android:background">@color/green</item>
    <item name="popupTheme">@style/ThemeOverlay.AppCompat.Light</item>
    <item name="theme">@style/ThemeOverlay.AppCompat.Dark.ActionBar</item>
</style>

答案 1 :(得分:5)

绝不使用主题进行编辑。因为主题定义了整体应用行为。你可以使用两种方法

方式:1

U可以直接在appbar.xml中指定参数,如下所示

appbar.xml中的

  <?xml version="1.0" encoding="utf-8"?>
    <android.support.v7.widget.Toolbar
        android:id="@+id/my_awesome_toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="@color/green"
        app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        app:popupTheme=">style/ThemeOverlay.AppCompat.Light"/>

方式:2

您可以使用Chris_Banes在上面的帖子

中建议的样式 appbar.xml中的

<android.support.v7.widget.Toolbar
    android:id="@+id/my_awesome_toolbar"
    android:layout_width="match_parent"
    android:layout_height="?attr/actionBarSize"
    style="@style/MyDarkToolbar" />
样式中的

<style name="MyDarkToolbarStyle" parent="Widget.AppCompat.Toolbar">
    <item name="android:background">@color/green</item>
    <item name="popupTheme">@style/ThemeOverlay.AppCompat.Light</item>
    <item name="theme">@style/ThemeOverlay.AppCompat.Dark.ActionBar</item>
</style>

注意事项

  

使用新工具栏,您可以应用样式和主题。他们是   不同!该样式是工具栏视图的本地样式,例如   背景颜色。 app:theme对所有ui元素都是全局的   在工具栏中膨胀,例如标题和图标的颜色。