AndroID的EditText字数检测和限制解决办法
控件EditText在AndroID布局中经常用到,对EditText中输入的内容也经常需要进行限制,我们可以通过TextWatcher去观察输入框中输入的内容。
public class TextWatcherDemo extends Activity { private TextVIEw mTextVIEw; private EditText mEditText; /** Called when the activity is first created. */ @OverrIDe public voID onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentVIEw(R.layout.main); mTextVIEw = (TextVIEw)findVIEwByID(R.ID.tv); mEditText = (EditText)findVIEwByID(R.ID.ET); mEditText.addTextChangedListener(mTextWatcher); } TextWatcher mTextWatcher = new TextWatcher() { private CharSequence temp; private int editStart ; private int editEnd ; @OverrIDe public voID beforeTextChanged(CharSequence s,int arg1,int arg2,int arg3) { temp = s; } @OverrIDe public voID onTextChanged(CharSequence s,int arg3) { mTextVIEw.setText(s); } @OverrIDe public voID afterTextChanged(Editable s) { editStart = mEditText.getSelectionStart(); editEnd = mEditText.getSelectionEnd(); if (temp.length() > 10) { Toast.makeText(TextWatcherDemo.this,"你输入的字数已经超过了限制!",Toast.LENGTH_SHORT) .show(); s.delete(editStart-1,editEnd); int tempSelection = editStart; mEditText.setText(s); mEditText.setSelection(tempSelection); } } };}
关于androID中的编码
result.getBytes() 是 new String(byte[]) 的逆过程。
前面那个是 String->byte[],后面那个是 byte[] -> String.
在Java运行时的时候,String与String是没有区别的都是以2字节的unicode的形式存在内存中,所谓编码,是针对把String转换成 byte[]而言的。比如我可以把 "abc" 通过 utf-8转换成了一串数据 A ,也可以通过gb2312转换成另一串数据 B,这个过程就是 String.getBytes(),比如 "abc".getBytes("utf-8")得到A,"abc".getBytes("gb2312")得到B。如果是"abc".getBytes(),就不知道用的什么编码了,这和平台相关。
那如何从A串或者 B串重新得到String呢,那就是 new String(A,"utf-8") 或者 new String(B,"gb2312")。因为A是从utf-8转换得到的,所以用utf-8转回String,如果new String(A,"gb2312"), 那么其中的中文就是乱码。
下面列出各编码格式下字符的字节数:
英文字母:A
字节数:1;编码:GB2312
字节数:1;编码:GBK
字节数:1;编码:GB18030
字节数:1;编码:ISO-8859-1
字节数:1;编码:UTF-8
字节数:4;编码:UTF-16
字节数:2;编码:UTF-16BE
字节数:2;编码:UTF-16LE
中文汉字:人
字节数:2;编码:GB2312
字节数:2;编码:GBK
字节数:2;编码:GB18030
字节数:1;编码:ISO-8859-1
字节数:3;编码:UTF-8
字节数:4;编码:UTF-16
字节数:2;编码:UTF-16BE
字节数:2;编码:UTF-16LE
根据上面的结果,我们可以通过每个字符的UTF-8字节数来判断是中文还是英文。
工作中遇到一个需求,是要限制EditText中输入的字符数的个数,中文15个,英文30个,中英文会交叉输入,就可以用上面的条件来判断。
具体的实现如下:
private TextWatcher minputTextWatcher = new TextWatcher() { private String temp; private int editStart; private int editEnd; @OverrIDe public voID onTextChanged(CharSequence s,int start,int before,int count) { temp = s.toString(); } @OverrIDe public voID beforeTextChanged(CharSequence s,int count,int after) { } @OverrIDe public voID afterTextChanged(Editable s) { mMainHandler.removeMessages(HD_MSG_UPDATE_HINT); mCurrentHint = s.toString().trim(); if (!TextUtils.isEmpty(temp)) { String limitSubstring = getlimitSubstring(temp); if (!TextUtils.isEmpty(limitSubstring)) { if (!limitSubstring.equals(temp)) { // Toast.makeText(activity,"字数已超过限制",// Toast.LENGTH_SHORT).show(); mEdtinput.setText(limitSubstring); mEdtinput.setSelection(limitSubstring.length()); } } } mMainHandler.sendEmptyMessageDelayed(HD_MSG_UPDATE_HINT,HINT_UPDATE_DaleY_TIME); } };
private String getlimitSubstring(String inputStr) { int orignLen = inputStr.length(); int resultLen = 0; String temp = null; for (int i = 0; i < orignLen; i++) { temp = inputStr.substring(i,i + 1); try {// 3 bytes to indicate chinese word,1 byte to indicate english // word,in utf-8 encode if (temp.getBytes("utf-8").length == 3) { resultLen += 2; } else { resultLen++; } } catch (UnsupportedEnCodingException e) { e.printstacktrace(); } if (resultLen > 30) { return inputStr.substring(0,i); } } return inputStr; }
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
总结以上是内存溢出为你收集整理的Android的EditText字数检测和限制解决办法全部内容,希望文章能够帮你解决Android的EditText字数检测和限制解决办法所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)