当前位置: 首页 > news >正文

Android开发中 Button 背景控制选择器

方式一:使用纯色背景(color

如果你只需要在不同状态下改变按钮的颜色,这是最简单的方法。

  1. res/color 目录下创建 XML 文件: 例如,创建一个名为 button_background_selector.xml 的文件。
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:state_pressed="true" android:color="#FF5722" /><item android:state_enabled="false" android:color="#B0BEC5" /><item android:state_focused="true" android:color="#FF7043" /><item android:color="#2196F3" />
</selector>
  1. 在布局文件中使用: 直接将这个 XML 文件作为按钮的 backgroundTint 属性引用。
<Buttonandroid:id="@+id/my_button"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="点击我"android:textColor="@android:color/white"android:backgroundTint="@color/button_background_selector" />
方式二:使用带圆角的形状背景(shape

这种方式更为常用,因为它不仅能改变颜色,还能控制按钮的形状、圆角、边框等样式。

1 . res/drawable 目录下创建 XML 文件:

- 首先,为每种状态创建一个单独的 `shape` 文件。
  • 默认状态:button_default.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="rectangle"><solid android:color="#2196F3" /><corners android:radius="8dp" /><padding android:left="16dp" android:top="8dp"android:right="16dp" android:bottom="8dp" />
</shape>
  • 按下状态:button_pressed.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="rectangle"><solid android:color="#1976D2" /><corners android:radius="8dp" /><padding android:left="16dp" android:top="8dp"android:right="16dp" android:bottom="8dp" />
</shape>
  • 禁用状态:button_disabled.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="rectangle"><solid android:color="#B0BEC5" /><corners android:radius="8dp" /><padding android:left="16dp" android:top="8dp"android:right="16dp" android:bottom="8dp" />
</shape>
  • 焦点状态
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"android:shape="rectangle"><solid android:color="#1E88E5" /><corners android:radius="8dp" /><stroke android:width="2dp" android:color="#FF5722" /><padding android:left="16dp" android:top="8dp"android:right="16dp" android:bottom="8dp" />
</shape>
  1. 创建 selector 文件来引用这些 shape 文件: 创建一个名为 button_background_selector.xml 的文件,放在 res/drawable 目录下。
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android"><item android:state_pressed="true" android:drawable="@drawable/button_pressed" /><item android:state_enabled="false" android:drawable="@drawable/button_disabled" /><item android:state_focused="true" android:drawable="@drawable/button_focused" /><item android:drawable="@drawable/button_default" />
</selector>
  1. 在布局文件中使用: 直接将这个 selector 文件作为按钮的 background 属性引用。
<Buttonandroid:id="@+id/my_button"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="点击我"android:textColor="@android:color/white"android:background="@drawable/button_background_selector" />
http://www.wxhsa.cn/company.asp?id=246

相关文章:

  • redis非阻塞锁
  • MyEMS:技术架构深度剖析与用户实践支持体系
  • ECT-OS-JiuHuaShan 的本质是超验数学结构,史上首个实现完全移植保真性的认知框架
  • Appium元素等待
  • DropWizard-REST-Web-服务指南-全-
  • Spring Boot如何启动嵌入式Tomcat?
  • sql随机查看数据
  • 自我介绍
  • 83、SpringMVC全局异常处理和数据校验
  • nginx反向代理
  • 微算法科技(NASDAQ: MLGO)基于阿基米德优化算法(AOA)的区块链存储优化方案
  • mysql常用命令
  • WebApi通用获取全量参数,不使用实体
  • 《【插件】2025版PS插件一键安装》
  • Nginx跨越设置
  • 依然是dots的介绍视频
  • 【GitHub每日速递】别再瞎买编程课了!这 2 个免费宝藏,从入门到职业规划全搞定
  • 你的项目一团糟-不是你的错-是框架的锅
  • 数据结构与算法-24.2-3查找树
  • 8 将GitHub远程仓库修改为ssh
  • Symfony学习笔记 - Symfony Documentation - Utilities(1)
  • IPv4向IPv6平滑过渡综合技术方案
  • TIA博图中的常用指令:定时器、计数器和触发器
  • Vue3项目开发专题精讲【左扬精讲】—— 企业网站系统(基于 Vue3 与 TypeScript 技术栈的企业网站系统开发实战)
  • Vue3项目开发专题精讲【左扬精讲】—— 商城网站系统(基于 Vue3 与 TypeScript 技术栈的企业网站系统开发实战)
  • $\LaTeX{}$之快速编译和删除中间文件 - Invinc
  • 我们一起“扒一扒”ReentrantLock:看看锁背后那些精妙的设计
  • win10使用openssl生成证书
  • $\LaTeX{}$之minted使用 - Invinc
  • linux服务器 系统服务文件