安卓TextinputLayout使用方法

本文介绍了如何在Android应用中使用TextinputLayout,包括配合EditText的功能、提示文字的显示、错误提示设置、密码框的实现以及基本属性设置。还展示了如何在XML布局中使用这些组件并处理用户输入验证。
摘要由CSDN通过智能技术生成

在这个页面中直接找到design这个依赖,点击后再点击这两个窗口上的OK按钮,等待编译完成就完成导入了!

(可能版本不一样,导入即可)


TextinputLayout


TextinputLayout在Design下,可以配合EditText或者EditText的子类使用,通常可以用来提示错误信息,或者显示提示字数限制等一些操作,还可以用来做密码框密码显示!这些使用,只需要在属于TextinputLayout的标签内加入相应的属性设置对应的事件即可,先来看下最简单的效果

当在这个文本框输入信息的时候,提示文字会自动向上移动;

第一个和第二个文本框使用了TextinputLayout,第三个未普通的EditText,我设置了显示字数长度和密码框的显示,看下我的布局文件

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

xmlns:app=“http://schemas.android.com/apk/res-auto”

xmlns:tools=“http://schemas.android.com/tools”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:orientation=“vertical”

android:paddingLeft=“20dp”

android:paddingRight=“20dp”

tools:context=“.MainActivity”>

<android.support.design.widget.TextInputLayout

android:id=“@+id/username”

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:layout_marginTop=“20dp”

android:hint=“输入用户名(TextInputLayout)”

app:counterEnabled=“true”

app:counterMaxLength=“6”

app:errorEnabled=“true”>

<EditText

android:layout_width=“match_parent”

android:layout_height=“wrap_content” />

</android.support.design.widget.TextInputLayout>

<android.support.design.widget.TextInputLayout

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:layout_marginTop=“20dp”

android:hint=“请输入密码(TextInputLayout)”

app:passwordToggleEnabled=“true”>

<EditText

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:inputType=“textPassword” />

</android.support.design.widget.TextInputLayout>

<EditText

android:layout_width=“match_parent”

android:layout_height=“wrap_content”

android:layout_marginTop=“40dp”

android:hint=“请输入手机号(普通的EditText)” />

TextinputLayout标签基本属性


| 属性 | 详细介绍 |

| — | — |

|  android:hint=" " | 提示输入内容 |

| app:hintEnabled=“true” | 是否显示提示(hint),默认为true |

| app:hintAnimationEnabled=“true” | 设置动画,是否有动画,默认为true |

| app:hintTextAppearance=" " | 提示文本的样式 |

|

app:errorEnabled=“true”

| 错误提示是否为显示 |

| app:errorTextAppearance=" " | 设置错误提示的样式 |

|

app:passwordToggleEnabled=“true”

| 设置是否为可显示密码(上图右边的小眼睛) |

| app:passwordToggleDrawable=" " | 定义显示密码按钮的图标 |

| app:passwordToggleTintMode=" " | 设置显示密码按钮的模式(screen、src_atop、multiply、src_in、src_over) |

| app:passwordToggleTint=" " | 为显示密码按钮设置颜色 |

| app:counterEnabled=" " | 是否显示字数限制(如图第一个文本框右下角) |

| app:counterMaxLength=" " | 最大的输入长度 |

|

app:counterEnabled=" "

| 是否显示长度限制(true、false) |

| app:counterTextAppearance=" " | 长度提示的样式 |

加入事件(java篇)


实现目标:点击注册按钮不符合要求后输入框下提示字数不符合要求。(在这里只对用户名做出了限制,举一反三即可)

》》》AndroidStudio快速实例化-插件安装与使用《《《点击进入

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

private TextInputLayout username;

private TextInputLayout pasword;

private EditText phone_number;

private Button register;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

initView();

}

private void initView() {

username = (TextInputLayout) findViewById(R.id.username);

pasword = (TextInputLayout) findViewById(R.id.pasword);

phone_number = (EditText) findViewById(R.id.phone_number);

register = (Button) findViewById(R.id.register);

register.setOnClickListener(this);

}

@Override

public void onClick(View v) {

switch (v.getId()) {

case R.id.register:

submit();

//判断字数,设置事件

username.setErrorEnabled(true);//提示信息设置为可见

username.setError(“字数不符合要求”);

if (username.getEditText().getText().length() == 0 || username.getEditText().getText().length() > 6) {

username.setError(“字数不符合要求”);

} else {

username.setErrorEnabled(false);//提示信息设置为不可见

}

break;

}

}

//判断手机号输入是否为空

private void submit() {

// validate

String number = phone_number.getText().toString().trim();

if (TextUtils.isEmpty(number)) {

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)

小结

有了这么多优秀的开发工具,可以做出更高质量的Android应用。

当然了,“打铁还需自身硬”,想要写出优秀的代码,最重要的一点还是自身的技术水平,不然用再好的工具也不能发挥出它的全部实力。

在这里我也分享一份大佬自己收录整理的Android学习PDF+架构视频+面试文档+源码笔记,还有高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料这些都是我闲暇还会反复翻阅的精品资料。在脑图中,每个知识点专题都配有相对应的实战项目,可以有效的帮助大家掌握知识点。

总之也是在这里帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!

打铁还需自身硬**”,想要写出优秀的代码,最重要的一点还是自身的技术水平,不然用再好的工具也不能发挥出它的全部实力。

在这里我也分享一份大佬自己收录整理的Android学习PDF+架构视频+面试文档+源码笔记,还有高级架构技术进阶脑图、Android开发面试专题资料,高级进阶架构资料这些都是我闲暇还会反复翻阅的精品资料。在脑图中,每个知识点专题都配有相对应的实战项目,可以有效的帮助大家掌握知识点。

总之也是在这里帮助大家学习提升进阶,也节省大家在网上搜索资料的时间来学习,也可以分享给身边好友一起学习

《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
  • 14
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值