zoukankan      html  css  js  c++  java
  • android edittext限制输入小数位数,限制输入数字大小

    public class CashierInputFilter implements InputFilter {  
        Pattern mPattern;  
      
        //输入的最大金额  
        private static final int MAX_VALUE = Integer.MAX_VALUE;  
        //小数点后的位数  
        private static final int POINTER_LENGTH = 2;  
      
        private static final String POINTER = ".";  
      
        private static final String ZERO = "0";  
      
        public CashierInputFilter() {  
            mPattern = Pattern.compile("([0-9]|\.)*");  
        }  
      
        /** 
         * @param source    新输入的字符串 
         * @param start     新输入的字符串起始下标,一般为0 
         * @param end       新输入的字符串终点下标,一般为source长度-1 
         * @param dest      输入之前文本框内容 
         * @param dstart    原内容起始坐标,一般为0 
         * @param dend      原内容终点坐标,一般为dest长度-1 
         * @return          输入内容 
         */  
        @Override  
        public CharSequence filter(CharSequence source, int start, int end, Spanned dest, int dstart, int dend) {  
            String sourceText = source.toString();  
            String destText = dest.toString();  
      
            //验证删除等按键  
            if (TextUtils.isEmpty(sourceText)) {  
                return "";  
            }  
      
            Matcher matcher = mPattern.matcher(source);  
            //已经输入小数点的情况下,只能输入数字  
            if(destText.contains(POINTER)) {  
                if (!matcher.matches()) {  
                    return "";  
                } else {  
                    if (POINTER.equals(source)) {  //只能输入一个小数点  
                        return "";  
                    }  
                }  
      
                //验证小数点精度,保证小数点后只能输入两位  
                int index = destText.indexOf(POINTER);  
                int length = dend - index;  
      
                if (length > POINTER_LENGTH) {  
                    return dest.subSequence(dstart, dend);  
                }  
            } else {  
                //没有输入小数点的情况下,只能输入小数点和数字,但首位不能输入小数点和0  
                if (!matcher.matches()) {  
                    return "";  
                } else {  
                    if ((POINTER.equals(source) || ZERO.equals(source)) && TextUtils.isEmpty(destText)) {  
                        return "";  
                    }  
                }  
            }  
      
            //验证输入金额的大小  
            double sumText = Double.parseDouble(destText + sourceText);  
            if (sumText > MAX_VALUE) {  
                return dest.subSequence(dstart, dend);  
            }  
      
            return dest.subSequence(dstart, dend) + sourceText;  
        }  
    }  
  • 相关阅读:
    POJ_1523 SPF (Tarjan 求割点)
    POJ 3177&& 3352
    POJ 基础数据结构
    Bellman Ford, SPFA 学习笔记(含有负权的单源最短路径)
    HDU_3062 Party (2SAT)
    POJ二分图最大匹配的简单题目
    POJ 2553 The Bottom of a Graph (Trajan 强连通分量 缩点)
    POJ_3678 Katu Puzzle (2SAT)
    HDU_3836 Equivalent Set (Trajan 强连通分量 缩点)
    POJ1904 King's Quest(Tarjan 求缩点)
  • 原文地址:https://www.cnblogs.com/androidstudy/p/5364409.html
Copyright © 2011-2022 走看看