【Android学习】自定义文本框和输入监听

实现功能

以上代码可实现功能:

1 自定义文本框样式

  1. 文本框触发形式转变

  2. 文本框输入长度监听,达到最大长度关闭软键盘

  3. password框触发检测phone框内容

1. drawable自定义形状

我创建了**editor_focus.xml 和 editor_unfocus.xml,**两者仅边界颜色不同

editor_focus.xml代码

java 复制代码
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <!--    指定文本框内部颜色-->
    <solid android:color="#ffffff" />
    <!--    声明边界线颜色-->
    <stroke
        android:width="1dp"
        android:color="#0000ff" />
    <!--    使用圆角-->
    <corners android:radius="5dp" />
    <!--    指定形状四个方向的间距-->
    <padding
        android:bottom="2dp"
        android:left="2dp"
        android:right="2dp"
        android:top="2dp" />

</shape>

editor_unfocus.xml代码

java 复制代码
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
    <!--    指定文本框内部颜色-->
    <solid android:color="#ffffff" />
    <!--    声明边界线颜色-->
    <stroke
        android:width="1dp"
        android:color="#888888" />
    <!--    使用圆角-->
    <corners android:radius="5dp" />
    <!--    指定形状四个方向的间距-->
    <padding
        android:bottom="2dp"
        android:left="2dp"
        android:right="2dp"
        android:top="2dp" />

</shape>

2. drawable自定义selector

selector的作用为不同的触发事件,编辑框有不同的形式。创建过程和上述shape创建过程类似,只是将shape改为 selector即可。

java 复制代码
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:drawable="@drawable/editor_focus" android:state_focused="true" />
    <item android:drawable="@drawable/editor_unfocus" />
</selector>

3. 创建 empty Activity

4.设置layout.xml

java 复制代码
<?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">

    <EditText
        android:id="@+id/et_phone"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:background="@drawable/editor_selector"
        android:hint="请输入电话号码"
        android:maxLength="11"
        android:inputType="text"
        android:layout_marginTop="5dp"
        />

    <EditText
        android:id="@+id/et_password"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:background="@drawable/editor_selector"
        android:hint="请输入密码"
        android:maxLength="6"
        android:inputType="textPassword"
        android:layout_marginTop="5dp"
        />

</LinearLayout>

5.Java代码

Activity

java 复制代码
package com.example.learn;

import androidx.appcompat.app.AppCompatActivity;

import android.os.Bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.View;
import android.widget.EditText;
import android.widget.Toast;

import com.example.learn.utils.ViewUtil;

public class EditerHideActivity extends AppCompatActivity implements View.OnFocusChangeListener{
    private EditText et_phone;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_editer_hide);
        et_phone = findViewById(R.id.et_phone);
        EditText et_password = findViewById(R.id.et_password);
        //设置Text changeListener
        et_phone.addTextChangedListener(new HideTextWatch(et_phone,11));
        et_password.addTextChangedListener(new HideTextWatch(et_password,6));
        //设置password框focus时对phone自动检测
        et_password.setOnFocusChangeListener(this);
    }

    @Override
    public void onFocusChange(View view, boolean b) {
        //如果获取聚焦
        if(b){
            String str = et_phone.getText().toString();
            if(!"".equals(str) && str.length()<11){
                et_phone.requestFocus();
                Toast.makeText(this,"电话号码不足11位",Toast.LENGTH_SHORT).show();
            }
        }
    }

    private class HideTextWatch implements TextWatcher {
        private EditText mView;
        private int maxLen;
        public HideTextWatch(EditText v, int len) {
            this.mView = v;
            this.maxLen=len;
        }

        @Override
        public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) {

        }

        @Override
        public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {

        }

        @Override
        public void afterTextChanged(Editable editable) {
            //获取文本框输入的文本
            String str = editable.toString();
            //判断是否输入的字符串与maxLen一致
            //一致则关软键盘
            if(str.length() == this.maxLen){
                //EditerHideActivity.this 外部类的 activity
                //this:HideTextWatch
                ViewUtil.hideKeyboard(EditerHideActivity.this,mView);
            }
        }
    }
}

Util

java 复制代码
package com.example.learn.utils;

import android.app.Activity;
import android.content.Context;
import android.view.View;
import android.view.inputmethod.InputMethodManager;

public class ViewUtil {
    //当输入达到对应长度后 隐藏键盘
    public static void hideKeyboard(Activity act, View v){
        //从系统服务中获取输入法管理器
        InputMethodManager im = (InputMethodManager) act.getSystemService(Context.INPUT_METHOD_SERVICE);
        //将系统输入软件盘隐藏
        im.hideSoftInputFromWindow(v.getWindowToken(),0);
    }
}
相关推荐
机智的叉烧11 分钟前
前沿重器[57] | sigir24:大模型推荐系统的文本ID对齐学习
人工智能·学习·机器学习
量子-Alex1 小时前
【多模态聚类】用于无标记视频自监督学习的多模态聚类网络
学习·音视频·聚类
吉大一菜鸡1 小时前
FPGA学习(基于小梅哥Xilinx FPGA)学习笔记
笔记·学习·fpga开发
C4rpeDime2 小时前
自建MD5解密平台-续
android
鲤籽鲲4 小时前
C# Random 随机数 全面解析
android·java·c#
爱吃西瓜的小菜鸡4 小时前
【C语言】判断回文
c语言·学习·算法
小A1594 小时前
STM32完全学习——SPI接口的FLASH(DMA模式)
stm32·嵌入式硬件·学习
岁岁岁平安5 小时前
spring学习(spring-DI(字符串或对象引用注入、集合注入)(XML配置))
java·学习·spring·依赖注入·集合注入·基本数据类型注入·引用数据类型注入
武昌库里写JAVA5 小时前
Java成长之路(一)--SpringBoot基础学习--SpringBoot代码测试
java·开发语言·spring boot·学习·课程设计
qq_589568105 小时前
数据可视化echarts学习笔记
学习·信息可视化·echarts