news 2026/4/15 16:15:59

Qt优雅的组织项目结构一(使用pri进行模块化配置)——————附带详细示例代码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Qt优雅的组织项目结构一(使用pri进行模块化配置)——————附带详细示例代码

文章目录

  • 背景
    • 1 使用pri
      • 1.1 概念
      • 1.2 应用场景
      • 1.3 实践
    • 附录

背景

因为编写qt项目(早期为了快速快发,并没有进行分块),随着文件、代码量的越来越多,导致项目越来约难以管理。例如下面这个项目,光头文件就有几十个。因此需要把项目模块化来进行管理和开发,于是有了此篇文章。

1 使用pri

1.1 概念

.priProject Include(项目包含)文件的缩写。

本质:它的语法和.pro(项目文件)完全一样,都是基于qmake语法。

作用:它不是一个独立的项目,而是一个配置容器。它被设计用来存放那些可以在多个项目之间共享的配置,比如源文件列表、头文件路径、库依赖等。

价值(模块化):**当项目规模变大、团队协作开发时,可以更好的给项目模块化。**避免把所有配置都堆砌在.pro文件中,让项目结构更清晰,代码更易于复用。

1.2 应用场景

    1. 模块化项目管理(推荐)
      当项目包含多个功能模块(如“网络模块”、“数据库模块”、“界面模块”)时,可以为每个模块创建一个.pri文件。
      做法:在每个模块文件夹下新建network.pri、database.pri
      好处:.pro文件变得非常干净,只负责“组合”模块,而不关心模块内部的具体文件。如果要移除某个模块,只需注释掉一行include
    1. 管理第三方库
      如果你的项目需要引入 OpenCV、Boost 等第三方库,或者你自己编译的静态库。
      做法:为每个第三方库创建一个.pri文件(如opencv_config.pri)。
      好处:配置项(头文件路径、库文件路径、链接指令)被封装起来。当你把这个库分享给同事时,直接发一个.pri文件即可,无需口头指导如何配置环境。
    1. 跨平台条件编译
      .pri 文件非常适合处理不同操作系统(Windows, Linux, macOS)下的差异。
      做法:在.pri文件中使用条件判断语句:
