Qt12.8

使用手动连接,将登录框中的取消按钮使用qt4版本的连接到自定义的槽函数中,在自定义的槽函数中调用关闭函数

将登录按钮使用qt5版本的连接到自定义的槽函数中,在槽函数中判断ui界面上输入的账号是否为"admin",密码是否为"123456",如果账号密码匹配成功,则输出"登录成功",并关闭该界面,如果匹配失败,则输出登录失败,并将密码框中的内容清空

头文件:

复制代码
#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QMovie>
#include <QPushButton>
#include <QDebug>
#include <iostream>
#include <QIcon>
#include <QLabel>
#include <QLineEdit>

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

public:
    Widget(QWidget *parent = nullptr);
    ~Widget();
signals:
    void my_singal();

public slots:
    void my_slot();  //自定义的槽
    void btn1_slot();
private:
    Ui::Widget *ui;
};
#endif // WIDGET_H

源文件:

复制代码
#include "widget.h"
#include "ui_widget.h"

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

    this->setWindowFlag(Qt::FramelessWindowHint);
    //窗口图标设置
    QMovie *mv = new QMovie(":/pictrue/kun.gif");
    ui->backgroundlabel->setMovie(mv);
    mv->start();
    ui->backgroundlabel->setScaledContents(true);



    ui->accountlabel->setPixmap(QPixmap(":/pictrue/userName.jpg"));
    ui->accountlabel->setScaledContents(true);

    ui->passwordlabel->setPixmap(QPixmap(":/pictrue/passwd.jpg"));
    ui->passwordlabel->setScaledContents(true);

    ui->passwdline->setEchoMode(QLineEdit::Password);

    //手动连接信号和自定义的槽函数 基于qt4版的连接 该连接是不友好的连接
    connect(ui->btn2,SIGNAL(clicked()),this,SLOT(my_slot()));

    //手动连接信号和自定义的槽函数 基于qt5版的连接 该连接是友好的连接
    connect(ui->btn1, &QPushButton::clicked, this, &Widget::btn1_slot);

}

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

void Widget::my_slot()
{
    this->close();
}
void Widget::btn1_slot()
{
    //获取账号和密码输入框中的文本
    QString inputAccout = ui->accoutline->text();
    QString inputPasswd = ui->passwdline->text();
    //如果账号密码匹配成功,则输出"登录成功"
    if(inputAccout == "admin" && inputPasswd == "123456")
    {
        //登录成功,输出"登录成功"
        qDebug() << "登录成功";
    }else
    {
        qDebug() << "登录失败";
        ui->passwdline->clear();
    }
}

效果图:

相关推荐
懒大王爱吃狼2 天前
Python + Qt Designer构建多界面GUI应用程序:Python如何调用多个界面文件
开发语言·数据库·python·qt·mysql·python基础·命令模式
恋恋风辰6 天前
QT系列教程(16) 定时器事件
开发语言·qt·命令模式
LuckyLay11 天前
Golang学习笔记_44——命令模式
笔记·学习·设计模式·golang·命令模式
墨️穹13 天前
QT 作业 day4
命令模式
Unique_yt14 天前
03.03 QT
开发语言·qt·命令模式
码熔burning15 天前
(十 五)趣学设计模式 之 命令模式!
java·设计模式·命令模式
m0_7482448316 天前
SpringDoc和Swagger使用
命令模式
Forget the Dream17 天前
设计模式之命令模式
java·c++·设计模式·命令模式
_真相只有一个18 天前
行为型模式 - 命令模式 (Command Pattern)
设计模式·命令模式
一只小小汤圆21 天前
以绘图(绘制点、直线、圆、椭圆、多段线)为例子 通过设计模式中的命令模式实现
设计模式·命令模式