Qt漂亮界面


原文链接:
https://blog.csdn.net/kissgoodbye2012/article/details/120404744?spm=1001.2101.3001.6650.13&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-13.pc_relevant_antiscanv2&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-13.pc_relevant_antiscanv2&utm_relevant_index=22

要做一个类似下面的qt界面,顶部是导航栏的样子——包含图标和程序名称,右边是界面切换按钮,然后放大、缩小和关闭按钮也在,还能拖动。这样,就更像一个商用的软件了。
在这里插入图片描述

功能规划:

1.去掉菜单栏、工具栏;
2.顶部导航栏包含程序图标、名称、界面切换按钮、放大缩小关闭按钮;
3.顶部导航栏可以拖动;
4.导航栏按钮可以切换界面。

可以参考的相关博客链接

一、去掉菜单栏和工具栏

在UI设计界面,在menuBar和mainToolBar上右键,选择移除菜单栏和移除工具栏。
在这里插入图片描述
把顶部的图标和程序名称、放大缩小关闭按钮都去掉,使用如下语句。

this->setWindowFlags(Qt::FramelessWindowHint | Qt::WindowSystemMenuHint | Qt::WindowMinMaxButtonsHint);

二、顶部导航栏的设计

主要是用installEventFilter来实现的。参考第6章节。
这个顶部导航栏是通过注册监听事件,让app监控所有的程序事件。如果属性是可移动的,然后记录鼠标的坐标等,来控制窗口的位置和大小。

appinit.h头文件

#ifndef APPINIT_H
#define APPINIT_H

#include <QObject>

class AppInit : public QObject
{
    Q_OBJECT
public:
    static AppInit *Instance();
    explicit AppInit(QObject *parent = 0);    

    void start();

protected:
    bool eventFilter(QObject *obj, QEvent *evt);

private:
    static AppInit *self;

signals:

public slots:
};

#endif // APPINIT_H

appinit.cpp的文件

#include "appinit.h"
#include "qmutex.h"
#include "qapplication.h"
#include "qevent.h"
#include "qwidget.h"

AppInit *AppInit::self = 0;
AppInit *AppInit::Instance()
{
    if (!self) {
        QMutex mutex;
        QMutexLocker locker(&mutex);
        if (!self) {
            self = new AppInit;
        }
    }

    return self;
}

AppInit::AppInit(QObject *parent) : QObject(parent)
{
}

bool AppInit::eventFilter(QObject *obj, QEvent *evt)
{
    QWidget *w = (QWidget *)obj;
    //如果窗口w的属性“canMove"是假的,继续监听
    if (!w->property("canMove").toBool()) {
        return QObject::eventFilter(obj, evt);
    }

    //如果属性是可移动
    static QPoint mousePoint;
    static bool mousePressed = false;

    //获取鼠标事件
    QMouseEvent *event = static_cast<QMouseEvent *>(evt);
    if (event->type() == QEvent::MouseButtonPress) {
        //如果鼠标被按下,且是左键按下
        if (event->button() == Qt::LeftButton) {
            mousePressed = true;
            //记下当前坐标:全局坐标-窗口坐标
            mousePoint = event->globalPos() - w->pos();
            return true;
        }
        //如果鼠标松开
    } else if (event->type() == QEvent::MouseButtonRelease) {
        mousePressed = false;
        return true;
        //如果鼠标在移动
    } else if (event->type() == QEvent::MouseMove) {
        if (mousePressed && (event->buttons() && Qt::LeftButton)) {
            //移动当前窗口到某个位置
            w->move(event->globalPos() - mousePoint);
            return true;
        }
    }

    return QObject::eventFilter(obj, evt);
}

void AppInit::start()
{
    qApp->installEventFilter(this);
}

使用方式:

//函数功能:让自定义的顶部导航栏可以拖动
    AppInit::Instance()->start();

三、阵列按钮的点击事件写法

当我们有一排按钮需要程序来添加点击事件时,如果一个个connect那么代码就太长了,connect需要写,它们的槽函数又要单独写,而这些按钮响应的事件处理又差不多。那么可以用如下的写法,立马让你成为QT中级程序员的感觉。
在这里插入图片描述
使用findChildren函数找到某个widget下所有的按钮,如下面代码所示。

//设置顶部导航按钮
    QList<QToolButton *> tbtns = ui->widgetTop->findChildren<QToolButton *>();
    foreach (QToolButton *btn, tbtns) {
        btn->setIconSize(icoSize);
        btn->setMinimumWidth(icoWidth);
        btn->setCheckable(true);
        connect(btn, SIGNAL(clicked()), this, SLOT(buttonClick()));
    }

