【Android进阶学习】监听EditText的变化

简介:

之前博客上的有关EditText的文章,只是介绍EditText的一些最基本的用法,这次来深入学习一下EditText。

监听EditText的变化

使用EditText的addTextChangedListener(TextWatcher watcher)方法对EditText实现监听,TextWatcher是一个接口类,所以必须实现TextWatcher里的抽象方法:

 当EditText里面的内容有变化的时候,触发TextChangedListener事件,就会调用TextWatcher里面的抽象方法。

MainActivity.java


 
 
  1. package com.lingdududu.watcher;  
  2.  
  3. import android.app.Activity;  
  4. import android.app.AlertDialog;  
  5. import android.content.DialogInterface;  
  6. import android.os.Bundle;  
  7. import android.text.Editable;  
  8. import android.text.TextWatcher;  
  9. import android.util.Log;  
  10. import android.widget.EditText;  
  11.  
  12. public class MainActivity extends Activity {  
  13.     private EditText text;  
  14.     String str;  
  15.     @Override 
  16.     public void onCreate(Bundle savedInstanceState) {  
  17.         super.onCreate(savedInstanceState);  
  18.         setContentView(R.layout.main);  
  19.           
  20.         text = (EditText)findViewById(R.id.text);  
  21.         text.addTextChangedListener(textWatcher);  
  22.     }  
  23.       
  24.     private TextWatcher textWatcher = new TextWatcher() {  
  25.           
  26.         @Override    
  27.         public void afterTextChanged(Editable s) {     
  28.             // TODO Auto-generated method stub     
  29.             Log.d("TAG","afterTextChanged--------------->");   
  30.         }   
  31.           
  32.         @Override 
  33.         public void beforeTextChanged(CharSequence s, int start, int count,  
  34.                 int after) {  
  35.             // TODO Auto-generated method stub  
  36.             Log.d("TAG","beforeTextChanged--------------->");  
  37.         }  
  38.  
  39.          @Override    
  40.         public void onTextChanged(CharSequence s, int start, int before,     
  41.                 int count) {     
  42.             Log.d("TAG","onTextChanged--------------->");    
  43.             str = text.getText().toString();  
  44.             try {  
  45.                 //if ((heighText.getText().toString())!=null)   
  46.                 Integer.parseInt(str);  
  47.                   
  48.             } catch (Exception e) {  
  49.                 // TODO: handle exception  
  50.                 showDialog();  
  51.             }  
  52.                               
  53.         }                    
  54.     };  
  55.  
  56.     private void showDialog(){  
  57.         AlertDialog dialog;  
  58.         AlertDialog.Builder builder = new AlertDialog.Builder(MainActivity.this);  
  59.         builder.setTitle("消息").setIcon(android.R.drawable.stat_notify_error);  
  60.         builder.setMessage("你输出的整型数字有误,请改正");  
  61.         builder.setPositiveButton("确定"new DialogInterface.OnClickListener(){  
  62.             @Override 
  63.             public void onClick(DialogInterface dialog, int which) {  
  64.                 // TODO Auto-generated method stub  
  65.                   
  66.             }                     
  67.         });  
  68.         dialog = builder.create();  
  69.         dialog.show();  
  70.     }  

 main.xml


 
 
  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  3.     android:orientation="vertical" 
  4.     android:layout_width="fill_parent" 
  5.     android:layout_height="fill_parent" 
  6.     > 
  7. <TextView    
  8.     android:layout_width="fill_parent"   
  9.     android:layout_height="wrap_content"   
  10.     android:text="请输入整型数字" 
  11.     /> 
  12. <EditText   
  13.     android:id="@+id/text" 
  14.     android:layout_width="fill_parent"   
  15.     android:layout_height="wrap_content"   
  16.     /> 
  17. </LinearLayout> 

  效果图:

当我们在输入框输入不是整型数字的时候,会立刻弹出输入框,提示你改正

在LogCat查看调用这些方法的顺序:

beforeTextChanged-->onTextChanged-->onTextChanged

第二个例子实现了提示文本框还能输入多少个字符的功能


 
 
  1. package com.lingdududu.test;  
  2.  
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5. import android.text.Editable;  
  6. import android.text.TextWatcher;  
  7. import android.view.View;  
  8. import android.widget.Button;  
  9. import android.widget.EditText;  
  10. import android.widget.TextView;  
  11.  
  12. public class MainActivity extends Activity {  
  13.  private Button clearBtn;  
  14.  private EditText et;  
  15.  private TextView tv;  
  16.  final int MAX_LENGTH = 20;  
  17.  int Rest_Length = MAX_LENGTH;  
  18.     @Override 
  19.     public void onCreate(Bundle savedInstanceState) {  
  20.         super.onCreate(savedInstanceState);  
  21.         setContentView(R.layout.main);  
  22.         tv =(TextView)findViewById(R.id.tv);  
  23.         et = (EditText)findViewById(R.id.et);  
  24.           
  25.         clearBtn = (Button)findViewById(R.id.btn);  
  26.  
  27.         et.addTextChangedListener(new TextWatcher() {  
  28.                           
  29.             @Override 
  30.             public void beforeTextChanged(CharSequence s, int start, int count,  
  31.                     int after) {  
  32.                 tv.setText("还能输入"+Rest_Length+"个字");              
  33.             }  
  34.                           
  35.             @Override 
  36.             public void afterTextChanged(Editable s) {  
  37.                 tv.setText("还能输入"+Rest_Length+"个字");  
  38.             }  
  39.               
  40.             @Override 
  41.             public void onTextChanged(CharSequence s, int start, int before, int count) {  
  42.                 if(Rest_Length>0){  
  43.                     Rest_Length = MAX_LENGTH - et.getText().length();  
  44.                 }  
  45.             }             
  46.         });  
  47.         
  48.         clearBtn.setOnClickListener(new Button.OnClickListener() {        
  49.             @Override 
  50.             public void onClick(View v) {  
  51.                 et.setText("");  
  52.                 Rest_Length = MAX_LENGTH;  
  53.             }  
  54.         });  
  55.     }  
  56.  } 

效果图:



本文转自 lingdududu 51CTO博客,原文链接: 

http://blog.51cto.com/liangruijun/729505


相关文章
|
2月前
|
Java Maven 开发工具
第一个安卓项目 | 中国象棋demo学习
本文是作者关于其第一个安卓项目——中国象棋demo的学习记录,展示了demo的运行结果、爬坑记录以及参考资料,包括解决Android Studio和maven相关问题的方法。
第一个安卓项目 | 中国象棋demo学习
|
6月前
|
API Android开发
Android高手进阶教程(十五)之---通过Location获取Address的使用!
Android高手进阶教程(十五)之---通过Location获取Address的使用!
61 1
|
27天前
|
Web App开发 编解码 视频直播
视频直播技术干货(十二):从入门到放弃,快速学习Android端直播技术
本文详细介绍了Android端直播技术的全貌,涵盖了从实时音视频采集、编码、传输到解码与播放的各个环节。文章还探讨了直播中音视频同步、编解码器选择、传输协议以及直播延迟优化等关键问题。希望本文能为你提供有关Andriod端直播技术的深入理解和实践指导。
38 0
|
6月前
|
监控 Unix 应用服务中间件
Android-音视频学习系列-(八)基于-Nginx-搭建(rtmp、http)直播服务器
Android-音视频学习系列-(八)基于-Nginx-搭建(rtmp、http)直播服务器
|
2月前
|
Android开发
Android学习 —— 测试init.rc中的条件触发的处理顺序
Android学习 —— 测试init.rc中的条件触发的处理顺序
|
3月前
|
搜索推荐 Android开发
学习AOSP安卓系统源代码,需要什么样的电脑?不同配置的电脑,其编译时间有多大差距?
本文分享了不同价位电脑配置对于编译AOSP安卓系统源代码的影响,提供了从6000元到更高价位的电脑配置实例,并比较了它们的编译时间,以供学习AOSP源代码时电脑配置选择的参考。
216 0
学习AOSP安卓系统源代码,需要什么样的电脑?不同配置的电脑,其编译时间有多大差距?
|
4月前
|
监控 Android开发 开发者
Android经典面试题之实战经验分享:如何简单实现App的前后台监听判断
本文介绍在Android中判断应用前后台状态的两种方法:`ActivityLifecycleCallbacks`和`ProcessLifecycleOwner`。前者提供精细控制,适用于需针对每个Activity处理的场景;后者简化前后台检测,适用于多数应用。两者各有优劣:`ActivityLifecycleCallbacks`更精确但复杂度高;`ProcessLifecycleOwner`更简便但可能在极端场景下略有差异。根据应用需求选择合适方法。
39 2
|
4月前
|
API Android开发
Android 监听Notification 被清除实例代码
Android 监听Notification 被清除实例代码
|
5月前
|
Android开发
技术经验分享:Android前后台切换的监听
技术经验分享:Android前后台切换的监听
78 2
|
5月前
|
XML Android开发 数据格式
37. 【Android教程】基于监听的事件处理机制
37. 【Android教程】基于监听的事件处理机制
80 2