31

如何更改所有按钮的文本颜色?

我知道我可以设置如下背景颜色:

<style name="AppTheme.Base" parent="Theme.AppCompat.Light.DarkActionBar">
    ...
    <item name="colorButtonNormal">@color/buttonColor</item>
</style>

如何为按钮文本执行此操作?

4

6 回答 6

49
 <style name="AppTheme.Base" parent="Theme.AppCompat.Light.DarkActionBar">
   <item name="android:textColor">#yourcolor</item>
    <item name="android:buttonStyle">@style/ButtonColor</item>
    <item name="colorButtonNormal">@color/buttonColor</item>
</style>



<style name="ButtonColor" parent="@android:style/Widget.Button">
   <item name="android:textColor">@color/yourcolor</item>
</style> 

android:textColor这应该可以帮助您全局更改文本颜色。

于 2016-03-28T11:32:06.720 回答
13

使用新Theme.MaterialComponents主题,您可以materialButtonStyle在应用主题中定义属性。

  <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.MaterialComponents.Light">
    ....

    <item name="materialButtonStyle">@style/MyButtonTheme</item>
  </style>

通过这种方式,您可以全局自定义应用程序中所有按钮的样式。您可以使用属性覆盖默认样式的主题materialThemeOverlay属性。

就像是:

  <style name="MyButtonTheme" parent="Widget.MaterialComponents.Button">
    <item name="materialThemeOverlay">@style/ButtonStyleTextColor</item>
  </style>

  <style name="ButtonStyleTextColor">
    <!-- For filled buttons, your theme's colorPrimary provides the default background color of the component, and -->
    <!--the text color is colorOnPrimary -->
    <item name="colorPrimary">@color/my_color</item>
    <item name="colorOnPrimary">@color/my_color2</item>

  </style>

目前该materialThemeOverlay属性需要1.1.0版本的材料组件用于 android 库。

于 2019-08-19T22:00:26.767 回答
11

对于任何偶然发现此问题的人,我建议您查看有关Material Design Button Styles 的类似问题。使用主题,您的“强调色”将用于为您的按钮着色。

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    ...
    <item name="android:buttonStyle">@style/Widget.AppCompat.Button.Colored</item>
    <item name="buttonStyle">@style/Widget.AppCompat.Button.Colored</item>
</style>
于 2017-02-22T15:36:44.490 回答
10

如果您只需要更改按钮的文本颜色。您可以修改textAppearanceButton主主题的样式属性。

<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <item name="colorButtonNormal">@color/buttonColor</item>
    <item name="android:textAppearanceButton">@style/TextAppearance.AppCompat.Button.Custom</item>
</style>

并声明您的新 textAppearance 样式如下

<style name="TextAppearance.AppCompat.Button.Custom">
    <item name="android:textColor">@color/mycustomcolor</item>
</style>
于 2016-03-28T12:12:30.330 回答
0

只需AppCompatButton通过设置此属性来使用:

"app:backgroundTint="@color/wildberries"

并确保您的活动扩展了 AppCompatActivity。我只是在我的项目中使用它。它在 5.X 和 pre-5.X 中都像一个魅力。

于 2017-06-12T06:47:52.023 回答
-3
<Button  
     app:backgroundTint="#fece2f" //any color
 />

如果您不希望在全局范围内定义它,这是最好的方法

于 2020-05-19T17:32:38.573 回答