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();
    }
}

效果图:

相关推荐
4U24720 小时前
Linux入门之vim
linux·编辑器·vim·命令模式·底行模式
monkey_meng1 天前
【Rust实现命令模式】
开发语言·设计模式·rust·命令模式
老攀呀3 天前
命令模式(Command)
命令模式
JAVA开发区3 天前
探索设计模式:命令模式
设计模式·命令模式
踏过山河,踏过海4 天前
【Qt c++】Qt内置图标
c++·qt·命令模式
XYX的Blog4 天前
设计模式08-行为型模式1(命令模式/迭代器模式/观察者模式/Java)
设计模式·迭代器模式·命令模式
skywind7 天前
我在命令行下学日语
linux·python·bash·命令模式
zzzhpzhpzzz7 天前
设计模式——命令模式
设计模式·命令模式
努力编程的阿伟8 天前
二十三种设计模式之命令模式
命令模式
神的孩子都在歌唱9 天前
行为设计模式 -命令模式- JAVA
java·设计模式·命令模式