Qt 制作登录对话框

Qt 制作登录对话框


版本说明

版本 作者 时间 备注
0.1 loon 2018.10.24 初步制作出登录对话框

目录

文章目录

  • Qt 制作登录对话框
    • 版本说明
    • 目录
    • 一、需求与目的
    • 二、实现方案说明
    • 三、实现结果展示
    • 四、代码展示
    • 五、最后

一、需求与目的

实现简单的类似QQ登录界面的登录对话框,可以输入用户名和密码,有登录和退出按钮,密码密文显示,用户名和密码正确则进入主窗口,错误则进行提示。

二、实现方案说明

我们之前已经实现了多窗口的功能,那么思路就很清晰了,程序启动首先进行登录对话框,登录对话框中有输入用户名和密码的LineEdit以及登录和退出的push button,然后写登录槽函数,将退出按钮和程序退出关联。其中登录槽函数进行用户名和密码的验证即可,验证通过则进入主窗口,验证失败则提醒并做一些后续工作。

OK,和之前实现多窗口一样,我们先创建一个基于widget的基础application,然后进入工程后添加文件,添加一个设计师界面类,依然选择dialog without button,然后类名设为loginDlg,接着按照我们的设想在界面文件中拖入对应的控件,然后做一些调整即可。

分别给用户名的lineEdit起名为usrLineEdit、密码的lineEdit起名pwdLineEdit,登录push button起名loginBtn,退出push button起名exitBtn,接着在Signal & Slots Editor中添加退出按钮的点击信号和loginDlg的退出方法的关联,最后右击登录push button选择转到槽去实现其槽函数即可。
Qt 制作登录对话框_第1张图片

三、实现结果展示

用户名为qt,密码为123456,目前是写死的,因为我们没有使用数据库,也没有连接服务器,仅仅是在本地进行简单的测试。
Qt 制作登录对话框_第2张图片

四、代码展示

main.cpp:

#include "widget.h"
#include 
#include "logindlg.h"

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    loginDlg login;
    
    if(login.exec() == QDialog::Accepted)
    {
        w.show();
        return a.exec();
    }
    else return 0;
}

logindlg.cpp:

#include "logindlg.h"
#include "ui_logindlg.h"
#include 

loginDlg::loginDlg(QWidget *parent) :
    QDialog(parent),
    ui(new Ui::loginDlg)
{
    ui->setupUi(this);
    ui->pwdLineEdit->setEchoMode(QLineEdit::Password);
}

loginDlg::~loginDlg()
{
    delete ui;
}

//登录按钮的槽函数实现
void loginDlg::on_loginBtn_clicked()
{
	/*ui->usrLineEdit->text().trimmed():获取用户名,后面的trimmed可以通过F1查看帮助了解其用法;
	判断用户名和密码分别符合“qt”和“123456”后调用accept使得main.cpp中条件满足,显示出widget;
	判断不符合要求时则用messageBox显示警告信息,然后清空用户名和密码框中的信息,最后将光标集中到usrLineEdit中。
	*/
    if(ui->usrLineEdit->text().trimmed() == tr("qt") && ui->pwdLineEdit->text() == tr("123456"))
        accept();
    else
    {
        QMessageBox::warning(this, tr("Warning"), tr("user name or password error!"),QMessageBox::Yes);
        ui->usrLineEdit->clear();
        ui->pwdLineEdit->clear();
        ui->usrLineEdit->setFocus();
    }
}

Qt 制作登录对话框_第3张图片

五、最后

这里仅仅实现了最初级的登录会话框,主要是对多窗口的一个应用以及阐述一下如何获取Qt自带的帮助信息,让我们更好的去阅读一些Qt的源码。当然,英语基础是必不可少的,遇到看不懂的搜索查询一下,不要轻言放弃。

你可能感兴趣的:(Qt开发,Qt制作登录对话框)