Android中监听EditText文本输入

平时在做Android开发过程中经常要用到EditText,有时候可能需要监听你在TextView中输入的字数的状态和变化,以便于我们能做相应的提示和操作。我们可以通过下面的方式来实现。

  1. class EditChangedListener implements TextWatcher {  
  2.        private CharSequence temp;//监听前的文本  
  3.        private int editStart;//光标开始位置  
  4.        private int editEnd;//光标结束位置  
  5.        private final int charMaxNum = 10;  
  6.   
  7.        @Override  
  8.        public void beforeTextChanged(CharSequence s, int start, int count, int after) {  
  9.            if (DEBUG)  
  10.                Log.i(TAG, "输入文本之前的状态");  
  11.            temp = s;  
  12.        }  
  13.   
  14.        @Override  
  15.        public void onTextChanged(CharSequence s, int start, int before, int count) {  
  16.            if (DEBUG)  
  17.                Log.i(TAG, "输入文字中的状态,count是一次性输入字符数");  
  18.            mTvAvailableCharNum.setText("还能输入" + (charMaxNum - s.length()) + "字符");  
  19.   
  20.        }  
  21.   
  22.        @Override  
  23.        public void afterTextChanged(Editable s) {  
  24.            if (DEBUG)  
  25.                Log.i(TAG, "输入文字后的状态");  
  26.            /** 得到光标开始和结束位置 ,超过最大数后记录刚超出的数字索引进行控制 */  
  27.            editStart = mEditTextMsg.getSelectionStart();  
  28.            editEnd = mEditTextMsg.getSelectionEnd();  
  29.            if (temp.length() > charMaxNum) {  
  30.                Toast.makeText(getApplicationContext(), "你输入的字数已经超过了限制!", Toast.LENGTH_LONG).show();  
  31.                s.delete(editStart - 1, editEnd);  
  32.                int tempSelection = editStart;  
  33.                mEditTextMsg.setText(s);  
  34.                mEditTextMsg.setSelection(tempSelection);  
  35.            }  
  36.   
  37.        }  
  38.    };  
 class EditChangedListener implements TextWatcher {
        private CharSequence temp;//监听前的文本
        private int editStart;//光标开始位置
        private int editEnd;//光标结束位置
        private final int charMaxNum = 10;

        @Override
        public void beforeTextChanged(CharSequence s, int start, int count, int after) {
            if (DEBUG)
                Log.i(TAG, "输入文本之前的状态");
            temp = s;
        }

        @Override
        public void onTextChanged(CharSequence s, int start, int before, int count) {
            if (DEBUG)
                Log.i(TAG, "输入文字中的状态,count是一次性输入字符数");
            mTvAvailableCharNum.setText("还能输入" + (charMaxNum - s.length()) + "字符");

        }

        @Override
        public void afterTextChanged(Editable s) {
            if (DEBUG)
                Log.i(TAG, "输入文字后的状态");
            /** 得到光标开始和结束位置 ,超过最大数后记录刚超出的数字索引进行控制 */
            editStart = mEditTextMsg.getSelectionStart();
            editEnd = mEditTextMsg.getSelectionEnd();
            if (temp.length() > charMaxNum) {
                Toast.makeText(getApplicationContext(), "你输入的字数已经超过了限制!", Toast.LENGTH_LONG).show();
                s.delete(editStart - 1, editEnd);
                int tempSelection = editStart;
                mEditTextMsg.setText(s);
                mEditTextMsg.setSelection(tempSelection);
            }

        }
    };
加上监听的事件。
  1. mEditTextMsg.addTextChangedListener(new EditChangedListener());  
 mEditTextMsg.addTextChangedListener(new EditChangedListener());
效果图:


。。。



发布了21 篇原创文章 · 获赞 11 · 访问量 11万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章