[Android Studio]设置Button的圆角、点击效果、按钮颜色

本文详细介绍如何使用Android的Selector实现按钮的动态样式变化,包括不同状态下的颜色、边框及圆角效果,通过XML布局文件轻松定制UI组件外观。

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

第一步:创建布局文件

在res/drawable目录下新建xml布局文件
在这里插入图片描述

第二步:编写xml文件

<?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">
          <!-- 圆角的度数-->
            <corners android:radius="6dp" />
          <!-- 设置按钮中的文字与边框的距离-->
            <padding android:bottom="10dp" android:left="20dp" android:right="20dp" android:top="10dp" />
          <!-- 背景色-->
            <solid android:color="#E33E33" />
          <!-- 边框色-->
            <stroke android:width="1dp" android:color="#000000" />
      </shape>>
  </item>
<item >
    <shape android:shape="rectangle">
        <corners android:radius="8dp"/>
        <solid android:color="#0497FD"/>
        <stroke android:width="1dp" android:color="#E89C17" />
    </shape>
</item>

</selector>
  1. selector是根结点,是必须存在的.
  2. selector可以包含多个<item
    item对应的属性 android: state_XX 是指UI组件的状态
    下面是9中情况:
android:state_pressed 
android:state_focused 
android:state_hovered 
android:state_selected 
android:state_checkable
android:state_checked 
android:state_enabled 
android:state_activated 
android:state_window_focused 

注意:UI组件根据状态来选择item,顺序是从上到下的,如果第一个item就满足UI组件此刻的状态满足这个item的android: state_XX条件,那么就不会在往下进行判断,那么之后的item将不再起作用.
所以,对于设置UI组件默认状态的item,一定要放在selector的最后面.

第三步:布局文中中引用

  <Button
        android:id="@+id/btn"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center_horizontal"
        android:textSize="25sp"
        android:layout_marginTop="10dp"
        android:background="@drawable/btn_shape"
        android:text="查看大图"
        android:textColor="#FFFFFF"/>

只需要在background中引用刚才编写的xml文件就可以了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值