首先,findChildren函数找到了widgetTop下的所有QToolButton类型按钮。
然后,给每一个按钮设置图标尺寸,宽度和可选择属性,然后连接connect到buttonClick()槽函数。
槽函数代码如下:

void UIDemo01::buttonClick()
{
    QToolButton *b = (QToolButton *)sender();
    //获取当前点击事件按钮的名称
    QString name = b->text();

    QList<QToolButton *> tbtns = ui->widgetTop->findChildren<QToolButton *>();
    foreach (QToolButton *btn, tbtns) {
        if (btn == b) {
            //如果是当前点击事件的按钮,将其设为选中状态
            btn->setChecked(true);
        } else {
            //如果不是当前点击事件的按钮,将其设为未选中状态
            btn->setChecked(false);
        }
    }

    if (name == "主界面") {
        ui->stackedWidget->setCurrentIndex(0);
    } else if (name == "系统设置") {
        ui->stackedWidget->setCurrentIndex(1);
    } else if (name == "警情查询") {
        ui->stackedWidget->setCurrentIndex(2);
    } else if (name == "调试帮助") {
        ui->stackedWidget->setCurrentIndex(3);
    } else if (name == "用户退出") {
        //退出程序
        exit(0);
    }
}

这个槽函数,首先使用sender()函数获得了发生点击事件的那个QToolButton类型按钮的句柄。
然后,将其设为选中状态,将其他的按钮设为未选中状态;
最后,根据按钮的名称来选择跳转到的主界面。

四、重写缩写界面、放大界面和关闭程序事件

首先,在.h文件中注册这些函数

private slots:
    void on_btnMenu_Min_clicked();
    void on_btnMenu_Max_clicked();
    void on_btnMenu_Close_clicked();

然后,直接重写这些函数即可。

void UIDemo01::on_btnMenu_Min_clicked()
{
    //qt自带函数
    showMinimized();
}

void UIDemo01::on_btnMenu_Max_clicked()
{
    //静态定义变量,只在第一次使用
    static bool max = false;
    //静态定义变量获得尺寸
    static QRect location = this->geometry();

    //记忆放大前的窗口尺寸,方便取消最大化时返回原位置和大小
    if (max) {
        this->setGeometry(location);
    } else {
        //保存当前的窗口尺寸
        location = this->geometry();
        //设置界面可达的最大尺寸
        this->setGeometry(qApp->desktop()->availableGeometry());
    }

    //最大化就不能移动了
    this->setProperty("canMove", max);
    max = !max;
}

void UIDemo01::on_btnMenu_Close_clicked()
{
    //qt自带函数
    close();
}

五、鼠标事件的处理

有时我们需要捕获某个控件上的鼠标事件,比如这个界面在导航栏双击可以最大化和取消最大化。
首先,在.h文件中注册bool eventFilter(QObject *watched, QEvent *event);函数

protected:
    bool eventFilter(QObject *watched, QEvent *event);

然后,给需要捕获鼠标事件的控件添加鼠标事件注册

ui->widgetTitle->installEventFilter(this);//顶部导航栏注册鼠标事件

最后,在鼠标事件中编写处理程序

bool UIDemo01::eventFilter(QObject *watched, QEvent *event)
{
    //如果是鼠标双击事件
    if (event->type() == QEvent::MouseButtonDblClick) {
        //如果发生的控件是 ui->widgetTitle
        if (watched == ui->widgetTitle) {
            //调用发生最大化的函数
            on_btnMenu_Max_clicked();
            return true;
        }
    }

    //我们处理了点击事件,把事件返回到上层,让它们继续处理其他事件
    return QWidget::eventFilter(watched, event);
}

六、installEventFilter的使用
installEventFilter的使用参考
简述:
事件过滤器,可以实现一个QObject监视另一个QObject的所有事件,但是两个QObject必须在同一个线程内

使用:
被监视者(ui->widge)安装事件过滤器

 ui->widget->installEventFilter(this);

在监视者(this)里重新实现eventFilter()函数,此函数返回false时,表示监视者(this)不过滤此事件,事件将会继续发送到被监视者(ui->widge);返回true时表示监视者过滤此事件,事件将不会发送到被监视者。

