9.9(QT Day 2)

将day1做的登录界面升级优化【资源文件的添加】

在登录界面的登录取消按钮进行以下设置:

使用手动连接,将登录框中的取消按钮使用第2种方式的连接到自定义的槽函数中,在自定义的槽函数中调用关闭函数

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

1.Widget.cpp

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

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget),
      btn2(new QPushButton("注册",this)),
      btn3(new QPushButton("登录",this)),
      lab4(new QLabel(this))
{
    ui->setupUi(this);

    //-------------窗口相关设置----------------
    this->setWindowTitle("用户登录"); //窗口标题
    this->setWindowIcon(QIcon(":/pictrue/jye.png")); //窗口图标
    this->resize(510,531); //重设窗口大小
    this->setFixedSize(510,531); //固定窗口大小
    //this->setWindowFlag(Qt::FramelessWindowHint); //隐藏头部
    //this->setStyleSheet("background-color:white");
    this->lower();


    //-------------标签相关设置----------------
    QMovie *mv = new QMovie(":/pictrue/longmao.gif");
    ui->loginlab->setMovie(mv); //将动图设置到标签中
    mv->start(); //让动图动起来
    ui->loginlab->setScaledContents(true); //让图自动适应

    QMovie *mv2 = new QMovie(":/pictrue/gongqijun.gif");
    lab4->setMovie(mv2); //将动图设置到标签中
    lab4->move(0,221);
    lab4->resize(510,440);
    lab4->lower();
    mv2->start(); //让动图动起来
    lab4->setScaledContents(true); //让图自动适应

    //----------------------------------------------
    ui->usernamelab->setPixmap(QPixmap(":/pictrue/R-C.png"));
    ui->usernamelab->setScaledContents(true);

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

    //-------------行编译器相关设置----------------
    ui->usernameEdit->setPlaceholderText("用户名");
    ui->passwdEdit->setPlaceholderText("设置密码");
    ui->passwdEdit->setEchoMode(QLineEdit::Password);

    //-------------按钮设置----------------
    btn2->move(ui->passwdlab->x(),ui->passwdlab->y()+ui->passwdlab->height()+70); //移动取消与登录的坐标位置,并重设大小
    btn2->resize(101,51);
    btn2->setStyleSheet("5px");
    btn3->move(ui->passwdlab->x()+ui->passwdlab->width()+170,ui->passwdlab->y()+ui->passwdlab->height()+70);
    btn3->resize(101,51);
    btn3->setStyleSheet("5px");
    connect(btn3,SIGNAL(clicked()),this,SLOT(my_slots()));

}

Widget::~Widget()
{
    delete ui;

}

void Widget::my_slots()
{
    if(ui->usernameEdit->text() == "admin" && ui->passwdEdit->text() == "123456")
    {
        qDebug("登录成功");
    }
    else
    {
        qDebug("登陆失败");
        ui->passwdEdit->clear();
    }
}

void Widget::on_pushButton_clicked()
{
   this->close();
}

2.Widget.h

复制代码
#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QLabel> //标签类
#include <QPushButton> //按钮类
#include <QIcon> //图标类
#include<QMovie> //动图类
#include <QDebug>

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

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

private slots:
    void on_pushButton_clicked();

public slots:
    void  my_slots();

private:
    Ui::Widget *ui;
    QPushButton *btn2;
    QPushButton *btn3;
    QLabel *lab4;
};
#endif // WIDGET_H

实现效果:

相关推荐
Molesidy19 分钟前
【随笔】【QT】QT5.15.2版本的最新下载方式!!!
开发语言·qt
梨轻巧1 小时前
pyside6的历史发展、Qt 介绍、PyQt 和 pyside6对比
qt·pyqt
二进制person1 小时前
Java EE初阶 --多线程2
java·开发语言
yue0081 小时前
C#理论学习-WinForm实践开发教程总结
开发语言·学习·c#
007php0072 小时前
某游戏大厂 Java 面试题深度解析(四)
java·开发语言·python·面试·职场和发展·golang·php
Mr.Jessy2 小时前
Web APIs学习第一天:获取 DOM 对象
开发语言·前端·javascript·学习·html
午安~婉2 小时前
javaScript八股问题
开发语言·javascript·原型模式
想不明白的过度思考者2 小时前
Rust——异步递归深度指南:从问题到解决方案
开发语言·后端·rust
芝麻开门-新起点3 小时前
flutter 生命周期管理:从 Widget 到 State 的完整解析
开发语言·javascript·ecmascript
我先去打把游戏先4 小时前
ESP32开发指南(基于IDF):连接AWS,乐鑫官方esp-aws-iot-master例程实验、跑通
开发语言·笔记·单片机·物联网·学习·云计算·aws