整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

Qt为什么站稳c++GUI的top1

Qt为什么站稳c++GUI的top1

什么现在QT越来越成为c++界面编程的第一选择,从事QT编程多年,在这之前做C++界面都是基于MFC。

当时为什么会从MFC转到QT?主要原因是MFC开发界面想做得好看一些十分困难,引用第三方基于MFC的界面库代码也是比较混乱,当时主要看到qt有qss样式设计这个功能,可以尝试试下。当项目移植到到QT后,觉得MFC真的是可以抛弃了,MFC相对于QT缺点实在太多。最终一定要抛弃MFC的原因是,代码需要从windows移植到linux下,所以MFC的一个致命的缺陷,没法跨平台

Qt为什么站稳c++GUI的top1

1. 工具软件丰富

QT不仅提供了功能丰富的SDK开发包,还提供了强大的工具,这也是我们选择他的原因之一。

基于VS的插件qt-vs-addin

qt的手册还是比较完备,并且包含了很多示例的源码。

?

基于XML的界面设计器Qt Designer,应该是c++领域最方便的界面设计器。

?

跨平台的开发工具 QtCreator,跨平台的c++开发工具,应该是在linux上最方便的c++开发调试工具,就算不用QT库,也可以用它来开发跨平台的c++项目,这是qt成为top1最牛逼的因素

?

2. 功能库丰富

除了提供了界面库之外,还提供了音频库,3d库,数据库SDK,WebEngine,网络库等,让我们做跨平台程序变得简便。

3. 开源并跨平台

可以自己通过QT源码进行移植,这是成为top1的第二牛逼因素,qt官方就已经提供了再windows,Android,ios,linux中运行的SDK

4. 架构的优势

界面源码与用户源码的隔离,qt的策略是没有界面都会生成一个对应的源码,比如有一个界面设计文件xps.ui 它会解析其中的xml生成一个对应了ui_xps.h 文件,这个文件你不需要修改,如果要调用界面中的控件直接通过 Ui::XPSClass ui; 这个对象定义也是写在ui_xps.h中。也就是你的业务逻辑就和界面控件对象的创建和设置做了隔离。

事件处理的便捷(灵活的信号槽机制),qt提供了信号槽机制,可以很好的降低耦合,提升代码的复用性,这是成为top1的第三牛逼因素

5. 及其便捷的样式设计(像开发web程序一样设计界面)

可以很容易的做一个圆角边框,并且有渐变效果,鼠标移上去还发生变化,可以参考下面的样式表,qss基本和css类似,包括支持css的选择器,这是成为top1的第四牛逼因素,可以通过类名,对象名,和父类名称来设置。

6.有未来

如果问Qt的未来会如何,我觉得是稳中有进。之所以稳,是因为Qt原本有优势的领域,未来依然有优势,毕竟要求高性能,支持非windows系统,还要开发效率高,Qt的竞争者并不多。

而有进,是因为随着国产化的推进,许多软件需要国产化替代,这一两年我看到有很多使用Qt的新项目,我觉得是个好兆头。

使用QJSEngine引擎编译和运行JavaScript脚本时,你可以将JavaScript代码保存在一个独立的文件中,并使用QFile读取该文件内容,然后使用QJSEngine的evaluate()方法执行该代码。下面是一个示例,演示如何加载并执行一个独立的JavaScript文件:

#include <QCoreApplication>
#include <QDebug>
#include <QFile>
#include <QJSEngine>
#include <QJSValue>

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    // 读取JavaScript文件内容
    QFile file("script.js");
    if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) {
        qDebug() << "Failed to open script file!";
        return -1;
    }
    QString script=file.readAll();
    file.close();

    QJSEngine engine;

    // 执行JavaScript脚本
    QJSValue result=engine.evaluate(script);

    // 检查结果并输出
    if (result.isNumber()) {
        int sum=result.toInt();
        qDebug() << "Sum: " << sum;
    } else {
        qDebug() << "Error evaluating script!";
    }

    return a.exec();
}

在上面的示例中,我们首先使用QFile打开并读取名为"script.js"的JavaScript文件的内容。然后,我们创建了一个QJSEngine对象,并使用evaluate()方法执行从文件中读取的JavaScript代码。最后,我们检查结果的类型并输出。

