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

TextInputLayout实战:从属性解析到自定义样式进阶

1. TextInputLayout基础入门从零开始掌握Material输入框第一次接触TextInputLayout时我被它丝滑的浮动提示动画惊艳到了。相比传统的EditText这个Material Design组件确实能让表单界面瞬间提升好几个档次。记得去年做登录页面重构时仅仅是把普通输入框替换成TextInputLayout产品经理就夸这才像大厂App该有的样子。要使用TextInputLayout首先得在build.gradle中添加Material库依赖implementation com.google.android.material:material:1.9.0基础用法非常简单用TextInputLayout包裹TextInputEditText即可com.google.android.material.textfield.TextInputLayout android:layout_widthmatch_parent android:layout_heightwrap_content android:hint用户名 com.google.android.material.textfield.TextInputEditText android:layout_widthmatch_parent android:layout_heightwrap_content/ /com.google.android.material.textfield.TextInputLayout这里有个新手容易踩的坑一定要用TextInputEditText而不是普通EditText。虽然用EditText也能运行但在某些机型上会出现文本位置偏移的问题。Material团队专门开发TextInputEditText就是为了解决这个兼容性问题。2. 核心属性全解析打造专业级表单控件2.1 浮动提示与计数器android:hint属性大家都很熟悉但在TextInputLayout中有个神奇的效果——当用户开始输入时提示文字会平滑上浮到输入框上方。这个动画效果可以通过app:hintAnimationEnabled控制默认就是开启的我建议保持这个默认设置因为关闭后界面会显得很生硬。计数器功能在需要限制输入长度的场景特别实用比如验证码输入com.google.android.material.textfield.TextInputLayout app:counterEnabledtrue app:counterMaxLength6 app:counterTextColorcolor/primary app:counterOverflowTextColorcolor/error实际项目中我发现当输入超过限制长度时除了文字变色最好再配合错误提示更明显textInputLayout.error 超过最大长度限制 textInputLayout.isErrorEnabled true2.2 图标与装饰文本前后图标是提升表单可用性的利器。比如在密码框添加眼睛图标切换明文com.google.android.material.textfield.TextInputLayout app:endIconModepassword_toggle在搜索框前面加个放大镜图标也很常见com.google.android.material.textfield.TextInputLayout app:startIconDrawabledrawable/ic_search app:startIconTintcolor/gray辅助文本可以用来显示格式要求我经常这样用com.google.android.material.textfield.TextInputLayout app:helperText请输入6-20位字母数字组合 app:helperTextTextColorcolor/gray3. 样式深度定制突破Material默认风格3.1 背景与边框定制Material提供了三种预设样式FilledBox默认填充样式OutlinedBox带边框样式无背景样式在XML中直接指定style属性即可stylestyle/Widget.MaterialComponents.TextInputLayout.OutlinedBox但真实项目往往需要自定义。比如要修改边框圆角com.google.android.material.textfield.TextInputLayout app:boxCornerRadiusTopStart8dp app:boxCornerRadiusTopEnd8dp app:boxBackgroundModeoutline这里有个细节要注意boxBackgroundMode必须设为outline否则圆角可能不生效。我在项目中就遇到过这个问题调试了半天才发现是这个属性没设置。3.2 颜色与状态适配深色模式适配现在已经是基本要求了。TextInputLayout的颜色控制非常灵活com.google.android.material.textfield.TextInputLayout app:boxStrokeColorcolor/selector_input_stroke app:boxStrokeErrorColorcolor/error app:hintTextColorcolor/selector_hint建议使用selector来管理不同状态的颜色变化。比如selector_input_stroke可以这样定义selector xmlns:androidhttp://schemas.android.com/apk/res/android item android:colorcolor/gray android:state_focusedfalse/ item android:colorcolor/primary android:state_focusedtrue/ /selector4. 高级实战技巧解决复杂业务场景4.1 动态表单验证表单验证是实际开发中最常见的需求。TextInputLayout内置了错误显示功能fun validateInput() { when { text.isEmpty() - { textInputLayout.error 不能为空 textInputLayout.isErrorEnabled true } text.length 6 - { textInputLayout.error 至少6个字符 textInputLayout.isErrorEnabled true } else - { textInputLayout.isErrorEnabled false } } }对于复杂验证比如密码强度检测可以结合TextWatcher实现实时校验editText.addTextChangedListener(object : TextWatcher { override fun afterTextChanged(s: Editable?) { validatePassword(s.toString()) } // 其他回调方法... })4.2 自定义样式扩展当项目需要独特设计语言时可以通过继承TextInputLayout创建自定义样式。比如实现一个圆角更大的输入框class RoundTextInputLayout JvmOverloads constructor( context: Context, attrs: AttributeSet? null, defStyleAttr: Int R.attr.textInputStyle ) : TextInputLayout(context, attrs, defStyleAttr) { init { shapeAppearanceModel shapeAppearanceModel .toBuilder() .setAllCornerSizes(resources.getDimension(R.dimen.input_corner_radius)) .build() } }在XML中使用时所有原有属性都保持不变com.yourpackage.RoundTextInputLayout app:boxBackgroundModeoutline app:hint自定义样式最近在做一个金融类App时我们就通过这种方式实现了带货币符号前缀的输入框用户反馈特别好。

