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"的位置顺序,布布扣,bubuko.com

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

上一篇:js 获取 input file 文件 附给 image src


下一篇:PHP 正则表达式处理字符串的应用(一)