百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

TextInputLayout,打造材料设计风格的文本输入框

yuyutoo 2024-10-19 11:08 2 浏览 0 评论

Android Material Design 对 EditText 输入框的交互设计定义了一个规范,详细设计细节可以参考官网介绍:Components/Text fields (需要 翻墙 )。android.support.design 包中恰好提供了一个实现这些设计细节的新控件:TextInputLayout,本文就来细细分析一下。

TextInputLayout

LinearLayout 的子类,专用于包裹 EditText 的一个 ViewGroup ,基本用法如下:

<android.support.design.widget.TextInputLayout
 android:layout_width="match_parent"
 android:layout_height="wrap_content">
 <android.support.design.widget.TextInputEditText
 android:layout_width="match_parent"
 android:layout_height="wrap_content"
 android:hint="@string/form_username"/>
 </android.support.design.widget.TextInputLayout>

相比传统单独使用 EditText 的做法,新增的容器 TextInputLayout 拥有的一些独特属性能够实现如下功能:

  1. hint 提示:输入框获取焦点时,EditText 通过 hint 属性设置的字符串内容将浮动显示在输入框左上方。用户进行输入操作时依旧能够看到提示信息。

  2. error 提示:通常用户输入的内容需要经过验证,可以使用 TextInputLayout 类提供的 setErrorEnabled(boolean)setError(CharSequence) 方法控制输入框左下方错误信息的显示与隐藏。

  3. character counter:通过 counterEnabledcounterMaxLength 属性可以统计输入内容的字数,并显示在输入框右下角。

  4. Password visibility toggling:当输入框内容为密码类信息时,可以通过 passwordToggleEnabled 属性或者 setPasswordVisibilityToggleEnabled(boolean) 方法在输入框右侧 drawableRight 的位置显示一个切换按钮,控制输入内容的显示与隐藏。

这里我写了一个测试 Demo,layout 文件内容如下:

效果如图:





前面提到的 TextInputLayout 的四个功能在 Demo 中均有所体现。再补充几个值得注意的地方:

  1. 浮动 hint 、error 提示、字数提示和 EditText 的背景样式默认使用主题 style 中的 colorAccent 属性定义的颜色;

  2. 控制密码显示状态的切换按钮的图标默认呈黑色眼睛状,TextInputLayout 提供了一些属性供开发人员自由设置其颜色与形状。比如「Nick Butcher」大神在他的项目 plaid 中利用 path 给图标做出了一个很炫酷的切换动画效果,再加上文字和小黑点的切换效果,简直完美,如下图所示 (图片源自 Twitter):





具体代码实现过程,可以直接参考:Plaid - Animated DN password visibility toggle

TextInputEditText

  1. 使用 TextInputLayout 时,设置 EditText 的 drawable 图标时需要同时使用相对值 (start/end) 和 绝对值 (left/right),否则 drawable 存在显示兼容问题。

  2. 默认情况下,当设备处于横屏时,点击 EditText 输入框,会弹出一个新的输入界面并显示软键盘,即 「extract mode」(全屏模式),而不是在当前界面弹出软键盘。如果单独使用 EditText,进入「extract mode」并且在用户还没输入任何内容时,hint 信息会显示在输入框中。但是 EditText 和 TextInputLayout 一起使用时,hint 信息则不会显示。而 TextInputEditText 的出现刚好解决了这个问题。

TextInputEditText 是 AppCompatEditText (继承自 EditText) 的子类,源码很简单,只是重写 onCreateInputConnection 方法,做了一个 hint 信息的传递,就是为了在「extract mode」中显示 hint 信息:

使用时,只需要将 TextInputLayout 中的 EditText 替换成 TextInputEditText 控件即可,属性和 EditText 一样,没有什么其他特殊用法,我们看一下效果图。

TextInputLayout 与 EditText:





TextInputLayout 与 TextInputEditText:





备注:如果不想使用 EditText 的「extract mode」,添加 android:imeOptions="flagNoExtractUi" 属性即可。

特殊说明:经测试发现,在目前最新版本 25.0.0 的 design 包中,TextInputLayout 与 TextInputEditText 的组合使用不能实现「extract mode」显示 hint 功能,而在旧版本中能够实现,比如 24.1.1 版本。目测这是新版 Design 包的一个 Bug,期待下个版本的修复吧。

最后,附上「Android Material Design」系列文章的 Demo 地址:[MDStudySamples](https://github.com/Mike-bel/MDStudySamples),欢迎 Star。

相关推荐

jQuery VS AngularJS 你更钟爱哪个?

在这一次的Web开发教程中,我会尽力解答有关于jQuery和AngularJS的两个非常常见的问题,即jQuery和AngularJS之间的区别是什么?也就是说jQueryVSAngularJS?...

Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0

在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,在输入数据时,实时校验输入内容是否正确,失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。HTML代码...

如何在pbootCMS前台调用自定义表单?pbootCMS自定义调用代码示例

要在pbootCMS前台调用自定义表单,您需要在后台创建表单并为其添加字段,然后在前台模板文件中添加相关代码,如提交按钮和表单验证代码。您还可以自定义表单数据的存储位置、添加文件上传字段、日期选择器、...

编程技巧:Jquery实时验证,指定长度的「负小数」

为了保障【负小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【负小数】的方法。HTML代码<inputtype="text"class="forc...

一篇文章带你用jquery mobile设计颜色拾取器

【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...

编程技巧:Jquery实时验证,指定长度的「正小数」

为了保障【正小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【正小数】的方法。HTML做成方法<inputtype="text"class="fo...

jquery.validate检查数组全部验证

问题:html中有多个name[],每个参数都要进行验证是否为空,这个时候直接用required:true话,不能全部验证,只要这个数组中有一个有值就可以通过的。解决方法使用addmethod...

Vue进阶(幺叁肆):npm查看包版本信息

第一种方式npmviewjqueryversions这种方式可以查看npm服务器上所有的...

layui中使用lay-verify进行条件校验

一、layui的校验很简单,主要有以下步骤:1.在form表单内加上class="layui-form"2.在提交按钮上加上lay-submit3.在想要校验的标签,加上lay-...

jQuery是什么?如何使用? jquery是什么功能组件

jQuery于2006年1月由JohnResig在BarCampNYC首次发布。它目前由TimmyWilson领导,并由一组开发人员维护。jQuery是一个JavaScript库,它简化了客户...

django框架的表单form的理解和用法-9

表单呈现...

jquery对上传文件的检测判断 jquery实现文件上传

总体思路:在前端使用jquery对上传文件做部分初步的判断,验证通过的文件利用ajaxFileUpload上传到服务器端,并将文件的存储路径保存到数据库。<asp:FileUploadI...

Nodejs之MEAN栈开发(四)-- form验证及图片上传

这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能。开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R...

大数据开发基础之JAVA jquery 大数据java实战

上一篇我们讲解了JAVAscript的基础知识、特点及基本语法以及组成及基本用途,本期就给大家带来了JAVAweb的第二个知识点jquery,大数据开发基础之JAVAjquery,这是本篇文章的主要...

推荐四个开源的jQuery可视化表单设计器

jquery开源在线表单拖拉设计器formBuilder(推荐)jQueryformBuilder是一个开源的WEB在线html表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...

取消回复欢迎 发表评论: