The method setFilters(InputFilter[]) in the type Editable is not applicable

简介:

解决办法:


EditText mEdit = (EditText)findViewById(R.id.mEdit);    	
InputFilter[] filters = {new AdnNameLengthFilter()};
mEdit.setFilters(filters);
public static class AdnNameLengthFilter implements InputFilter
	{
		private int nMax;

		public  CharSequence filter (CharSequence source, int start, int end, Spanned dest, int dstart, int dend)
		{
			Log.w("Android_12", "source("+start+","+end+")="+source+",dest("+dstart+","+dend+")="+dest);

			if(isChinese(dest.toString())|| isChinese(source.toString()))
			{
				nMax = LENGTH_ZNAME;
			}else
			{
				nMax =LENGTH_ENAME;
			}
			
	            int keep = nMax - (dest.length() - (dend - dstart));

	            if (keep <= 0) {
	                return "";
	            } else if (keep >= end - start) {
	                return null; // keep original
	            } else {
	                return source.subSequence(start, start + keep);
	            }
        
		}
	}

其中的isChinese函数是判断是否字符串中是否包含中文字符,具体实现方法就不再赘述了。

LENGTH_ZNAME : 是中文模式下允许输入的最大字符数。

LENGTH_ENAME:是纯英文模式下允许输入的最大字符数。

android怎样判断EditText输入的值是数字还是汉字 ,并限定输入字数
2011-11-25 10:37

判断汉字的方法private boolean isChinese(char c) {
        Character.UnicodeBlock ub = Character.UnicodeBlock.of(c);
        if (ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS
             || ub == Character.UnicodeBlock.CJK_COMPATIBILITY_IDEOGRAPHS
            || ub == Character.UnicodeBlock.CJK_UNIFIED_IDEOGRAPHS_EXTENSION_A
            || ub == Character.UnicodeBlock.GENERAL_PUNCTUATION
            || ub == Character.UnicodeBlock.CJK_SYMBOLS_AND_PUNCTUATION
            || ub == Character.UnicodeBlock.HALFWIDTH_AND_FULLWIDTH_FORMS) {
            return true;
        }
        return false;
    }

数字就根据unicode的范围判断吧!

 

方法一:利用TextWatcher


editText.addTextChangedListener(new TextWatcher() {   
           private CharSequence temp;   
           private boolean isEdit = true;   
           private int selectionStart ;   
           private int selectionEnd ;   
           @Override  
           public void beforeTextChanged(CharSequence s, int arg1, int arg2,   
                   int arg3) {   
               temp = s;   
           }   
              
           @Override  
           public void onTextChanged(CharSequence s, int arg1, int arg2,   
                   int arg3) {   
           }   
              
           @Override  
           public void afterTextChanged(Editable s) {   
                selectionStart = editText.getSelectionStart();   
               selectionEnd = editText.getSelectionEnd();   
               Log.i("gongbiao1",""+selectionStart);   
               if (temp.length() > Constant.TEXT_MAX) {   
                   Toast.makeText(KaguHomeActivity.this,   
                           R.string.edit_content_limit, Toast.LENGTH_SHORT)   
                           .show();   
                   s.delete(selectionStart-1, selectionEnd);   
                   int tempSelection = selectionStart;   
                   editText.setText(s);   
                   editText.setSelection(tempSelection);   
               }   
           }   
  
  
       }); 

 private TextWatcher mTextWatcher = new TextWatcher(){
  Toast mToast = null;
  public void beforeTextChanged(CharSequence s, int start, 
    int count,int after) {
  }

  public void onTextChanged(CharSequence s, int start, 
    int before,int count) {
  }
  
  public void afterTextChanged(Editable s) {
   int nSelStart = 0;
   int nSelEnd = 0;
   boolean nOverMaxLength = false;
   
   nSelStart = mEditText.getSelectionStart();
   nSelEnd   = mEditText.getSelectionEnd();
   
   nOverMaxLength = (s.length() > Constants.MAX_TEXT_INPUT_LENGTH) ? true : false;
   if(nOverMaxLength){
    if(null == mToast){
     mToast = Toast.makeText(mContext, 
       R.string.IDS_MSG_TEXT_OVER_MAXLENGTH, 
       Toast.LENGTH_SHORT);
    }
    mToast.show();
    
    s.delete(nSelStart - 1, nSelEnd);

    mEditText.setTextKeepState(s);//请读者注意这一行,保持光标原先的位置,而 mEditText.setText(s)会让光标跑到最前面,

                                                     //就算是再加mEditText.setSelection(nSelStart) 也不起作用
    }
  }
 };

方法二:利用InputFilter

    


editText.setFilters(new InputFilter[]{new InputFilter.LengthFilter(100)});  //其中100最大输入字数 

editText.setFilters(new InputFilter[]{new InputFilter.LengthFilter(100)});  //其中100最大输入字数

方法三:在XML中设定

