首页 > 其他分享 >嵌入式学习

嵌入式学习

时间:2024-06-17 23:29:46浏览次数:8  
标签:void 嵌入式 学习 ui login my event 255

笔记

作业

升级优化自己应用程序的登录界面。
     要求: 1. qss实现
                 2. 需要有图层的叠加 (QFrame)
                 3. 设置纯净窗口后,有关闭等窗口功能。
                 4. 如果账号密码正确,则实现登录界面关闭,另一个应用界面显示。

        登录界面代码:

widget.h文件:

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QTimer>
#include <QMouseEvent>

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_signal_mul();//"X"  关闭窗口  的信号函数
    void my_signal_login();//登录按钮  对应的  信号函数
    void my_signal_cancel();//取消按钮  对应的  信号函数
    void my_jump();//第一个界面的信号


public slots:
    void my_slot_mul();//"X"  关闭窗口  的槽函数
    void my_slot_login();//登录按钮  对应的  槽函数
    void my_slot_cancel();//取消按钮  对应的  槽函数
    void my_slot_jump_back();//返回  登录页面  的槽函数

private:
    Ui::Widget *ui;

protected:
    //重写鼠标按下事件
    void mousePressEvent(QMouseEvent *event) override;
    //重写鼠标移动事件
    void mouseMoveEvent(QMouseEvent *event) override;

private:
    QPoint dragPosition;//声明一个坐标点
};
#endif // WIDGET_H

widget.cpp文件:

#include "widget.h"
#include "ui_widget.h"

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

    this->setWindowFlag(Qt::FramelessWindowHint);//设置纯净窗口

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

    connect(ui->btn_login, &QPushButton::clicked, this, &Widget::my_slot_login);//登录  按钮  连接槽函数
    connect(ui->btn_cancel, &QPushButton::clicked, this, &Widget::my_slot_cancel);//取消  按钮  连接槽函数
    connect(ui->btn_mul, &QPushButton::clicked, this, &Widget::my_slot_mul);//"X" 按钮  连接槽函数


}

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

//"X" 按钮  对应的  槽函数
void Widget::my_slot_mul()
{
    this->close();
}


//登录按钮  对应的  槽函数
void Widget::my_slot_login()
{
    if(ui->lineEdit_userame->text() == "admin" && ui->lineEdit_passwd->text() == "123456")
    {
        /*
        QLabel *lab_login_success = new QLabel("登录成功",this);//创建  “登录成功”  标签
        lab_login_success->resize(100,ui->lineEdit_userame->height());//设置标签大小,与登录按钮高度相同
        lab_login_success->setStyleSheet("background-color:rgb(220,220,220)");//设置标签颜色
        lab_login_success->show();//标签显示
        lab_login_success->setAlignment(Qt::AlignCenter);//设置标签中文本居中显示
        lab_login_success->move(ui->btn_login->x(),ui->btn_login->y()-lab_login_success->height());//设置标签位置在登录按钮上方

        //关闭标签
        QTimer::singleShot(3000,lab_login_success,SLOT(close()));//仅在3秒后关闭标签
        */
        this->close();//关闭窗口

        emit my_jump();//触发信号

    }else
    {
        QLabel *lab_login_failure = new QLabel("登陆失败",this);//创建  “登录失败”  标签
        lab_login_failure->resize(100,ui->lineEdit_userame->height());//设置标签大小,与登录按钮高度相同
        lab_login_failure->setStyleSheet("background-color:rgb(220,220,220)");//设置标签颜色
        lab_login_failure->show();//标签显示
        lab_login_failure->setAlignment(Qt::AlignCenter);//设置标签中文本居中显示
        lab_login_failure->move(ui->btn_login->x(),ui->btn_login->y()-lab_login_failure->height());//设置标签位置在登录按钮上方
        ui->lineEdit_passwd->clear();//清空  密码  行编辑器中的内容

        //关闭标签
        QTimer::singleShot(3000,lab_login_failure,SLOT(close()));//仅在3秒后关闭标签
    }
}


//取消按钮  对应的  槽函数
void Widget::my_slot_cancel()
{
    //清空  账户和密码  行编辑器中的内容
    ui->lineEdit_userame->clear();//清空  账户  行编辑器中的内容
    ui->lineEdit_passwd->clear();//清空  密码  行编辑器中的内容
}

//重写鼠标按下事件
void Widget::mousePressEvent(QMouseEvent *event) {
    // 当按下鼠标左键时记录当前位置
    if (event->button() == Qt::LeftButton) {
        dragPosition = event->globalPos();
        event->accept();
    }
}

void Widget::my_slot_jump_back()
{
    this->show();//显示当前页面
}


