Android Drawable 关于selector中state_pressed="true"的位置顺序

界面中有一个按钮使用这样的样式:

 

<?xml version="1.0" encoding="utf-8"?>

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item>
        <shape>
            <corners android:radius="10dp"/>
            <solid android:color="#ff0099ff"/>
        </shape>
    </item>
    <item android:state_pressed="true">
        <shape>
            <corners android:radius="5dp"/>
            <solid android:color="#ff063c91"/>
        </shape>
    </item>
</selector>

会发现按钮被点击之后颜色未变,原来是press="true"的位置颠倒了,改为如下即可:

<?xml version="1.0" encoding="utf-8"?>

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true">
        <shape>
            <corners android:radius="5dp"/>
            <solid android:color="#ff063c91"/>
        </shape>
    </item>
    <item>
        <shape>
            <corners android:radius="10dp"/>
            <solid android:color="#ff0099ff"/>
        </shape>
    </item>
</selector>

也就是两个Item标签更换一下位置。
其实这就有点类似于switch语句,最后item没有属性就代表default

Android Drawable 关于selector中state_pressed="true"的位置顺序,,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。