我使用http://android-developers.blogspot.in/2014/10/appcompat-v21-material-design-for-pre.html中的相同代码作为我的项目。
当我创建一个仅测试工具栏的空白项目时,颜色正常工作。但是,在使用相同的代码将项目升级到材料设计后,工具栏颜色变为灰色。
似乎android:background?attr/colorPrimary
没有加载正确的颜色。当我使用@color\theme_red
时,颜色在工具栏上正确设置。
这里出了什么问题?
我的colors.xml:
<?xml version="1.0" encoding="utf-8"?><resources>
<color name="theme_red">#d43d1e</color>
<color name="theme_red_dark">#aa3118</color>
<color name="theme_accent">#3333ff</color>
</resources>
&安培; styles.xml:
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="AppTheme.Base"/>
<style name="AppTheme.Base" parent="Theme.AppCompat.Light.NoActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/theme_red</item>
<item name="colorPrimaryDark">@color/theme_red_dark</item>
<item name="colorAccent">@color/theme_accent</item>
</style>
&安培;工具栏代码:
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:minHeight="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />
android:background?attr/colorPrimary
工具栏的外观如何:
工具栏的显示方式与@color/theme_red
:
更新:
我正在更新问题,因为我在代码中有另一个似乎有关的错误。我在Android 5.0.2手机上试过这个应用程序&amp;即使正确的主题和状态,状态栏也没有暗色调。在styles.xml中定义的颜色。状态栏与第一张图片中的Toolbar
颜色完全相同。
styles.xml在上面。 v-21 / styles.xml如下:
<resources>
<style name="AppTheme" parent="AppTheme.Base">
<item name="colorPrimary">@color/theme_red</item>
<item name="colorPrimaryDark">@color/theme_red_dark</item>
<item name="colorAccent">@color/theme_accent</item>
<item name="android:windowContentTransitions">true</item>
<item name="android:windowAllowEnterTransitionOverlap">true</item>
<item name="android:windowAllowReturnTransitionOverlap">true</item>
<item name="android:windowSharedElementEnterTransition">@android:transition/move</item>
<item name="android:windowSharedElementExitTransition">@android:transition/move</item>
</style>
</resources>
不知何故,即使正确定义,系统也无法使用这些颜色。
完整项目位于:https://github.com/pauldmps/BPUTApp-AndroidStudio,如果有人想查看整个代码。
答案 0 :(得分:8)
您在清单中指定了错误的主题:
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/Theme.AppCompat.Light.NoActionBar">
您应该使用android:theme="@style/AppTheme"
。
答案 1 :(得分:0)
这很奇怪......也许尝试将其用作styles.xml
:
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar">
<!-- Customize your theme here. -->
<item name="colorPrimary">@color/theme_red</item>
<item name="colorPrimaryDark">@color/theme_red_dark</item>
<item name="colorAccent">@color/theme_accent</item>
</style>
</resources>
答案 2 :(得分:0)
如果您想将DarKActionBar
用作AppTheme
,则必须通过添加AppTheme
来禁用默认操作栏:
<item name="windowActionBar">false</item>
<item name="android:windowNoTitle">true</item>
使用小部件ToolBar
需要它们。不过,您已NoActionBar
使用AppTheme
,但不需要超过两项,但您应在app:theme
中将AppTheme
设为ToolBar
。
答案 3 :(得分:0)
您很可能会遇到此问题,因为您正在XML文件中将Toolbar
的主题设置为ThemeOverlay.AppCompat.Dark.ActionBar。
尝试更改
app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
到
app:theme="@style/AppTheme"
您可能还想专门为Toolbar
指定主题。
<!-- Exclusive theme for the Toolbar -->
<style name="Theme.Toolbar" parent="Theme.AppCompat">
<item name="colorPrimary">@color/yourColor</item>
<item name="android:textColorPrimary">@color/yourTextColor</item>
</style>
答案 4 :(得分:0)
所以我不知道它是什么样的巫术......但这里有适合我的修复
在您的values-v21 / styles.xml中,添加以下行。
<item name="colorPrimary">@color/theme_red</item>
<item name="colorPrimaryDark">@color/theme_red_dark</item>
<item name="colorAccent">@color/theme_accent</item>
我不知道为什么样式21不会继承这些属性......但是很好