如何在主题

时间:2016-03-28 11:29:58

标签: android button android-theme

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

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

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

如何为按钮Text?

执行此操作

6 个答案:

答案 0 :(得分:30)

 <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 这可以帮助您全局更改文本颜色。我希望这是有帮助的谢谢你

答案 1 :(得分:9)

如果您只需要更改按钮的文字颜色。您可以修改主题的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>

答案 2 :(得分:8)

对于任何偶然发现此问题的人,我建议您查看一个关于Material Design Button Styles.的类似问题。主题是您的&#34;强调颜色&#34;将用于为按钮着色。

<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>

答案 3 :(得分:2)

使用新的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属性要求用于Android库的材料组件的版本为 1.1.0

implementation 'com.google.android.material:material:1.1.0-alpha09'

答案 4 :(得分:0)

只需使用AppCompatButton设置此属性:

"app:backgroundTint="@color/wildberries"

确保您的活动扩展AppCompatActivity。我只是在我的项目中使用它。它在5.X和5.X之前就像一个魅力。

答案 5 :(得分:-3)

<Button  
     app:backgroundTint="#fece2f" //any color
 />

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