缘起
前段时间用到了验证用户输入数据合理性功能(double 类型,QDoubleValidator 无法验证数据应该是个众所周知的bug了,但是一直没能修改,至少在5.5版本还没有修改,这其中的缘由不敢妄加猜测),一开始想着要用正则验证,但是又觉得以后可能还会遇到这样的需求,所以决定自己改造一下QDoubleValidator。
过程
其实,我只继承了QDoubleValidator,在原有的QDoubleValidator基础上去细化各种验证过程,只需要继承并重新实现下面两个函数就能实现我的需求:
- virtual State validate(QString &str, int &i) const;
- virtual void fixup(QString & input) const;
代码
废话不多说了,直接上代码。
.h
#ifndef MYDOUBLEVALIDATOR #define MYDOUBLEVALIDATOR #include <QDoubleValidator> class MyDoubleValidator: public QDoubleValidator { public: explicit MyDoubleValidator(QObject * parent = 0); virtual State validate(QString &str, int &i) const; virtual void fixup(QString & input) const; }; #endif // MYDOUBLEVALIDATOR
.cpp
#include "mydoublevalidator.h" MyDoubleValidator::MyDoubleValidator(QObject *parent) :QDoubleValidator(parent) { } QValidator::State MyDoubleValidator::validate(QString &str, int &i) const { //Q_UNUSED(i); if (str.isEmpty()) { return QValidator::Intermediate; } if(bottom()<0 && str=="-") return QValidator::Intermediate; bool cOK = false; double val = str.toDouble(&cOK); if (!cOK) { return QValidator::Invalid; } int dotPos = str.indexOf("."); if (dotPos > 0) { if (str.right(str.length() - dotPos-1).length() > decimals()) { return QValidator::Invalid; } } if (val<= top() && val >= bottom()) { return QValidator::Acceptable; } else if(val>top()) { return QValidator::Invalid; } else if(val<bottom()) { return QValidator::Intermediate; } return QValidator::Invalid; } void MyDoubleValidator::fixup(QString &input) const { if(input.toDouble()<bottom()) { QString *str=&input; *str=QString::number(bottom()); } }
最后
如有问题,欢迎大家指正。