确保将实际的JavaScript文件命名为"script.js"并与可执行文件位于同一目录下。你可以在JavaScript文件中编写复杂的功能,包括定义函数、使用对象等。

这是一个简单的示例,演示了如何使用QJSEngine引擎加载和执行一个独立的JavaScript文件

、Qt界面美化教程

Qt界面美化是基于Qt框架实现的一种美化方式。要实现一个漂亮的Qt界面,需要掌握 Qt 相关的各种美化技巧。以下是一些 Qt 界面美化教程。

1. 使用QSS进行界面美化

QSS是一种基于CSS语法的Qt样式表,用来定义控件的样式和外观。通过对QSS进行修改,可以轻松地美化应用程序的界面样式。

// 设置按钮颜色和字体
QPushButton {
    background-color: #333;
    border: none;
    color: #FFF;
    font-size: 16px;
}

// 设置标签颜色和字体
QLabel {
    color: #333;
    font-size: 16px;
}

2. 使用Qt Designer进行界面美化

Qt Designer 是一种可视化的Qt界面设计工具,可以通过拖拽控件、修改属性等方式轻松地设计和美化Qt界面。在使用Qt Designer时,可以选择不同的Qt风格,使界面更加漂亮。

下面是一个使用Qt Designer进行界面设计的示例:


# mainwindow.ui
从 Qt Designer 中导出的代码

3. 使用第三方美化工具进行界面美化

除了使用Qt Designer和QSS进行界面美化,还可以使用一些第三方的美化工具,如 Qt Beautifier、qdarkstyle、qsseditor 等。这些工具可以帮助我们更加方便、快捷地实现 Qt 界面美化。

下面是一个使用qdarkstyle进行界面美化的示例:


# main.py
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow
import qdarkstyle

class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.setStyleSheet(qdarkstyle.load_stylesheet())
        self.show()

if __name__=="__main__":
    app=QApplication(sys.argv)
    window=MainWindow()
    sys.exit(app.exec_())

二、Qt界面美化设计

Qt界面美化设计主要包括颜色设计、图标设计、字体设计和布局设计等方面。下面分别详细介绍。

1. 颜色设计

颜色设计是界面美化中非常重要的一部分。通过选择合适的颜色搭配,可以使界面更加美观、舒适。在进行颜色设计时,可以参考网上的配色方案或自行调整。

以下是一个使用自定义颜色设计QSS的示例代码:


// 设置按钮颜色和字体
QPushButton {
    background-color: #FF9900;
    border: none;
    color: #FFF;
    font-size: 16px;
}

// 设置标签颜色和字体
QLabel {
    color: #333;
    font-size: 16px;
}

2. 图标设计

图标设计是Qt界面美化中另一个重要的方面。一个好的图标可以使应用程序更加吸引人、易于使用。可以自己设计图标,也可以从网上下载各种风格的图标应用到自己的程序中。

以下是一个使用自定义图标替换按钮图标的示例代码:


# main.py
import sys
from PyQt5.QtGui import QIcon
from PyQt5.QtWidgets import QApplication, QPushButton

if __name__=="__main__":
    app=QApplication(sys.argv)
    button=QPushButton("Click me!")
    button.setIcon(QIcon("icon.png"))
    button.show()
    sys.exit(app.exec_())

3. 字体设计

字体设计也是Qt界面美化中的一个重要方面。我们可以选择不同的字体、字号和字体颜色,使界面更加美观。在选择字体时,应考虑字体的易读性和视觉效果。

以下是一个使用自定义字体设置QSS的示例代码:


// 设置按钮颜色和字体
QPushButton {
    background-color: #FF9900;
    border: none;
    color: #FFF;
    font-size: 16px;
    font-family: SimSun;
}

// 设置标签颜色和字体
QLabel {
    color: #333;
    font-size: 16px;
    font-family: SimSun;
}

4. 布局设计

布局设计是Qt界面美化中的一个关键方面。我们可以通过设置布局方式、调整控件的位置和大小,使界面更加合理、美观、易于使用。

【文章福利】Qt开发学习资料包、大厂面试题、技术视频和学习路线图,包括(Qt C++基础,数据库编程,Qt项目实战、Qt框架、qt线程等等)有需要的可以进企鹅裙661714027领取哦~