bool CustomerSwitchet::eventFilter(QObject *obj,QEvent *e)
{
    QWidget*wid = qobject_cast<QWidget*>(obj);
    if(wid==ui->widget)
    {
    	//根据事件类型,写处理逻辑
       qDebug()<<"widget";
    }
    return  false;
}

Qt大量同类控件的操作

https://blog.csdn.net/kissgoodbye2012/article/details/121725580
当前,我需要解决如下的一个问题:
有一个曲线图,包含有1条显性主曲线和31条隐性类正态分布曲线(所谓的显性和隐性,指的是曲线是一直显示的,还是在拖动它的控制点时才显示)。显性主曲线是31条隐性类正态分布曲线之和。每条类正态分布曲线有3个控制点,控制点可以拖动,这3个控制点代表这条类正态分布曲线曲线的中心频率、Q值和增益。
如果离散的分别进行操作,虽然也能实现功能,但所有东西都是搅在一起的,且代码量肯定很大。这里使用一个类来理清关系。

正则表达式的设计

https://blog.csdn.net/kissgoodbye2012/article/details/121938706

正则表达式是用于描述符合某些复杂规则的字符串的工具,也就是用来匹配字符串的。


Qt 手把手教你实现漂亮的登录界面


原文链接:https://blog.csdn.net/qq_16488989/article/details/108884580

前言

最近在使用Qt5,Qt Creator做一个管理系统类的项目,自然需要用到登录界面,故记录一下登录界面的制作。其中一些功能的实现也得益于之前Qt5基础视频不规则窗口部分的学习。

一、手把手教你实现漂亮的登录界面

首先看一下成品。
在这里插入图片描述

第一步、新建一个Qwidget项目

没必要用qmainwindow,不需要那些菜单,一般用qwidget就可以,注意勾选ui。
在这里插入图片描述

第二步、添加界面组件

1、添加容器
在这里插入图片描述
调整容器为合适大小,同时调整整个画布为合适大小。
在这里插入图片描述
2、添加按钮,标签,文字组件
构思:
账号密码部分使用Input Widgets:Line Edit
Logo和忘记密码使用两个Display Widgets:TextLabel
是否记住我选择一个Buttons:CheckBox
登录按钮使用Buttons:PushButton

在这里插入图片描述

3、修改组件名称
首先修改Line Edit默认文本属性,分别点击两个LineEdit修改文本属性为Username和Password。
在这里插入图片描述
然后其他的按钮文本标签直接双击修改名称即可。
在这里插入图片描述
以上两步之后,可以得到这个样子(这里统一在Wighets右边的菜单里修改过字体,一会可以通过样式表统一去改)。
在这里插入图片描述
4、添加样式表
类似于css,Qt具有Qss,最为关键的一步就是添加样式表。在Frame容器外 画布内 右键改变样式表,输入以下代码。

*{
background:rgb(255, 255, 255);
font-size:15px;
font-style:MingLiU-ExtB;
}
QFrame{
border:sold 10px rgba(0,0,0);
background-image:url(H:/GUI_design/day04/image/Login_Blue5);//背景
}
QLineEdit{
color:#8d98a1;
background-color:#405361;
font-size:16px;
border-style:outset;
border-radius:10px;
font-style:MingLiU-ExtB;
}
QPushButton{
background:#ced1d8;
border-style:outset;
border-radius:10px;
font-style:MingLiU-ExtB;
}
QPushButton:pressed{
background-color:rgb(224,0,0);
border-style:inset;
font-style:MingLiU-ExtB;
}
QCheckBox{
background:rgba(85,170,255,0);
color:white;
font-style:MingLiU-ExtB;
}
QLabel{
background:rgba(85,170,255,0);
color:white;
font-style:MingLiU-ExtB;
font-size:14px;
}

背景部分找“度娘”就可以。
在这里插入图片描述
应用样式表后展示。
在这里插入图片描述

第三步、实现最小化窗口和关闭窗口功能

1、添加最小化和关闭窗口按钮
按钮选择Buttons:Tool Button,最小化采用-,关闭窗口采用x。
在这里插入图片描述
2、按钮转到槽
将两个按钮都转到槽。
在这里插入图片描述
3、代码示例
转到槽之后,只需要在相应的函数里添加close()和showMinimized()功能即可。具体的代码如下。

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>

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

    void on_toolButton_2_clicked();

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

main.cpp

#include "widget.h"

#include <QApplication>

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

widget.cpp

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

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

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

//核心代码就这几行
void Widget::on_toolButton_clicked()
{
    close();
}

void Widget::on_toolButton_2_clicked()
{
    showMinimized();
}

