selector的最佳用法

本文介绍了一种简化Android UI按钮状态布局的方法,通过一个Selector实现按钮在不同状态下的背景变化,包括圆角和颜色切换,使得UI设计更加灵活且易于维护。

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

在进行UI布局的时候,我们经常会遇到这样的布局:如图


这个包括背景的两种状态(分按下和没有按下)和圆角,之前我一直用的就是,先把圆角和背景写到一个drawable,分别写两个,然后再写一个selecor,这样做有点xx

其实有一种更简单的写法如下:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <!-- pressed -->
    <item android:state_pressed="true">
        <shape>
            <corners android:radius="@dimen/btn_corners_radius"/>
            <solid android:color="@color/colorPress"/>
        </shape>
    </item>

    <!-- selected -->
    <item android:state_selected="true">
        <shape>
            <corners android:radius="@dimen/btn_corners_radius"/>
            <solid android:color="@color/colorPress"/>
        </shape>
    </item>

    <!-- default -->
    <item>
        <shape>
            <corners android:radius="@dimen/btn_corners_radius"/>
            <solid android:color="@color/colorMain"/>
        </shape>
    </item>

</selector>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值