win32{LIBS+=-lws2_32 # Windows 特有的库 DEFINES+=OS_WIN}unix:!macx{LIBS+=-lpthread # Linux 特有的库 DEFINES+=OS_LINUX}macx{LIBS+=-framework Cocoa DEFINES+=OS_MAC}

这样,主.pro文件无需关心平台细节,直接include(platform.pri)即可。

1.3 实践

这是一个没有使用pri文件的项目:


pro文件的内容如下:

QT+=core guigreaterThan(QT_MAJOR_VERSION,4):QT+=widgets CONFIG+=c++17#You can make your code fail to compileifit uses deprecated APIs.#In order todoso,uncomment the following line.#DEFINES+=QT_DISABLE_DEPRECATED_BEFORE=0x060000# disables all the APIs deprecated before Qt6.0.0SOURCES+=\ main.cpp \ mainwindow.cpp HEADERS+=\ mainwindow.h FORMS+=\ mainwindow.ui#Default rulesfordeployment.qnx:target.path=/tmp/$${TARGET}/binelse:unix:!android:target.path=/opt/$${TARGET}/bin!isEmpty(target.path):INSTALLS+=target

现在我们对项目进行改造:

  • 1,在项目的根目录下,新建一个interface文件夹,把UI相关的文件移到文件夹内;

创建前:

创建后:

  • 2,在interface文件夹中,创建Interface.pri文件;

  • 3,在pro文件中,添加如下内容;

# 引入UI配置模块include(./Interface/interface.pri)

把包含的文件代码修改为:

SOURCES+=\ main.cpp # \#mainwindow.cpp#HEADERS+=\#mainwindow.h#FORMS+=\#mainwindow.ui

删除如下内容:

#QT+=gui#greaterThan(QT_MAJOR_VERSION,4):QT+=widgets

修改完成后的pro为:

QT+=core CONFIG+=c++17#You can make your code fail to compileifit uses deprecated APIs.#In order todoso,uncomment the following line.#DEFINES+=QT_DISABLE_DEPRECATED_BEFORE=0x060000# disables all the APIs deprecated before Qt6.0.0SOURCES+=\ main.cpp#Default rulesfordeployment.qnx:target.path=/tmp/$${TARGET}/binelse:unix:!android:target.path=/opt/$${TARGET}/bin!isEmpty(target.path):INSTALLS+=targetinclude(./Interface/interface.pri)

然后重写构建一下项目,将会变成如下的项目结构;

  • 4,在Interface.pri中编写如下内容;
# 指定头文件路径 INCLUDEPATH+=$$PWD/include # 指定依赖的 Qt 模块 QT+=guigreaterThan(QT_MAJOR_VERSION,4):QT+=widgets # 添加源文件、头文件、UI文件 SOURCES+=$$PWD/mainwindow.cpp HEADERS+=$$PWD/mainwindow.h FORMS+=$$PWD/mainwindow.ui

重写构建项目,项目结构将会变成:

这就相当于把UI模块剥离出来了。

  • 5,现在需要在main函数中,使用UI模块中的代码;
#include"interface/mainwindow.h"#include<QApplication>intmain(intargc,char*argv[]){QApplicationa(argc,argv);MainWindow w;w.show();returna.exec();}

如果包含头文件时,不想要interface的前缀,可以在pro文件中添加如下内容:

INCLUDEPATH+=$$PWD/interface

然后main函数的代码,就可以写成如下内容:

#include"mainwindow.h"#include<QApplication>intmain(intargc,char*argv[]){QApplicationa(argc,argv);MainWindow w;w.show();returna.exec();}

至此带有pri分模块的项目,就构建完成了。

附录

完整的项目代码见此

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/8 23:05:32

装机不再迷茫:AI硬件助手——您身边的专业硬件决策伙伴

在信息爆炸的时代&#xff0c;组装一台电脑看似选择更多&#xff0c;却也让无数新手和老手陷入了“选择困难”的漩涡。面对琳琅满目的CPU型号、纷繁复杂的显卡参数、日新月异的硬件迭代&#xff0c;我们常常感到无从下手。有没有一个工具&#xff0c;能像一个懂行的朋友&#x…

作者头像 李华
网站建设 2026/4/14 12:12:01

探索你的“饮食碳足迹”:一款直观的可持续饮食计算工具

随着环保意识的提升&#xff0c;越来越多人开始关注日常生活中的碳排放。你是否想过&#xff0c;一顿普通的饭菜也会对环境产生影响&#xff1f;今天&#xff0c;我们介绍一款简洁直观的在线工具——“计算你的饮食碳足迹”&#xff08;Calculate Your Meals Footprint&#xf…

作者头像 李华
网站建设 2026/4/14 0:43:23

超越简单收益:用“年化ROI计算器”看清投资的真实表现

投资不仅仅是数字的游戏&#xff0c;更是时间的朋友。如何判断一项投资是否真正“划算”&#xff1f;除了看总收益&#xff0c;更要看时间价值。今天&#xff0c;我们为大家介绍一款清晰、互动的ROI&#xff08;投资回报率&#xff09;计算工具&#xff0c;帮助你深入理解资金的…

作者头像 李华
网站建设 2026/4/14 21:49:01

25、打造个性化的Linux游戏与多媒体Live CD

打造个性化的Linux游戏与多媒体Live CD 1. 游戏Live CD的商业游戏许可 在制作Linux游戏Live CD时,许可问题是需要重点考虑的。如果基于Knoppix以及Debian/Knoppix软件仓库中的软件包来构建Live CD,能避开一些复杂的许可问题。若想确保所构建的Live CD可自由分发,选择经过严…

作者头像 李华
网站建设 2026/3/28 7:34:58

29、定制集群实时 Linux CD 及 DVD 上的实时 Linux 系统使用指南

定制集群实时 Linux CD 及 DVD 上的实时 Linux 系统使用指南 定制集群实时 Linux CD 在集群环境中,定制实时 Linux CD 可以让我们更灵活地满足特定的计算需求。下面将详细介绍如何定制集群实时 Linux CD 以及相关操作步骤。 运行 XPVM 首先,在主节点上打开控制台并运行 …

作者头像 李华
网站建设 2026/3/30 10:44:49

31、《Linux 系统中 ISO 镜像测试与刻录指南》

《Linux 系统中 ISO 镜像测试与刻录指南》 在 Linux 系统的使用过程中,测试和刻录 ISO 镜像文件是常见的操作。本文将详细介绍使用 VMware Player 测试 ISO 镜像,以及使用 cdrecord 和 K3b 工具刻录 ISO 镜像到 CD 或 DVD 的方法。 1. 使用 VMware Player 测试 ISO 镜像 V…

作者头像 李华