调整画布到合适大小
在这里插入图片描述

展示如下:

在这里插入图片描述
这个时候我们还需要把Widget自带的上边框去掉,并且去掉背景。

第四步、隐藏widget窗口边框和背景

widget.cpp文件中添加如下两句代码即可。

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    //去窗口边框
        setWindowFlags(Qt::FramelessWindowHint | windowFlags());

    //把窗口背景设置为透明;
        setAttribute(Qt::WA_TranslucentBackground);
}

第五步、实现界面可移动

需要添加一个鼠标移动和鼠标按下事件。以*e来获取鼠标移动或按下。
main.cpp

#include "widget.h"

#include <QApplication>

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

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>

QT_BEGIN_NAMESPACE
namespace Ui { class Widget; }
QT_END_NAMESPACE

class Widget : public QWidget
{
    Q_OBJECT

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

protected:

    void mouseMoveEvent(QMouseEvent *e);//鼠标移动
    void mousePressEvent(QMouseEvent *e);//鼠标按下移动

private slots:
    void on_close_clicked();

    void on_minimized_clicked();


private:
    Ui::Widget *ui;

     QPoint p;
};
#endif // WIDGET_H

widget.cpp

#include "widget.h"
#include "ui_widget.h"
#include <QPainter>
#include <QMouseEvent>


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

    //去窗口边框
        setWindowFlags(Qt::FramelessWindowHint | windowFlags());

    //把窗口背景设置为透明;
        setAttribute(Qt::WA_TranslucentBackground);

}

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


void Widget::mousePressEvent(QMouseEvent *e)
{
    if(e->button() == Qt::LeftButton)
    {
        //求坐标差值
        //当前点击坐标-窗口左上角坐标
        p = e->globalPos() - this->frameGeometry().topLeft();
    }
}

void Widget::mouseMoveEvent(QMouseEvent *e)
{
    if(e->buttons() & Qt::LeftButton)
    {
        //移到左上角
        move(e->globalPos() - p);
    }

}

void Widget::on_close_clicked()
{
    close();
}
void Widget::on_minimized_clicked()
{
    showMinimized();
}

Qt之QWidget设置窗口背景图片的几种方法

原文链接:https://blog.csdn.net/wangbaba_1/article/details/113648465

使用间接的方式来设置背景

比如说在窗口上覆盖一个QLabel,这个label始终与窗口一样大。然后在label中设置图片,视觉效果上和直接给窗口设置背景图片一样。

Widget::Widget(QWidget *parent) :
	QWidget(parent)
{
	m_lblBg = new QLabel(this);
	m_lblBg ->setPixmap(QPixmap(":/bg.jpg"));
	m_lblBg ->setScaledContents(true);
}
void Widget::resizeEvent(QResizeEvent * ev)
{
	m_lblBg->resize(this->size());
}

创建一个label作为Widget的子窗口,然后设置图片。通过在Widget的resizeEvent事件中设置label的大小与Widget一致。这里需要注意调用QLabel的setScaledContents(true),否则效果和第一种一样。由于QLabel可以用来显示动图因此使用这种方式可以实现窗口的动态背景图片。

由于QLabel可以用来显示动图因此使用这种方式可以实现窗口的动态背景图片。

QToolButton 工具按钮

原文链接:https://blog.csdn.net/wangxiaobei2017/article/details/77824938

工具按钮(QToolButton)区别于普通按钮(QPushButton)的一点是,工具按钮(QToolButton)可以带图标,他们两个有同一个父类(QAbstractButton);
工具按钮(QToolButton)有两部分组成:文本text 和 图标icon(建议用png格式的图片)

之后,在QAbstractButton属性选项中的icon下加载图标资源,在text 中修改工具按钮的文本“帮助”。
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

参考连接

qt 如何设计好布局和漂亮的界面

QT-通用的软件界面框架,好看且实用

