Android Studio中实现普通、点击、禁用状态下圆角按钮背景颜色的改变

自定义按钮可以改变普通、点击、禁用状态下的背景颜色,并将按钮设置为圆角形状且可自定义角度

1、新建activity以及对应的xml文件,在xml文件中设置三个button,分别设置其文字内容为“正常”、“点击”和“禁用”,在新建的activity中书写代码,点击“禁用”时禁用“正常”键的点击功能,点击“点击”时恢复点击功能。

button1.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        button2.setEnabled(false);
    }
});
button3.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        button2.setEnabled(true);
    }
});

2、在res目录下的drawable中新建selector.xml文件,代码为

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item
        android:state_enabled="false"
        android:drawable="@drawable/btn_no"
        />
    <item
        android:state_pressed="true"
        android:drawable="@drawable/btn_click"/>

    <item
        android:drawable="@drawable/btn_normal"
        />


</selector>

注意:selector第一项为按钮不可点时对应的选项;因为selector按照item顺序进行判断,如果有一项符合则退出selector,不再继续进行判断。
3、新建对应selector中选项的xml文件
(1)新建btn_no.xml文件,禁用状态下按钮为灰色

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >
    <!-- 圆角半径 -->
    <corners android:radius="200dp" />
    <!-- 填充颜色 -->
    <solid android:color="@android:color/darker_gray"/>
</shape>

在这里插入图片描述
(2)新建btn_click.xml文件 点击状态下为渐变色

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >
    <!-- 圆角半径 -->
    <corners android:radius="200dp" />
    <!-- 填充颜色 -->
    <solid android:color="@android:color/holo_purple"/>
    <gradient
        android:type="linear"
        android:angle="0"
        android:centerX="0.5"
        android:centerY="0.5"
        android:startColor="@android:color/holo_green_light"
        android:centerColor="@android:color/holo_orange_dark"
        android:endColor="@android:color/holo_purple"
        android:useLevel="false"/>
</shape>

在这里插入图片描述
这里我将点击后的颜色设置为了渐变色,具体内容可以去看关于shape中的子标签gradient
(3)新建btn_normal.xml文件 正常状态下为蓝色

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >
    <!-- 圆角半径 -->
    <corners android:radius="200dp" />
    <!-- 填充颜色 -->
    <solid android:color="@android:color/holo_blue_light"/>
</shape>

在这里插入图片描述
这样就完成任务了!

如有发现错误,欢迎指正~

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值