StateListDrawable的使用

以前一直做android开发的时候当要使用一个按钮或者一个控件有按下效果的时候,都是在res文件夹下的drawable下创建一个对应的drawable.xml文件,比如

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">


    <item android:drawable="@drawable/qiandw_back_press" android:state_pressed="true"/>
    <item android:drawable="@drawable/qiandw_back_normal"/>


</selector>

每次都这样使用,今天希望给没有发现和使用过StateListDrawable的码友推荐一个方法,再也不用去每次都创建新的xml文件了,你只需要写一个方法即可

public StateListDrawable getSeletorDrawable(int normalID, int pressID){
		StateListDrawable drawable = new StateListDrawable();
		int pressed = android.R.attr.state_pressed;  
		drawable.addState(new int []{pressed , pressed}, getResources().getDrawable(pressID));  
		drawable.addState(new int []{}, getResources().getDrawable(normalID));  
		return drawable;
	}

传入一个点击时候的图素的ID和正常时候的ID即可!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android状态列表StateListDrawable是一种Drawable,它允许您在不同的状态下显示不同的图形。例如,当视图处于按下状态时,您可以使用不同的图像来表示它。您可以使用StateListDrawable创建按钮、复选框、单选按钮、背景等。 以下是使用StateListDrawable的简单步骤: 1. 创建drawable资源文件,例如button_selector.xml。 2. 在drawable资源文件,定义不同状态下的图形。您可以使用<item>标记来定义图形,使用android:drawable属性来指定图形文件。 例如,以下代码定义了按钮在不同状态下的颜色: ``` <selector xmlns:android="http://schemas.android.com/apk/res/android"> <item android:state_pressed="true" android:drawable="@color/blue" /> <item android:state_focused="true" android:drawable="@color/green" /> <item android:drawable="@color/gray" /> </selector> ``` 上述代码,第一个<item>表示按钮在按下状态下的颜色为蓝色,第二个<item>表示按钮在得到焦点状态下的颜色为绿色,第三个<item>表示按钮在其他状态下的颜色为灰色。 3. 在布局文件,将StateListDrawable作为背景指定给视图。 例如,以下代码StateListDrawable作为背景指定给按钮: ``` <Button android:id="@+id/my_button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="My Button" android:background="@drawable/button_selector" /> ``` 上述代码android:background属性指定了StateListDrawable作为按钮的背景。 使用StateListDrawable可以方便地创建不同状态下的图形,并且可以将其应用于许多不同的视图,例如按钮、文本框、标签等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值