Xml代码 
<EditText  
    .   
    .   
    .   
    Android:maxLength="100"  
/> 

 

=========================================================

方法二:
         利用EditText可以设置filter的特性,自定义一个LengthFilter,当输入字数超过限制时 ,做出自定义的提示
          // 输入框限制输入字数
        InputFilter[] filters = new InputFilter[1];
        filters[0] = new InputFilter.LengthFilter(Constant.TEXT_MAX) {
            @Override
            public CharSequence filter(CharSequence source, int start, int end,
                    Spanned dest, int dstart, int dend) {
                if (source.length() > 0 && dest.length() == Constant.TEXT_MAX) {
                    if ((System.currentTimeMillis() - toastTime) > interval) {
                        toastTime = System.currentTimeMillis();
                        Toast
                                .makeText(KaguHomeActivity.this,
                                        R.string.edit_content_limit,
                                        Toast.LENGTH_SHORT).show();
                    }
                }
                if (dest.toString().equals(
                        getResources().getString(R.string.input_default_txt))) {
                    Bundle data = new Bundle();
                    data.putCharSequence("source", source);
                    Message message = textHandler.obtainMessage();
                    message.setData(data);
                    message.sendToTarget();
                }

                return super.filter(source, start, end, dest, dstart, dend);
            }
        };
        editText.setFilters(filters);
private Handler textHandler = new Handler() {
        @Override
        public void handleMessage(Message msg) {

            Bundle data = msg.getData();
            CharSequence source = data.getCharSequence("source");
            editText.setTextColor(Color.BLACK);
            editText.setText(source);
            editText.setSelection(source.length());
        }
    };


相关文章
|
9月前
|
人工智能 弹性计算 运维
操作系统智能助手OS Copilot新功能 评测
作为一名游戏开发工程师,我近期对阿里云Copilot进行了详细评测。Copilot支持多种Linux系统,具备完整的思维链推理能力,能处理复杂任务,大幅减轻运维工作量。它覆盖了大部分常用命令和参数,适合中高级运维工程师。虽然存在一些缺陷,但其在代码解读、错误分析等方面表现出色,极大提升了工作效率。强烈推荐有运维需求的用户使用Copilot,未来运维离不开它。 附上Copilot文档链接:[点击查看](https://help.aliyun.com/zh/alinux/user-guide/instructions-for-os-copilot)
199 26
|
存储 容灾 Linux
服务器备份
服务器备份
378 2
《QT从基础到进阶·二十六》绘制多个图形项(QGraphicsRectItem,QGraphicsLineItem,QGraphicsPolygonItem)
《QT从基础到进阶·二十六》绘制多个图形项(QGraphicsRectItem,QGraphicsLineItem,QGraphicsPolygonItem)
446 0
|
存储 分布式计算 大数据
惊了!大数据时代来袭,传统数据处理OUT了?创新应用让你眼界大开,看完这篇秒变专家!
【8月更文挑战第6天】在数据爆炸的时代,高效利用大数据成为关键挑战与机遇。传统数据处理手段难以胜任现今海量数据的需求。新兴的大数据技术,如HDFS、NoSQL及MapReduce、Spark等框架,为大规模数据存储与处理提供了高效解决方案。例如,Spark能通过分布式计算极大提升处理速度。这些技术不仅革新了数据处理方式,还在金融、电商等领域催生了风险识别、市场预测及个性化推荐等创新应用。
271 1
|
JavaScript Java 测试技术
基于SpringBoot+Vue+uniapp微信小程序的社区养老服务的详细设计和实现
基于SpringBoot+Vue+uniapp微信小程序的社区养老服务的详细设计和实现
195 1
|
移动开发 前端开发
ruoyi-nbcio-plus基于vue3的flowable流程查看器组件的升级修改
ruoyi-nbcio-plus基于vue3的flowable流程查看器组件的升级修改
184 1
|
编解码 数据可视化 前端开发
ECharts 对比 Highcharts 使用教程
ECharts 对比 Highcharts 使用教程
449 1
|
存储 缓存 移动开发
详细介绍HTML5的离线储存(工作原理+使用场景+真实使用步骤)
详细介绍HTML5的离线储存(工作原理+使用场景+真实使用步骤)
Rainbond v5.17 版本发布,统一管理离线镜像和私有仓库
为了更好地应对离线场景,提升私有仓库镜像部署体验。Rainbond v5.17 版本支持上传镜像包和使用本地镜像创建组件。同时对于私有镜像的部署也进行了优化,通过统一配置私有镜像仓库。用户无需重复输入账号密码,即可快速部署私有镜像。
|
算法 测试技术 UED
如何优化模型渲染性能
优化模型渲染性能对于提升用户体验、节约资源消耗、支持复杂场景、扩展到低端硬件、节约能源以及提高开发效率来说都是非常重要的。通过优化性能,可以实现更高质量、更高效的图形渲染。
399 0