//重写鼠标移动事件
void Widget::mouseMoveEvent(QMouseEvent *event) {
    // 当移动鼠标时移动窗口
    if (event->buttons() & Qt::LeftButton) {
        move(this->x() + event->globalPos().x() - dragPosition.x(),
             this->y() + event->globalPos().y() - dragPosition.y());
        dragPosition = event->globalPos();
        event->accept();
    }
}

qss语句:

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

QFrame#frame{  /*背景*/
	
	border-image: url(:/Logo/shanChuan.jpg);

	border-radius:10px
}

#frame_surface{
	
	background-color: rgba(190, 190, 190, 100);
}


QPushButton{
	color: rgb(255, 255, 255);

	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(81, 81, 81, 120), stop:1 rgba(255, 255, 255, 255));

	border-radius:5px;
}

QPushButton:hover{
	color: rgb(255, 255, 255);

	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(85, 81, 81, 120), stop:1 rgba(255, 255, 255, 255));

	border-radius:5px;
}

QPushButton:pressed{  /*鼠标按下*/
	color: rgb(255, 255, 255);

	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(85, 81, 81, 120), stop:1 rgba(255, 255, 255, 255));

	border-radius:5px;

	padding-top:5px;
	padding-left:5px;
}

/*右上角三个按钮*/
QPushButton#btn_set,#btn_sub,#btn_mul{
	
	background-color: rgba(106, 102, 116, 0);

	/*color: rgb(255, 255, 255);*/

	border: none;
}


/*主题标签*/
QLabel#label_theme{
	
	background-color: rgba(81, 81, 81, 120);
	border-radius:5px;
}

/*头像标签*/
QLabel#label_head{
	
	border-image: url(:/QQ/head.png);
	background-color: rgba(255, 255, 255, 90);
	border-radius: 25px;
	
}

/*账号  密码*/
QLineEdit{
	background: transparent;
	border: none;
	border-bottom:1px solid rgba(255, 255, 255, 120);
	color: rgb(255, 255, 255, 120);
}

QPushButton#btn_login,#btn_cancel{
	background-color: rgba(81, 81, 81, 120);
	border-radius:5px;
}

        第二个界面:

second.h文件:

#ifndef SECOND_H
#define SECOND_H

#include <QWidget>
#include <QMovie>
#include <QMouseEvent>

namespace Ui {
class Second;
}

class Second : public QWidget
{
    Q_OBJECT

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

signals:
    void my_signal_mul();//"X" 按钮  的信号函数
    void my_signal_back();//返回  按钮  的信号函数
    void my_signal_jump_back();//返回  登录页面  的信号函数

public slots:
    void jump_slot();//第二个界面准备的槽函数
    void my_slot_mul();//"X" 按钮  的槽函数
    void my_slot_back();//返回  按钮  的槽函数

private:
    Ui::Second *ui;


protected:
    //重写鼠标按下事件
    void mousePressEvent(QMouseEvent *event) override;
    //重写鼠标移动事件
    void mouseMoveEvent(QMouseEvent *event) override;

private:
    QPoint dragPosition;//声明一个坐标点
};

#endif // SECOND_H

second.cpp文件:

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

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

    this->setWindowFlag(Qt::FramelessWindowHint);//设置纯净窗口

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

    QMovie *mv = new QMovie(":/QQ/zz.gif");//设置一个动图对象接收动图
    ui->label_top->setMovie(mv);//将动图设置到顶部标签中
    mv->start();//让动图动起来
    ui->label_top->setScaledContents(true);//让图片自适应
    ui->label_top->setStyleSheet("border-radius:5px");//设置边框圆角

    connect(ui->btn_mul, &QPushButton::clicked, this, &Second::my_slot_mul);//"X" 按钮  连接  槽函数

    connect(ui->btn_back, &QPushButton::clicked, this, &Second::my_slot_back);//“返回”  按钮  连接  槽函数

}

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

void Second::jump_slot()
{
    this->show();//显示
}


//重写鼠标按下事件
void Second::mousePressEvent(QMouseEvent *event) {
    // 当按下鼠标左键时记录当前位置
    if (event->button() == Qt::LeftButton) {
        dragPosition = event->globalPos();
        event->accept();
    }
}


//重写鼠标移动事件
void Second::mouseMoveEvent(QMouseEvent *event) {
    // 当移动鼠标时移动窗口
    if (event->buttons() & Qt::LeftButton) {
        move(this->x() + event->globalPos().x() - dragPosition.x(),
             this->y() + event->globalPos().y() - dragPosition.y());
        dragPosition = event->globalPos();
        event->accept();
    }
}

// “X” 按钮对应的槽函数
void Second::my_slot_mul()
{
    this->close();//点击  “X”  按钮   关闭整个窗口
}

//“返回”  按钮  对应的  槽函数
void Second::my_slot_back()
{
    this->close();//关闭当前窗口
    emit my_signal_jump_back();//触发信号
}

 qss语句:

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

QFrame#frame{
	border-radius:5px;
}