相关文章:

TextInputLayout实战:从属性解析到自定义样式进阶

1. TextInputLayout基础入门:从零开始掌握Material输入框 第一次接触TextInputLayout时,我被它丝滑的浮动提示动画惊艳到了。相比传统的EditText,这个Material Design组件确实能让表单界面瞬间提升好几个档次。记得去年做登录页面重构时&…...

LeetCode 岛屿数量题解

LeetCode 岛屿数量题解 题目描述 给定一个二维网格地图 1(陆地)和 0(水),计算岛屿的数量。 示例: 输入:grid [ ["1","1","1","1","0"], …...

基于WebSocket的Web即时通讯后端架构设计与实战部署指南

1. 项目概述:一个面向开发者的Web即时通讯解决方案最近在折腾一个内部协作工具,需要集成一个稳定、可控且能深度定制的即时通讯模块。市面上成熟的IM SDK很多,但要么是黑盒,出了问题排查困难;要么是功能臃肿&#xff0…...

3步在Windows上安装APK应用:告别安卓模拟器的轻量级解决方案

3步在Windows上安装APK应用:告别安卓模拟器的轻量级解决方案 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 想在Windows电脑上直接运行Android应用却不想安…...

【Nature期刊精准捕获术】:基于Perplexity语义图谱的跨学科文献溯源方法论(附2024最新验证数据集)

更多请点击: https://intelliparadigm.com 第一章:【Nature期刊精准捕获术】:基于Perplexity语义图谱的跨学科文献溯源方法论(附2024最新验证数据集) 传统关键词检索在跨学科高影响力期刊(如 Nature、Scie…...

避坑指南:SciencePlots安装后样式不生效?手把手教你排查Matplotlib的stylelib路径问题

科学绘图样式失效?彻底解决Matplotlib样式库路径配置难题 当你第一次尝试用SciencePlats的science样式美化科研图表时,却发现Python报出KeyError: science is not a valid style的错误提示——这种挫败感我深有体会。作为每天与数据可视化打交道的从业者…...

YOLO26改进 | MSHC多尺度异构卷积:用方形核与条带核捕获复杂空间纹理,以清晰动机打造超强创新!

# YOLO26改进最新创新改进系列 | MSHC多尺度异构卷积:用方形核与条带核捕获复杂空间纹理,以清晰动机打造超强创新! 购买相关资料后畅享一对一答疑! 畅享超多免费持续更新且可大幅度提升文章档次的纯干货工具! 这篇采用…...

用Python和MATLAB复现DMD算法:从COVID-19死亡数据预测到动态模态分解实战

用Python和MATLAB复现DMD算法:从COVID-19死亡数据预测到动态模态分解实战 动态模态分解(Dynamic Mode Decomposition, DMD)作为一种数据驱动的建模方法,近年来在复杂系统分析、流体力学和流行病预测等领域展现出强大潜力。本文将带…...

如何快速搭建AI聊天前端:SillyTavern完整教程与角色扮演系统指南

如何快速搭建AI聊天前端:SillyTavern完整教程与角色扮演系统指南 【免费下载链接】SillyTavern LLM Frontend for Power Users. 项目地址: https://gitcode.com/GitHub_Trending/si/SillyTavern 想象一下,你能够与任何AI角色进行沉浸式对话&#…...

紧急预警:Midjourney即将下架Nihonga相关风格标签?(内部消息+已存档的5类不可再生提示词组合,仅限今日开放获取)

更多请点击: https://intelliparadigm.com 第一章:Nihonga风格在Midjourney中的历史定位与美学内核 Nihonga(日本画)作为明治维新后确立的现代民族绘画体系,以天然矿物颜料、金箔银箔、胶质媒介及传统和纸为物质基础&…...

手把手教你ClickHouse(二、Windows下Docker部署与可视化实战)

1. Windows下Docker环境准备 在开始部署ClickHouse之前,我们需要先确保Windows系统已经正确配置Docker环境。这里我推荐使用Docker Desktop for Windows,它提供了图形化界面和完整的容器管理功能。安装过程可能会遇到几个常见坑点,我把自己实…...

别再只盯着应力云图了!用ANSYS Workbench的‘圣维南原理’和模型简化,把你的计算效率提升200%

别再只盯着应力云图了!用ANSYS Workbench的‘圣维南原理’和模型简化,把你的计算效率提升200% 有限元分析工程师常常陷入一个误区:认为模型越精细,结果越准确。但现实情况是,一个未经合理简化的复杂模型不仅会消耗大量…...

深入理解STM32的FSMC:如何像操作SRAM一样轻松点亮你的TFTLCD屏幕

深入理解STM32的FSMC:如何像操作SRAM一样轻松点亮你的TFTLCD屏幕 在嵌入式开发领域,TFTLCD屏幕的驱动一直是让开发者又爱又恨的难题。传统的GPIO模拟时序方式虽然简单直接,但在高分辨率屏幕和复杂应用场景下往往力不从心。这时,S…...

Midjourney咖啡印相为何总偏灰?揭秘RGB→Lab→咖啡染料光谱响应的3层色彩断层及校正算法

更多请点击: https://intelliparadigm.com 第一章:Midjourney咖啡印相为何总偏灰?揭秘RGB→Lab→咖啡染料光谱响应的3层色彩断层及校正算法 咖啡印相(Coffee Cyanotype)作为一种新兴的生物友好型物理输出工艺&#xf…...

Sora 2与3D Gaussian结合实战指南(工业级部署避坑手册)

更多请点击: https://intelliparadigm.com 第一章:Sora 2与3D Gaussian结合的工业级部署全景图 Sora 2作为OpenAI新一代视频生成模型,在长时序建模与物理一致性方面取得显著突破;而3D Gaussian Splatting(3DGS&#x…...

软件设计师下午题训练1-3题 练习真题训练10

一、2019下1、问题1E1:帮买顾问E2:车辆交易系统E3:物流商2、问题2D1:线索表D2:订单表D3:路线表D4:合约表D5:物流商表3、问题3数据流 起点 终点物流信息 P5 …...

别再折腾Anaconda了!用PyCharm 2024.1自带工具5分钟搞定TensorFlow 2.15 + Keras 3环境

PyCharm 2024.1极简指南:5分钟无痛部署TensorFlow 2.15 Keras 3深度学习环境 深度学习环境配置曾是无数开发者的噩梦——直到PyCharm 2024.1彻底改变了游戏规则。最新版本集成的环境管理工具让TensorFlow和Keras的安装变得像点外卖一样简单,完全跳过了传…...

Cognize-Agent™空间智能体,98.5%故障预警准确率,终结非计划停机

Cognize-Agent™空间智能体,98.5%故障预警准确率,终结非计划停机工业制造领域,设备非计划停机始终是制约生产效率、拉高运维成本的核心痛点。传统设备运维依赖定期检修、事后抢修,依赖人工巡检与单一数据监测,无法提前…...

MatrixFusion™矩阵视频融合,一路画面管全厂,彻底消除车间监控盲区

MatrixFusion™矩阵视频融合,一路画面管全厂,彻底消除车间监控盲区在智能制造全域可视化管控的落地实践中,工业车间因设备密集、产线交错、通道迂回、多区域分割的固有场景特性,成为监控体系搭建的核心难点。传统工业视频监控系统…...

关于岐金兰AI元人文构想与江畅《论道德真理》之关系的理论说明

关于岐金兰AI元人文构想与江畅《论道德真理》之关系的理论说明——致敬江畅教授,并申明独立研究的道路岐金兰2026年5月12日一、相遇:迟到的阅读,及时的对话2026年3月11日,我在一个偶然的学术检索中读到了江畅教授的《论道德真理》…...

实验记录-农药种衣剂

1.显色度取决于种子颗粒大小,种子越大,则显色越差;2.需加入增稠剂...

2026年邵阳高复机构大揭秘,哪家才是学子的理想之选?

高考失利后,复读成为许多学子重新追逐梦想的途径。在邵阳,众多高复机构如繁星般闪耀,而湘郡铭志学校高复部无疑是其中一颗璀璨的明星。接下来,让我们深入了解湘郡铭志学校高复部,同时对比其他知名高复机构,…...

告别SVN提交冲突!手把手教你配置TortoiseSVN 1.10.5的忽略列表与清理功能

告别SVN提交冲突!手把手教你配置TortoiseSVN 1.10.5的忽略列表与清理功能 团队协作开发中,版本控制系统是必不可少的工具。Subversion(SVN)作为一款经典的集中式版本控制系统,至今仍在许多项目中发挥着重要作用。然而&…...

终极指南:如何使用Harepacker-resurrected打造你的MapleStory游戏Mod

终极指南:如何使用Harepacker-resurrected打造你的MapleStory游戏Mod 【免费下载链接】Harepacker-resurrected All in one .wz file/map editor for MapleStory game files 项目地址: https://gitcode.com/gh_mirrors/ha/Harepacker-resurrected 如果你是一…...

基于官方API的WhatsApp AI助手集成:规避封号风险与实战部署指南

1. 项目概述:为你的AI助手开通一个安全的WhatsApp专线 如果你正在使用OpenClaw构建自己的AI助手,并且希望它能通过WhatsApp与用户自然交流,那么你很可能已经研究过各种方案了。市面上常见的方案,比如基于 whatsapp-web.js 或 …...

taotoken模型广场功能体验与主流模型选型建议

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 taotoken模型广场功能体验与主流模型选型建议 1. 平台入口与模型广场概览 登录Taotoken控制台后,最直观的功能入口之一…...

从RIPv2到RIPng:IPv6时代路由协议的演进与实战部署

1. 从RIPv2到RIPng:为什么IPv6需要新的路由协议? 第一次在实验室配置RIPv2时,我盯着那些IPv4地址看了整整三天。直到某天客户突然要求支持IPv6,才发现这个诞生于1988年的老协议已经跟不上时代——就像用传呼机收发4K视频&#xff…...

STM32F103C8T6与DHT11单总线通信:从时序解析到数据校验的实战指南

1. 认识STM32F103C8T6与DHT11这对黄金搭档 第一次接触嵌入式开发的朋友可能会觉得,让单片机读取温湿度数据是个复杂的事情。但当你用STM32F103C8T6这颗性价比超高的Cortex-M3内核芯片,搭配DHT11这个经典温湿度传感器时,事情就变得简单多了。…...

分布式架构实战:全平台矩阵管理系统的技术实现与性能优化

前言在数字化运营进入全域竞争的今天,多平台账号集群管理已成为企业与开发者的核心技术挑战。传统单体架构的矩阵工具普遍存在算力弹性不足、账号关联风险高、跨平台适配复杂、AI 能力割裂等问题,导致 90% 以上的自研矩阵系统最终以失败告终。本文基于生…...

阿里云效前端流水线自动化部署

一、权限准备 如果你想实现这个功能,那么你的云效必须要有权限!!这非常重要!!如何确定自己是否有相关权限呢? 流水线权限 制品仓库权限 就是云服务器的权限,这个权限是要你可以读写文件的…...