QT作业day4

完善对话框,点击登录对话框,如果账号和密码匹配,则弹出信息对话框,给出提示"登录成功",提供一个Ok按钮,用户点击Ok后,关闭登录界面,跳转到其他界面

如果账号和密码不匹配,弹出错误对话框,给出信息"账号和密码不匹配,是否重新登录",并提供两个按钮Yes|No,用户点击Yes后,清除密码框中的内容,继续让用户进行登录,如果用户点击No按钮,则直接关闭登录界面

如果用户点击取消按钮,则弹出一个问题对话框,给出信息"您是否确定要退出登录?",并给出两个按钮Yes|No,用户点击Yes后,关闭登录界面,用户点击No后,关闭对话框,继续执行登录功能

要求:基于属性版和基于静态成员函数版至少各用一个

main文件:

#include "work2.h"
#include "second.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    work2 w;
    w.show();

    //实例化第二个界面
    Second s;
    //将跳转信号和对应的槽函数连接
    QObject::connect(&w,&work2::jump_Second_signal,&s,&Second::jump_Second_slot);

    return a.exec();
}

第一个界面头文件:

#ifndef WORK2_H
#define WORK2_H

#include <QWidget>
#include <QMessageBox>

QT_BEGIN_NAMESPACE
namespace Ui { class work2; }
QT_END_NAMESPACE

class work2 : public QWidget
{
    Q_OBJECT

public:
    work2(QWidget *parent = nullptr);
    ~work2();

signals:
    void jump_Second_signal();//声明跳转第二个界面的信号


private slots:
    void on_login_button_clicked();

    void on_cancel_button_clicked();

private:
    Ui::work2 *ui;
};
#endif // WORK2_H

第一个界面源文件:

#include "work2.h"
#include "ui_work2.h"

work2::work2(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::work2)
{
    ui->setupUi(this);

    //设置窗口图标
    this->setWindowIcon(QIcon(":/photograph/picture/starry sky.jpg"));
    //纯净窗口
    this->setWindowFlag(Qt::FramelessWindowHint);

    //去掉空白
    this->setAttribute(Qt::WA_TranslucentBackground);

    //设置 占位
    ui->user_edit->setPlaceholderText("账号/手机号");
    //设置 占位
    ui->passwd_edit->setPlaceholderText("密码");
    //设置显示模式 (密码)
    ui->passwd_edit->setEchoMode(QLineEdit::Password);

}

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

//登录按钮槽函数
void work2::on_login_button_clicked()
{
    if(ui->user_edit->text() == "wang1111" && ui->passwd_edit->text() == "123456")
    {
        //弹出信息对话框,表示登录成功
        QMessageBox::information(this,"提示","登录成功");
        //关闭登录窗口
        this->close();
        //跳转到第二个界面
        emit jump_Second_signal();
    }
    else
    {
        //弹出错误对话框
        QMessageBox Critical_msg(QMessageBox::Critical,"错误","账号和密码不匹配,是否重新登录",QMessageBox::Yes | QMessageBox::No);
        //调用exec函数弹出对话框
        int ret = Critical_msg.exec();
        //根据不同选择执行不同功能
        if(ret == QMessageBox::Yes)
        {
            //清除密码框的内容
            ui->passwd_edit->clear();
        }
        else if(ret == QMessageBox::No)
        {
            //关闭登录界面
            this->close();
        }

    }
}

//取消按钮槽函数
void work2::on_cancel_button_clicked()
{
    //弹出问题对话框
    int ret = QMessageBox::question(this,"问题","您是否确定要退出登录?", QMessageBox::Yes | QMessageBox::No);
    //根据不同选择执行不同的功能
      if(ret == QMessageBox::Yes)
      {
         //关闭登录界面
          this->close();
      }
      else if(ret == QMessageBox::No)
      {
          //回到登录界面,不做任何处理
      }
}

第二个界面头文件:

#ifndef SECOND_H
#define SECOND_H

#include <QWidget>

namespace Ui {
class Second;
}

class Second : public QWidget
{
    Q_OBJECT

public:
    explicit Second(QWidget *parent = nullptr);
    ~Second();

public slots:
    void jump_Second_slot();//跳转到第二个界面的槽函数声明

private:
    Ui::Second *ui;
};

#endif // SECOND_H

第二个界面的源文件:

#include "second.h"
#include "ui_second.h"

Second::Second(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Second)
{
    ui->setupUi(this);
}

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

//跳转第二个界面的槽函数实现
void Second::jump_Second_slot()
{
    //显示第二个界面
    this->show();
}