以下是一个使用水平布局和垂直布局布局控件的示例代码:


# main.py
import sys
from PyQt5.QtWidgets import QApplication, QHBoxLayout, QPushButton, QVBoxLayout, QWidget

if __name__=="__main__":
    app=QApplication(sys.argv)
    widget=QWidget()
    layout1=QHBoxLayout()
    layout2=QVBoxLayout()
    button1=QPushButton("Button 1")
    button2=QPushButton("Button 2")
    button3=QPushButton("Button 3")
    layout1.addWidget(button1)
    layout1.addWidget(button2)
    layout2.addWidget(button3)
    layout2.addLayout(layout1)
    widget.setLayout(layout2)
    widget.show()
    sys.exit(app.exec_())

三、Qt界面美化库选取

Qt界面美化库可以帮助我们更加方便、快捷地实现界面美化。根据需求不同,可以选择不同的美化库。

1. PyQTGraph

PyQTGraph是一个用于科学计算和数据分析的绘图库,特别适用于Qt界面的绘图。PyQTGraph可以创建各种类型的图表,如线性图、散点图、柱状图、等高线图等。PyQTGraph还有许多其他功能,如数据缓存、软件渲染等。

以下是一个PyQTGraph绘制图表的示例代码:


# main.py
import sys
import numpy as np
import pyqtgraph as pg
from PyQt5.QtWidgets import QApplication, QMainWindow

class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        pg.setConfigOptions(antialias=True)
        self.setWindowTitle("PyQTGraph")
        self.setGeometry(100, 100, 640, 480)
        self.plotWidget=pg.PlotWidget(self, background="w")
        self.setCentralWidget(self.plotWidget)
        x=np.linspace(0, 3 * np.pi, 500)
        y=np.sin(x) + np.random.normal(size=500, scale=0.2)
        self.plotWidget.plot(x, y, pen=pg.mkPen("b", width=1))
        self.show()

if __name__=="__main__":
    app=QApplication(sys.argv)
    window=MainWindow()
    sys.exit(app.exec_())

2. PyQtGraphicalEffects

PyQtGraphicalEffects是一个用于绘制特效的库,包括模糊、阴影、光辉、亮度、色彩转换等。使用PyQtGraphicalEffects可以使界面更加生动、有趣。

以下是一个PyQtGraphicalEffects添加阴影效果的示例代码:


# main.py
import sys
from PyQt5.QtWidgets import QApplication, QLabel, QMainWindow
from PyQt5.QtGui import QColor
from PyQtGraphicalEffects import applyShadowEffect

class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("PyQtGraphicalEffects")
        self.setGeometry(100, 100, 320, 240)
        label=QLabel(self)
        label.setText("Hello World")
        label.setGeometry(50, 50, 200, 50)
        applyShadowEffect(label, QColor(0, 0, 0, 50), 10, 0, 0, 0)
        self.show()

if __name__=="__main__":
    app=QApplication(sys.argv)
    window=MainWindow()
    sys.exit(app.exec_())

3. QDarkStyleSheet

QDarkStyleSheet是一种基于QSS的Qt主题,用于实现暗色主题。使用QDarkStyleSheet可以使界面更加美观、护眼,特别适用于长时间使用的应用程序。

以下是一个使用QDarkStyleSheet实现暗色主题的示例代码:


# main.py
import sys
from PyQt5.QtGui import QFontDatabase
from PyQt5.QtWidgets import QApplication, QMainWindow
import qdarkstyle

class MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.setStyleSheet(qdarkstyle.load_stylesheet_pyqt5())
        self.setWindowTitle("QDarkStyleSheet")
        self.setGeometry(100, 100, 640, 480)
        self.show()

if __name__=="__main__":
    app=QApplication(sys.argv)
    QFontDatabase.addApplicationFont("./fonts/Quicksand-Regular.ttf")
    window=MainWindow()
    sys.exit(app.exec_())

4. QSS-Borderless-Window

QSS-Borderless-Window是一种用于实现无边框窗口的库。使用QSS-Borderless-Window可以使界面更加简洁、美观。

以下是一个使用QSS-Borderless-Window实现无边框窗口的示例代码: