Qt实现自定义验证码输入框控件

举报
黑兔子 发表于 2022/09/16 09:31:18 2022/09/16
【摘要】 本文实现了自定义的验证码输入框控件。控件包括图标、输入框、获取验证码按钮、验证码获取倒计时标签。支持鼠标点击获取验证码按钮后开始显示倒计时功能,倒计时为0时,才可以在此点击获取验证码按钮。

前言:

本文实现了自定义的验证码输入框控件。控件包括图标、输入框、获取验证码按钮、验证码获取倒计时标签。支持鼠标点击获取验证码按钮后开始显示倒计时功能,倒计时为0时,才可以在此点击获取验证码按钮。效果如图:

1648621312(1).jpg

主要的编程思想还是实现自定义控件的封装性和共用性。

UI布局:

1648628622(1).jpg

  • 控件1:QWidget,实现整个控件的封装,这个控件使用水平布局,实现控件的水平摆放,同时,当其中一个控件隐藏时,位置会重新更新,实现在控件的后面只显示获取验证码和倒计时两个控件中的一个。
  • 控件2:QLabel,实现展示盾牌图标。
  • 控件3:QLineEdit,实现验证码输入功能。
  • 控件4:QPushButton,实现获取验证码功能。
  • 控件5:QLabel,实现倒计时显示。

页面样式初始化:

控件1:实现外边框和背景: 边框宽1像素,颜色#DBDBDB,背景颜色#FFFFFF。

setStyleSheet("QWidget#widget{border:1px solid #DBDBDB;background-color:#FFFFFF;}");

控件2:实现盾牌图标的展示: 图片资源:image/vCode.png。

ui.lablevCode->setStyleSheet("border-image:url(image/vCode.png);");

控件3:实现验证码输入功能: 无边框,背景颜色#FFFFFF,字体颜色#333333。

ui.lineEdit->setStyleSheet("QLineEdit{border:0px;color:#333333;background:#FFFFFF;}");

控件4:实现获取验证码按钮: 无边框,字体颜色#999999,鼠标悬浮时字体颜色#3B85FF。

ui->pushButton->setStyleSheet("QPushButton{border:none;color:#999999;}"
                              "QPushButton:hover{border:none;color:#3B85FF;}");

控件5:初始化隐藏(在没有点击获取验证码按钮时为隐藏状态,点击获取验证码按钮后,显示倒计时,隐藏获取验证码按钮)。字体颜色#b7b7b7。

ui->label_time->setStyleSheet("QLabel{color:#b7b7b7;}");
ui->label_time->hide();

除了这些控件外,我们还需要创建一个定时器,用来实现倒计时的功能,定时器的溢出时间为1s,定时器的槽函数为slotVCodeTimeout()。

//创建成员变量
QTimer *m_timer;
//动态创建定时器,并指定定时器的溢出事件和槽函数
m_vCodeTimer = new QTimer(this);
connect(m_vCodeTimer, SIGNAL(timeout()), this, SLOT(slotVCodeTimeout()));
m_vCodeTimer->setInterval(1000);  // 1s

功能实现:

1. 输入限制:

不显示上下文菜单,禁止输入中文,默认显示“请输入验证码”,手机号只能是11位0~9的数字。

ui.lineEdit->setContextMenuPolicy (Qt::NoContextMenu); // 不显示上下文菜单
ui.lineEdit->setAttribute(Qt::WA_InputMethodEnabled, false);  // 设置禁止中文输入
ui.lineEdit->setPlaceholderText(QString::fromLocal8Bit("请输入验证码")); // 设置默认显示内容
QRegExp rx("[0-9]{1,8}"); // 正则表达式:数字, 8位
QRegExpValidator *validator = new QRegExpValidator(rx, this);
ui.lineEdit->setValidator(validator);// 设置正则表达式

2.点击获取验证码按钮,执行获取验证码操作:

在按钮的点击响应函数中,调用获取验证码的方法,通常是调用后台接口,实现给指定手机号发送验证码的功能。这里可以发射一个信号,由控件外部响应这个信号,再做相应的操作,如判断是否输入手机号、手机号是否正确、调用后台接口、判断是否成功发送验证码等。

void VCodeLineEdit::on_pushButton_clicked()
{
    //调用获取验证码方法
}

3.隐藏获取验证码按钮,显示倒计时:

ui->pushButton->hide();//隐藏获取验证码按钮
ui->label_time->show();//显示倒计时标签

if (m_vCodeTimer->isActive())如果定时器已经启动,先停止定时器,再重新打开定时器
{
    m_vCodeTimer->stop();
}
m_vCodeTimer->start();
//设置倒计时显示的文本
ui->label_time->setText(QString::number(m_time) +QStringLiteral("s后重新发送"));

4.定时器响应函数:

这里定义了一个成员变量m_time,m_time的初始值设置为60(倒计时事件为60s)。每次定时器溢出,m_time的值减1,先判断m_time是否已经小于等于0。如果是,则表示倒计时结束,隐藏倒计时标签,重新显示获取验证码按钮,并关闭定时器,重置m_time。如果没有小于等于0,表示倒计时没有结束,则更新倒计时显示标签内容。

m_time -= 1;
if(m_time <= 0)
{
    ui->label_time->hide();
    ui->pushButton->show();
    if (m_vCodeTimer->isActive())
    {
        m_vCodeTimer->stop();
    }
    m_time = 60;
}
else{
    ui->label_time->setText(QString::number(m_time) +QStringLiteral("s后重新发送"));
}
【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。