qss语句:

*{	
	background-color: rgb(255, 255, 255);
}

QFrame#frame{
	
	
	border-image: url(:/photograph/picture/liuying.jpg);
}

#frame_2{
	
	background-color: rgba(153, 153, 153, 120);
}

QLabel#label_1{
	border-radius:30px;
	background-color: rgba(144, 144, 144, 120);
}
#label_2{
	background:transparent; /*完全透明*/
	color: rgba(128, 255, 106, 120);
	font: 18pt "等线";
}

QLineEdit{
	background:transparent; /*完全透明*/
	border:none;  /*无边框*/
	border-bottom: 1px solid rgba(255, 255, 255, 120);/*显示下边框*/
	color: rgba(255, 255, 255, 120);
	font: 14pt "等线";
}

QPushButton#login_button{
	border-radius:10px;
	color: rgba(255, 255, 255, 120);
	font: 14pt "等线";
	
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(96, 161, 215, 255), stop:1 rgba(255, 255, 255, 255));
}
QPushButton#login_button:hover{  /*鼠标移动*/
	border-radius:10px;
	color: rgba(255, 255, 255, 120);
	font: 14pt "等线";
	
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(130, 161, 215, 255), stop:1 rgba(255, 255, 255, 255));
}
QPushButton#login_button:pressed{  /*鼠标按压*/
	border-radius:10px;
	color: rgba(255, 255, 255, 120);
	font: 14pt "等线";
	
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(96, 161, 215, 255), stop:1 rgba(255, 255, 255, 255));
	padding-top:5px;
	padding-left:5px;
}

QPushButton#cancel_button{
	border-radius:10px;
	color: rgba(255, 255, 255, 120);
	font: 14pt "等线";
	
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(96, 161, 215, 255), stop:1 rgba(255, 255, 255, 255));
}
QPushButton#cancel_button:hover{  /*鼠标移动*/
	border-radius:10px;
	color: rgba(255, 255, 255, 120);
	font: 14pt "等线";
	
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(130, 161, 215, 255), stop:1 rgba(255, 255, 255, 255));
}
QPushButton#cancel_button:pressed{  /*鼠标按压*/
	border-radius:10px;
	color: rgba(255, 255, 255, 120);
	font: 14pt "等线";
	
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(96, 161, 215, 255), stop:1 rgba(255, 255, 255, 255));
	padding-top:5px;
	padding-left:5px;
}

#quit_button{
	font: 28pt "等线";
background:transparent;/*完全透明*/
	color: rgb(255, 255, 255);
}
#quit_button:hover{
	color: rgb(255, 255, 255);
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(96, 161, 215, 255), stop:1 rgba(255, 255, 255, 255));
}

#min_button{
	font: 28pt "等线";
background:transparent;/*完全透明*/
	color: rgb(255, 255, 255);
}
#min_button:hover{
	color: rgb(255, 255, 255);
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(96, 161, 215, 255), stop:1 rgba(255, 255, 255, 255));
}

#checkBox_1{
	font: 9pt "等线";
background:transparent;/*完全透明*/
	color: rgb(255, 255, 255);
}

#checkBox2{
	font: 9pt "等线";
background:transparent;/*完全透明*/
	color: rgb(255, 255, 255);
}

Qt_day4作业1

思维导图:

相关推荐
hairenjing11236 小时前
使用 Mac 数据恢复从 iPhoto 图库中恢复照片
windows·stm32·嵌入式硬件·macos·word
九鼎科技-Leo8 小时前
了解 .NET 运行时与 .NET 框架:基础概念与相互关系
windows·c#·.net
九鼎科技-Leo10 小时前
什么是 ASP.NET Core?与 ASP.NET MVC 有什么区别?
windows·后端·c#·asp.net·mvc·.net
黎明晓月14 小时前
Java之字符串分割转换List
java·windows·list
九鼎科技-Leo14 小时前
在 C# 中,ICollection 和 IList 接口有什么区别?
windows·c#·.net
顾辰呀15 小时前
实现uniapp-微信小程序 搜索框+上拉加载+下拉刷新
前端·windows
Bunny Chen18 小时前
如何缩小PPT演示文稿的大小?
windows·microsoft·powerpoint
如光照18 小时前
Linux与Windows中的流量抓取工具:wireshark与tcpdump
linux·windows·测试工具·网络安全
wwc_boke19 小时前
Linux查看端口占用及Windows查看端口占用
linux·运维·windows
WangMing_X20 小时前
C# 一个工具类让winform自动根据窗体大小缩放所有控件
开发语言·windows·c#