selector中的item是有顺序的

本文介绍如何使用Android的Selector实现按钮的不同状态显示效果,包括默认、按压、不可用等状态,并详细解释了不同状态属性的作用。

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

一旦前面的一个 `item` 已经满足匹配的状态,后面的 `item` 就不会去执行了。

例如下面的代码,按钮被按下变色的效果就没有

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!--默认-->
    <item >
        <shape android:shape="rectangle">
            <solid android:color="@color/act_login_user_login_text_color"/>
            <corners android:radius="16dp" />
        </shape>
    </item>

    <!--按压时-->
    <item android:state_pressed="true">
        <shape android:shape="rectangle">
            <solid android:color="@color/act_login_icon_remark_text_color"/>
            <corners android:radius="16dp" />
        </shape>
    </item>

    <!--不可用-->
    <item android:state_enabled="false">
        <shape android:shape="rectangle">
            <solid android:color="@color/btn_un_use"/>
            <corners android:radius="16dp" />
        </shape>
    </item>
    
</selector>

而下面的代码,按钮被点击后才有变色的效果

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

    <!--按压时-->
    <item android:state_pressed="true">
        <shape android:shape="rectangle">
            <solid android:color="@color/act_login_icon_remark_text_color"/>
            <corners android:radius="16dp" />
        </shape>
    </item>

    <!--不可用-->
    <item android:state_enabled="false">
        <shape android:shape="rectangle">
            <solid android:color="@color/btn_un_use"/>
            <corners android:radius="16dp" />
        </shape>
    </item>

    <!--默认-->
    <item >
        <shape android:shape="rectangle">
            <solid android:color="@color/act_login_user_login_text_color"/>
            <corners android:radius="16dp" />
        </shape>
    </item>

</selector>

相关属性:

android:state_selected是选中
android:state_focused
是获得焦点
android:state_pressed
是点击
android:state_enabled
是设置是否响应事件,指所有事件


<?xml version="1.0" encoding="utf-8" ?>   
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
<!--
 默认时的背景图片-->  
  <item android:drawable="@drawable/pic1" />    
<!--
 没有焦点时的背景图片 -->  
  <item android:state_window_focused="false"   
        android:drawable="@drawable/pic1" />   

<!--选中时的图片背景-->  

  <item android:state_selected="true"   android:drawable="@drawable/pic4" />   

<!--获得焦点时的图片背景--> 

<item android:state_focused="true"   android:drawable="@drawable/pic5" />

<!--点击时的图片背景-->   

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

</selector>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值