当前位置: 首页 > article >正文

基于Qt的qss登录界面优化

目标

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

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

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

代码及实现效果

界面一qss

*{
	background-color: rgb(255, 255, 255);
}
QFrame#frame{
	
	border-image: url(:/picture/kda-poster-02.8ba864.jpg);
	border-radius:20px;
}
#frame_2{
	
	background-color: rgba(100, 100, 100, 50);
	border-radius:20px;
}
QLabel#label{
	
	background-color: rgba(100, 100, 100, 140);
	border-radius:20px;
}
#label_2{
	
	font: 25 12pt "微软雅黑";
	background:transparent;
	
	color: rgba(255, 255, 255, 200);
}
QLineEdit{
	background:transparent;
	border:none;
	color: rgba(255, 255, 255, 200);
	border-bottom:1px solid rgba(255, 255, 255, 200);
}
QPushButton{
	
	font: 10pt "微软雅黑";
	color: rgb(255, 255, 255);
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(186, 33, 198, 255), stop:1 rgba(179, 215, 255, 255));
	border-radius:5px;
}
QPushButton:hover{/*鼠标移动*/
	
	font: 10pt "微软雅黑";
	color: rgb(255, 255, 255);
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(200, 33, 198, 255), stop:1 rgba(179, 215, 255, 255));
	border-radius:5px;
}
QPushButton:pressed{/*鼠标按下*/
	font: 10pt "微软雅黑";
	color: rgb(255, 255, 255);
	background-color: qlineargradient(spread:pad, x1:0, y1:0, x2:1, y2:1, stop:0 rgba(186, 33, 198, 255), stop:1 rgba(179, 215, 255, 255));
	border-radius:5px;
	padding-top:5px;
	padding-left:5px;
}

界面一头文件

#ifndef WIDGET_H
#define WIDGET_H
#include <QDebug>
#include <QWidget>

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT
public slots:
    void my_close();
public:
    Widget(QWidget *parent = nullptr);
    ~Widget();
signals:
    void my_log();
private slots:
    void on_logbutt_clicked();

private:
    Ui::Widget *ui;
};
#endif // WIDGET_H

界面二头文件

#ifndef LOGWINDOW_H
#define LOGWINDOW_H

#include <QWidget>
#include <Qicon>
namespace Ui {
class logwindow;
}

class logwindow : public QWidget
{
    Q_OBJECT
public slots:
    void log_in();
public:
    explicit logwindow(QWidget *parent = nullptr);
    ~logwindow();

private:
    Ui::logwindow *ui;
};

#endif // LOGWINDOW_H

界面一功能函数

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

void Widget::my_close()
{
    close();
}

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    this->setWindowIcon(QIcon(":/picture/lol.webp"));
    this->setWindowTitle("英雄联盟");
    ui->setupUi(this);
    this->setWindowFlag(Qt::FramelessWindowHint);
    this->setAttribute(Qt::WA_TranslucentBackground);
    connect(ui->cbutt,SIGNAL(clicked()),this,SLOT(my_close()));
}

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


void Widget::on_logbutt_clicked()
{
    if((ui->namelet->text()=="admin")||(ui->passwordle->text()=="123456")){
        this->close();
        emit my_log();
        qDebug()<<"登录成功"<<endl;
    }else{
        qDebug()<<"登录失败"<<endl;
        ui->passwordle->setText("");
    }
}

界面二功能函数

#include "logwindow.h"
#include "ui_logwindow.h"



logwindow::logwindow(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::logwindow)
{
    ui->setupUi(this);
    this->setWindowIcon(QIcon(":/picture/lol.webp"));
    this->setWindowTitle("英雄联盟");
}

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

void logwindow::log_in()
{
    this->show();
}

主函数

#include "widget.h"
#include "logwindow.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();
    logwindow l;
    QObject::connect(&w,&Widget::my_log,&l,&logwindow::log_in);
    return a.exec();
}

实现效果

打开界面

登录失败

登录成功

知识点思维导图


http://www.kler.cn/a/457300.html

相关文章:

  • 【LC】3083. 字符串及其反转中是否存在同一子字符串
  • 【JAVA】神经网络的基本结构和前向传播算法
  • es单机安装脚本自动化
  • ArcGIS JSAPI 高级教程 - 通过RenderNode实现视频融合效果(不借助三方工具)
  • 绘制三元图、颜色空间图:R语言代码
  • 【LLM】Langflow 的简单使用
  • 深入解析Spring Boot中的@ConfigurationProperties注解
  • 深入理解 LeetCode 978:最长湍流子数组
  • FPGA随记---时序约束
  • API安全学习笔记
  • QML学习(三) QML 的基本语法介绍
  • Yocto 项目中的交叉编译:原理与实例
  • 若依整合 Gitee 登录
  • BGP路由常用的属性
  • C语言-详细讲解-给定数字n,生成共有n个括号的所有正确的形式
  • Stream `Collectors.toList()` 和 `Stream.toList()` 的区别(Java)
  • python 不应该将列表作为函数的默认参数
  • 工业大数据分析算法实战-day14
  • 【每日学点鸿蒙知识】节点析构问题、区分手机和pad、 Navigation路由问题、Tabs组件宽度、如何监听Map
  • Sql Sqserver 相关知识总结
  • 【每日学点鸿蒙知识】Web组件加载空白、C++回调ArkTS、底部横幅隐藏显示、构建warn过多、ArkTS与C++实时通信
  • 深入了解SpringIoc(续篇)
  • Docmatix:突破性的文档视觉问答数据集
  • 从头开始学SpringMVC—01MVC介绍和入门案例
  • ​Python数据序列化模块pickle使用
  • 如何快速又安全的实现端口转发【Windows MAC linux通用】