Android:更改按钮文字和背景颜色

Mae*_*lig 62 android background colors status button

使用xml时,如何在按下按钮时更改文本和背景颜色?

要更改文字颜色,我可以这样做:

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" android:color="mycolor"/>
    <item android:color="mycolor2/>
</selector>
Run Code Online (Sandbox Code Playgroud)

要改变我可以做的背景(在带有可绘制参考的选择器/项目中使用它):

<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <solid android:color="#FF0079FF" />
</shape>
Run Code Online (Sandbox Code Playgroud)

但我怎么能两个都做?假设我想拥有:

  • 默认值:黑色文本/白色背景
  • 按下:白色文本/蓝色背景

编辑:回答

我完全忘了背景和文字颜色是分开管理的,所以我就是这样做的:

<Button
    android:textColor="@color/filtersbuttoncolors"
    android:background="@drawable/mybackgroundcolors" />
Run Code Online (Sandbox Code Playgroud)

在mybackgroundcolors.xml中我管理背景,在filtersbuttoncolors.xml中我管理文本颜色.在两个xml文件中我管理状态(按下,选中,默认)

Mit*_*hah 42

这是一个drawable的例子,默认情况下是白色,按下时是黑色:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true">
        <shape>
            <solid
                android:color="#1E669B"/>
            <stroke
                android:width="2dp"
                android:color="#1B5E91"/>
            <corners
                android:radius="6dp"/>
            <padding
                android:bottom="10dp"
                android:left="10dp"
                android:right="10dp"
                android:top="10dp"/>
        </shape>

    </item>
    <item>
        <shape>
            <gradient
                android:angle="270"
                android:endColor="#1E669B"
                android:startColor="#1E669B"/>
            <stroke
                android:width="4dp"
                android:color="#1B5E91"/>
            <corners
                android:radius="7dp"/>
            <padding
                android:bottom="10dp"
                android:left="10dp"
                android:right="10dp"
                android:top="10dp"/>
        </shape>
    </item>
</selector>
Run Code Online (Sandbox Code Playgroud)


Jon*_*oke 25

从API级别21开始,您可以使用:

android:backgroundTint="@android:color/white"
Run Code Online (Sandbox Code Playgroud)

你只需要在你的xml中添加它

  • 这是一个更好的解决方案,我不知道为什么android使它变得如此复杂,只需更改按钮背景颜色.并保持默认行为. (3认同)
  • @Bhaskara 你可以使用支持库`app:backgroundTint="@android:color/white"` (2认同)

use*_*854 23

我认为这样做更简单:

button.setBackgroundColor(Color.BLACK);
Run Code Online (Sandbox Code Playgroud)

你不需要import android.graphics.Color;:import android.R.color;

或者你可以写0xFF000000第一个字节设置alpha 的4字节十六进制代码(不是3字节).

  • 当您选择按钮时,这将松开按钮的颜色,并且还会松开主题对按钮所暗示的任何阴影或形状. (14认同)

小智 12

在styles.xml中添加以下行

<style name="AppTheme.Gray" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="colorButtonNormal">@color/colorGray</item>
    </style>
Run Code Online (Sandbox Code Playgroud)

在按钮,添加android:theme="@style/AppTheme.Gray",示例:

<Button
            android:theme="@style/AppTheme.Gray"
            android:textColor="@color/colorWhite"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@android:string/cancel"/>
Run Code Online (Sandbox Code Playgroud)


Abd*_*ood 9

只是补充@Jonsmoke的答案.

对于API级别21及以上,您可以使用:

android:backgroundTint="@android:color/white"
Run Code Online (Sandbox Code Playgroud)

在XML中用于按钮布局.

对于低于21的API级别,使用appCompatButton使用app命名空间而不是android用于backgroundTint.

例如:

<android.support.v7.widget.AppCompatButton
    android:id="@+id/my_button"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="My Button"
    app:backgroundTint="@android:color/white" />
Run Code Online (Sandbox Code Playgroud)