QT C++实战:实现用户登录页面及多个界面跳转

是瑶瑶子啦 2024-07-17 09:05:11 阅读 79

主要思路

一个登录界面,以管理员Or普通用户登录管理员:一个管理员的操作界面,可以把数据录入到数据库中。有返回登陆按钮,可以选择重新登陆(管理员Or普通用户普通用户:一个主界面,负责展示视频和检测。有返回登陆按钮,可以选择重新登陆(管理员Or普通用户

参考教程:P1 登入Qt界面布局,多个界面切换

一、UI设计

我们一共要设计3个界面

主界面(与项目同名):主要的功能实现界面:视频观看、算法检测可视化登录界面管理员信息管理界面

1.0:vs2019中添加QT界面:

一般用vs2019开发,创建Qt Widgets Application之后,会自带一个和项目名同名的主窗口类。这个时候需要手动创建另外一个,即新窗口类。创建方法可以参考这篇博客:Qt5.12.6 + VS2019 点击按钮弹出新窗口

在这里插入图片描述

在这里插入图片描述

1.1:主界面:

由于我的项目名是:<code>new_QT_python,我的主界面为:

new_QT_python.uinew_QT_python.hnew_QT_python.cpp

在这里插入图片描述

这里UI以及主要功能已经完成,这里不再详细讲解。重点讲解用户登录功能的实现以及界面跳转

1.2:登录界面

添加<code>Login登录界面后,双击Login.ui进入QtCreator进行UI设计:

在这里插入图片描述

注意,在<code>main.cpp中记得修改展示界面。使得程序一开始运行,首先展示的是登录界面。

#include "Login.h"

#include <QtWidgets/QApplication>

int main(int argc, char *argv[])

{

QApplication a(argc, argv);

//登录界面的显示

Login w;

w.show();

return a.exec();

}

1.3:管理员管理界面

还是按照上面相同的方式创造界面就行,这里界面设计和逻辑功能暂时忽略。

在这里插入图片描述

二、实现页面跳转(各个槽函数

2.1:登陆界面的槽函数

修改控件名称,编写对应的槽函数:

在这里插入图片描述

tips:用Vs2019创建的QT项目此时可能会报错:

解决方法:手动添加槽函数,会麻烦些,但也不要紧

在这里插入图片描述

首先先确定主要3个槽函数(暂时不做实现)

<code>login.h

#pragma once

#include <QMainWindow>

#include "ui_Login.h"

class Login : public QMainWindow

{

Q_OBJECT

public:

Login(QWidget *parent = nullptr);

~Login();

private:

Ui::LoginClass ui;

private slots:

void on_inlog_clicked();

void on_quit_clicked();

void on_checkBox_clicked(bool checked);

}

;

login.cpp

#include "Login.h"

Login::Login(QWidget *parent)

: QMainWindow(parent)

{

ui.setupUi(this);

this->setWindowTitle("用户登录");

//登录按钮

connect(ui.inlog, &QPushButton::clicked, this, &Login::on_inlog_clicked);

//退出按钮

connect(ui.quit, &QPushButton::clicked, this, &Login::on_quit_clicked);

//显示密码按钮

connect(ui.checkBox, &QPushButton::clicked, this, &Login::on_checkBox_clicked);

}

Login::~Login()

{

}

//登录按钮对应槽函数:登陆成功跳转到主功能界面or管理员界面

void Login::on_inlog_clicked() {

}

//退出按钮对应槽函数:关闭当前窗口,退出程序

void Login::on_quit_clicked() {

}

//显示密码按钮,1表示选中,0表示密文显示

void Login::on_checkBox_clicked(bool checked) {

}

Tips:通过ui.nameui.pswd可以对其进行各种操作

下面实现槽函数和以及用户名以及密码的输入及限制功能:

#include "Login.h"

#include "new_QT_python.h"

//登录按钮对应槽函数:登陆成功跳转到主功能界面or管理员界面

void Login::on_inlog_clicked() {

//创建功能主界面并显示

new_QT_python* w = new new_QT_python();

w->show();

//隐藏

this->hide();

}

//退出按钮对应槽函数:关闭当前窗口,退出程序

void Login::on_quit_clicked() {

//关闭当前界面

this->close();

}

//显示密码按钮,1表示选中,0表示密文显示

/*显示,不回显,密文:enum EchoMode { Normal, NoEcho, Password, PasswordEchoOnEdit };*/

void Login::on_checkBox_clicked(bool checked) {

if (checked) {

//显示密码

ui.pswd->setEchoMode(QLineEdit::Normal);

}

else {

//密文显示

ui.pswd->setEchoMode(QLineEdit::Password);

}

}

三、实现登录的逻辑功能

主要逻辑功能:输入管理员账户和密码:跳转到管理员操作界面(按返回则返回到登录界面);输入普通用户的账号和密码:跳转到普通用户的主功能操作界面(按返回则返回到登录界面)

🪧思路:

主要是在void Login::on_inlog_clicked() 槽函数中进行逻辑控制:

判断账号与密码是否和管理员的相同,若相同,则进入管理员管理施工信息的页面判断账号和密码是否和普通用户的相同,若相同,则进入普通用户的主要功能的管理页面否则,不能登录,返回。

//登录按钮对应槽函数:登陆成功跳转到主功能界面or管理员界面

void Login::inlog_clicked() {

//获取用户名和密码输入框中数据

QString nameString = ui.name->text();

QString pswdString = ui.pswd->text();

if (nameString == QString::fromLocal8Bit("admin")&& pswdString == QString::fromLocal8Bit("123456")) {

Admin* w = new Admin();

this->close();

w->show();

}

else if (nameString == QString::fromLocal8Bit("user") && pswdString == QString::fromLocal8Bit("111111")) {

//创建功能主界面并显示

new_QT_python* w = new new_QT_python();

this->close();

w->show();

}

else {

QMessageBox::about(this, "警告", "用户名或密码错误");

return;

}

}


基本登录功能以及页面之间的跳转逻辑已经写好了。下面主要任务是学习QT如何连接数据库,一方面是项目需要将施工信息录入到数据库中;另一方面,上面代码中管理员和普通用户的账号和密码信息都是写死的,也就是硬编码,但是按理来说最好还是将用户信息存储在数据库当中。还有一个问题是,将数据库和QT进行连接后,对后面项目的打包是否有影响,是否要提前在对方主机上安装mysql等数据库呢?还是边学边看看吧。🤔



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。