QPushButton{
	color: rgb(255, 255, 255);

	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(81, 81, 81, 120), stop:1 rgba(255, 255, 255, 255));

	border-radius:5px;
}

QPushButton:hover{
	color: rgb(255, 255, 255);

	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(85, 81, 81, 120), stop:1 rgba(255, 255, 255, 255));

	border-radius:5px;
}

QPushButton:pressed{  /*鼠标按下*/
	color: rgb(255, 255, 255);

	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(85, 81, 81, 120), stop:1 rgba(255, 255, 255, 255));

	border-radius:5px;

	padding-top:5px;
	padding-left:5px;
}

QPushButton#btn_mul{
	background-color: rgba(106, 102, 116, 0);

	border: none;
}

        主函数:

main.c文件:

#include "widget.h"
#include "second.h"

#include <QApplication>

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

    Second s;//实例化第二个界面

    QObject::connect(&w, &Widget::my_jump, &s, &Second::jump_slot);//登陆页面  跳转到  第二个页面

    QObject::connect(&s, &Second::my_signal_jump_back, &w, &Widget::my_slot_jump_back);//第二个页面  跳转到  登陆页面

    return a.exec();
}

实现效果:

 

标签:void,嵌入式,学习,ui,login,my,event,255
From: https://blog.csdn.net/qq_46068832/article/details/139756923

相关文章

  • clip_en的使用学习
    代码分析importtorchimportcn_clip.clipasclipfromPILimportImagefromcn_clip.clipimportload_from_name,available_modelsprint("Torchversion:",torch.__version__)device="cuda"iftorch.cuda.is_available()else"cpu"......
  • 【简单讲解下OneFlow深度学习框架】
    ......
  • 【减法网络】Minusformer:通过逐步学习残差来改进时间序列预测
    摘要本文发现泛在时间序列(TS)预测模型容易出现严重的过拟合。为了解决这个问题,我们采用了一种去冗余的方法来逐步恢复TS的真实值。具体来说,我们引入了一种双流和减法机制,这是一种深度Boosting集成学习方法。通过将信息聚合机制从加法转向减法,对普通的Transformer进行了改......
  • spring的问题-能耗、学习曲线
    说实话,在过去将近20年中,spring对于it行业的帮助还是很大的,尤其是信息系统建设方面。但在我看来,spring的发展也许进入了一个困局。 开始的时候,spring的确是一个还是算小巧的工具,但是现在已经变成了一个庞杂的大东西。的确,它好像什么都可以解决,但是变得过于繁复,庞大,性能上也有......
  • 嵌入式 Linux 基础:环境配置(Debian 12 安装配置)
    目录一、安装虚拟机1、安装VMwareWorkstationPro注册博通官网注册账号下载VMwareWorkstationPro2、虚拟机安装Debian12下载Debian12镜像虚拟机设置配置(安装)debian12配置debian12环境3、配置Debian12软件设置Flatpak和Flathub安装微信二、其他开发环境配置一、安......
  • 机器学习day1
    机器学习day11.环境准备pythonPython是一种解释型、面向对象、动态数据类型的高级程序设计语言。Python由GuidovanRossum于1989年底发明,第一个公开发行版发行于1991年。像Perl语言一样,Python源代码同样遵循GPL(GNUGeneralPublicLicense)协议。pycharm......
  • SingletonKit单例源码阅读学习
    阅读学习QFramwork中的SingletonKit源码。Singleton普通类的单例作为最常用的单例模块,通过继承单例泛型类来实现,需要私有构造;//使用第一种接口单例方式internalclassClass2Singleton:Singleton<Class2Singleton>{//记录被初始化的次数privat......
  • maven学习笔记
    maven学习笔记https://www.bilibili.com/video/BV1nx4y1U755/?p=3&spm_id_from=pageDriver&vd_source=d4fa9dbf28bc50f3509f7caf41d36abd1.什么是Maven1.1.Maven的概念Maven是自动化构建工具。Maven是Apache软件基金会组织维护的一款自动化构建工具,专注服务于Java平......
  • 计算机组成原理学习 Part 2
    系统总线总线连接各个部件的信息传输线,是各个部件共享的传输介质结构单总线面向CPU的双总线以存储器为中心的双总线三总线三总线的又一形式四总线分类片内总线:芯片内部的总线系统总线:计算机各部件之间的信息传输线\[ \begin{cases} 数据总线&双向\quad......
  • 系统地学习Lua编程语言,掌握其基础知识并应用于实际项目中;Lua编程语言中级开发的大纲,涵
    学习Lua编程语言的初级开发大纲可以帮助你系统性地掌握这门语言的基础知识。下面是一个详细的大纲,从基础语法到基本的编程概念,再到一些实用的库和工具。Lua初级开发大纲1.Lua简介Lua的历史与特点Lua的应用场景安装与配置Lua环境2.基础语法注释:单行注释和多行注释......