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

实现效果:

相关推荐
执笔论英雄1 小时前
Slime异步原理(单例设计模式)4
开发语言·python·设计模式
e***74953 小时前
Modbus报文详解
服务器·开发语言·php
lly2024063 小时前
ASP 发送电子邮件详解
开发语言
小徐敲java3 小时前
python使用s7协议与plc进行数据通讯(HslCommunication模拟)
开发语言·python
likuolei3 小时前
XSL-FO 软件
java·开发语言·前端·数据库
6***37943 小时前
PHP在电商中的BigCommerce
开发语言·php
Dev7z3 小时前
基于Matlab的多制式条形码识别与图形界面(GUI)系统设计与实现
开发语言·matlab
合作小小程序员小小店3 小时前
桌面开发,在线%信息管理%系统,基于vs2022,c#,winform,sql server数据。
开发语言·数据库·sql·microsoft·c#
FL16238631293 小时前
ONNX RuntimeC++ 静态库下载安装和使用教程
开发语言·c++
星释3 小时前
Rust 练习册 95:React与响应式编程
开发语言·react.js·rust