Qt界面开发(一)(各种控件以及图表)

  • 43
    点赞
  • 483
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: Qt界面设计是指使用Qt框架进行界面设计的过程。Qt是一个跨平台的C++图形用户界面应用程序开发框架,它提供了丰富的UI组件和工具,方便开发人员创建各种类型的界面。 以下是一个使用Qt界面设计的实例: 假设我们要开发一个音乐播放器的界面,我们首先需要打开Qt创建一个新的项目。然后,在Qt的设计模式下,我们可以选择使用Qt Designer来设计图形用户界面。 在Qt Designer中,我们可以通过拖放控件的方式来构建界面。我们可以选择音乐播放器所需的各种UI组件,例如按钮、滑块、进度条等。然后,我们可以对这些组件进行布局和调整,以满足我们的需求。 接下来,我们可以为每个组件添加功能。例如,我们可以为播放按钮添加点击事件,当用户点击播放按钮时,音乐播放器就会开始播放音乐。我们还可以为滑块添加拖动事件,当用户拖动滑块时,可以控制音乐的播放进度。 在Qt Designer中,我们还可以自定义界面的外观。我们可以选择不同的主题、颜色和字体,以使界面更加美观和符合用户的喜好。我们还可以添加背景图片或图标,使界面更具个性。 最后,我们可以通过Qt的编程语言C++来编写界面的逻辑代码。我们可以在代码中连接各个组件,处理用户的操作并对界面做出相应的反应。例如,当音乐播放完成时,我们可以自动切换到下一首歌曲。 总之,Qt界面设计是一个使用Qt框架进行界面开发的过程。通过Qt Designer的可视化设计和Qt的编程语言,我们可以创建出功能丰富、美观的界面,满足用户的需求。 ### 回答2: Qt是一个跨平台的C++图形用户界面开发框架,可以用来创建各种类型的用户界面。在Qt中,界面设计是一个重要的环节,设计出美观、易用且功能强大的界面对于提升用户体验和软件质量至关重要。 下面我以一个简单的登录界面设计为例来说明Qt界面设计的操作步骤和实现方法。 首先,在Qt Creator中创建一个新的Qt Widgets Application项目。然后,在主窗口上拖放所需的控件,例如标签、文本框和按钮等,布局控件的位置和大小。 接下来,通过Qt的设计工具——Qt Designer进行界面设计。打开.ui文件,从工具栏中选择所需的控件,拖放到主窗口上,并进行相应的大小、位置和样式的调整。 在编辑界面的过程中,可以使用Qt Designer提供的属性编辑器来设置控件的属性,例如文本内容、字体颜色和背景颜色等,还可以连接信号和槽函数,以实现响应式功能。 完成界面设计后,需要在代码中实现界面的功能。打开对应的源文件,编写槽函数,将控件和槽函数进行连接,以实现界面逻辑的交互。 在我们的登录界面设计中,通过点击登录按钮,连接登录按钮的clicked信号和自定义的槽函数,实现登录功能。在槽函数中获取用户名和密码,并与事先存储的正确的用户名和密码进行比较验证。如果验证通过,则显示登录成功的提示信息,否则显示登录失败的提示信息。 最后,编译和运行项目,查看界面的显示效果。可以通过调试和测试,进一步完善界面的交互和功能。 通过以上步骤,我们可以实现一个简单的登录界面Qt界面设计。同时,Qt还提供了丰富的控件和功能,可以根据实际需求进行界面设计,开发出更加复杂和丰富的应用程序。 ### 回答3: Qt界面设计是指使用Qt框架进行用户界面设计的过程。Qt是一种跨平台的应用程序框架,它提供了丰富的工具和组件,使开发者可以方便地创建各种精美、功能强大的用户界面。 下面是一个Qt界面设计的实例: 假设我们要设计一个简单的计算器应用程序。首先,我们需要创建一个新的Qt项目并选择合适的界面布局。 在界面设计中,我们可以使用Qt的UI设计器来添加所需的控件,例如按钮、标签和文本输入框。我们可以通过拖拽和放置的方式将这些控件添加到布局上。 为了实现计算器的基本功能,我们需要添加数字按钮、运算符按钮和一个文本显示框。我们可以使用Qt的信号槽机制来连接按钮的点击事件和相应的逻辑处理函数。例如,当用户点击数字按钮时,我们可以将对应的数字追加到文本显示框的内容中。 此外,我们还可以为计算器添加一些额外的功能,例如添加删除按钮和清除按钮,以及实现基本的计算操作,如加法、减法、乘法和除法等。 在设计界面时,我们还应该考虑使用合适的颜色和字体来提升用户体验。Qt提供了丰富的样式和主题选择,以及自定义样式的能力,使得界面可以根据用户的喜好进行调整。 最后,我们需要确保界面的布局和控件的操作方式符合用户的直觉和习惯,以提供良好的用户体验。 综上所述,Qt界面设计能够帮助我们创建出实用、美观、易用的应用程序界面。通过合理利用Qt的工具和组件,我们可以在短时间内完成复杂的界面设计,并为用户提供出色的操作体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值