EditText入力制限およびワード数制限に関する質問

2687 ワード

EditText入力制限およびワード数制限に関する質問
最近奇抜な需要に出会って、テキストの入力枠は内容を入力する時、中国語、英語と数字しか入力できなくて、その上入力の字数に対して制限をしなければならなくて、中国語は最大5個で、英語の数字は最大10個で、1つのタイプだけは比較的にコントロールしやすいですが、もし中国語と英語が混ざっているならば以下が解決策だと判断しにくいです:
editText.addTextChangedListener(new TextWatcher() {

            String imputtxt;
            String str;
            @Override
            public void beforeTextChanged(CharSequence s, int start, int count, int after) {

            }

            @Override
            public void onTextChanged(CharSequence s, int start, int before, int count) {
                if (!TextUtils.isEmpty(s)){
                    remove_text.setVisibility(View.VISIBLE);
                }else if (TextUtils.isEmpty(s)){
                    remove_text.setVisibility(View.GONE);
                }
                imputtxt = editText.getText().toString();
                 str = stringFilter(imputtxt);
            }
            @Override
            public void afterTextChanged(Editable s) {

                if (!TextUtils.isEmpty(str)){
                    String limtxt = getLimitSubstring(str);
                    if (!TextUtils.isEmpty(limtxt)){
                        if (!limtxt.equals(imputtxt)){
                            editText.setText(limtxt);
                            editText.setSelection(limtxt.length());
                        }
                    }
                }

            }
        });  

私は入力リスニングTextWatcherを設定してonchangeの時にテキストの入力のタイプを検査して正則を利用して、afterchangeの時に字数の長さを制限します
//      
 public static String stringFilter(String str)throws PatternSyntaxException {
        //       、     
        String   regEx  =  "[^a-zA-Z0-9\u4E00-\u9FA5]";
        Pattern p   =   Pattern.compile(regEx);
        Matcher m   =   p.matcher(str);
        return   m.replaceAll("").trim();
    }
//      
 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 > 10) {
                return inputStr.substring(0, i);
            }
        }
        return inputStr;
    }