Android 用state list drawable动态改变按钮点击前后的状态

本文介绍如何使用stateListDrawable自定义Android按钮的点击和未点击状态样式,包括背景颜色和文字颜色的变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


有时候我们希望按钮在点击时和未点击时显示不同的背景和(或)文字样式,这时我们可以使用state list drawable自定义drawable。


首先我们创建按钮点击状态下应显示的shape(res/drawable/button_shape_pressed.xml):

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
	android:shape="rectangle" >
	<solid android:color="# ff00ff " />
	<stroke
	    android:width="1dip"
	    android:color="# ff00ff " />
	<padding
	    android:bottom="2dp"
	    android:left="2dp"
	    android:right="2dp"
	    android:top="2dp" />
	<corners android:radius="8dp" />
</shape>

然后创建按钮未点击状态下应显示的shape(res/drawable/button_shape_normal.xml):

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
	android:shape="rectangle" >
	<solid android:color="#ffffff" />
	<stroke
	    android:width="1dip"
	    android:color="#A0A0A0" />
	<padding
	    android:bottom="2dp"
	    android:left="2dp"
	    android:right="2dp"
	    android:top="2dp" />
	<corners android:radius="8dp" />
</shape>


接下来我们需要一个state list drawable, state list drawable必须包含一个selector根元素,以及用来描述状态的一个或多个item。右键单击res/drawable/目录,以selector为根元素,创建一个名为button_bg_shape.xml文件:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
	<item android:drawable="@drawable/button_shape_normal"
	    android:state_pressed="false"></item>
	<item android:drawable="@drawable/button_shape_pressed"
	    android:state_pressed="true"></item>
</selector>

在未点击状态与点击状态下,按钮显示文字的颜色不同。与上一步骤一样,我们右键单击res/drawable/目录,创建一个button_text_color.xml的state list drawable:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
    <item android:state_pressed="false" android:color="#000000" />
    <item android:state_pressed="true" android:color="#ffffff" />
</selector>

最后在自己的button中设置一下background和textcolor属性就大功告成啦。

<Button 
        android:id="@+id/testBtn"
        android:layout_width="50dp"
        android:layout_height="30dp"
       android:layout_centerVertical="true" 
        android:text="@string/testText"
        android:layout_alignParentRight="true"
        android:layout_alignParentEnd="true"
        android:layout_marginRight="5dp"
        android:layout_marginLeft="5dp"
        android:textColor="@drawable/button_text_color"
        android:background="@drawable/button_bg_shape"
        />


怎么样,自己试一下吧~~~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值