文章目录
1 Qt开发之路—模块化设计.pri文件
1.1 pri文件简介
i是包含(include)的首字母。类似于C、C++中的头文件,我们可以把*.pro文件内的一部分内容单独放到一个*.pri文件内,然后包含进来。
例如,我们将源文件的设置独立出来,放到test.pri文件内:
SOURCES += main.cpp/
widget.cpp
HEADERS += widget.h
FORMS += widget.h
这时,我们的test.pro文件就可以简化为:
TEMPLATE = app
CONFIG += QT
QT += core gui
TARGET = test
include(test.pri)
如果一个大点的项目,含有多个*.pro文件,这些pro需要有些共同的设置或需要的文件,这时就很有必要了。
1.2 通过*.pri模块化设计
对于QT项目,默认情况下所有的文件都是在同一个文件夹下进行开发的,当做一个项目规模相对较大的时候,文件很多导致维护及其困难,所以pri对文件模块化开发至关重要,pri进行模块化无非就是将相同业务逻辑的代码放到同一文件夹下进行管理。
当工程文件变多时,工程逻辑结构变得相对复杂,这时点开你的工程节点,会发现节点下都是这样长长的一串,什么模块的文件都挤在一个节点下,很臃肿。如下图,模块化前后对比:
第一步:到项目根目录下新建你自己的业务逻辑的文件夹,Dialog、Widget文件夹如下图所示:
第二步:将相同的功能文件移动到对应的文件夹中。
第三步:在新建的文件夹下新建“.pri”文件,新建.pri文件名称规则(文件夹名称+.pri),新建.pri文件后,手动添加内容,或者根据第五步添加。
第四步:在根据根目录的.pro文件中添加如下内容。
INCLUDEPATH
include
QT += core gui
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
TARGET = TestQt
TEMPLATE = app
SOURCES += main.cpp\
mainwindow.cpp
HEADERS += mainwindow.h
FORMS += mainwindow.ui
RESOURCES += \
image.qrc
DISTFILES +=
INCLUDEPATH += $$PWD/Dialog # 工程编译时,会去INCLUDEPATH列表下的目录搜索文件
include ($$PWD/Dialog/Dialog.pri) # include()包含的文件会显示在工程结构图中
INCLUDEPATH += $$PWD/Widget # 工程编译时,会去INCLUDEPATH列表下的目录搜索文件
include ($$PWD/Widget/Widget.pri) # include()包含的文件会显示在工程结构图中
第五步:qmake后,分别右键Dialog、Widget添加对应文件夹下的文件。.pri文件内容如下:
Dialog.pri文件:
FORMS += \
$$PWD/dialogone.ui \
$$PWD/dialogtwo.ui
HEADERS += \
$$PWD/dialogone.h \
$$PWD/dialogtwo.h
SOURCES += \
$$PWD/dialogone.cpp \
$$PWD/dialogtwo.cpp
Widget.pri文件:
FROMS += \
$$PWD/widgetone.ui \
$$PWD/widgettwo.ui
HEADERS += \
$$PWD/widgetone.h \
$$PWD/widgettwo.h
SOURCES += \
$$PWD/widgetone.cpp \
$$PWD/widgettwo.cpp
第六步:效果图
2 Qt开发大型项目时,通过.pri文件将众多文件按功能模块分类显示
后期维护代码时,要找某个功能的代码,就可以先找到对应功能模块的目录,然后在该目录下找到对应的类文件即可。
3 Qt中多pro与多pri合作编程
pri文件跟pro文件没有本质区别,都是起到包含路径等作用,区别在于pro文件是主要文件,pri是附属文件。
要是项目相对来说比较复杂,比如多平台开发时,需要用到多pri与pro共同合作,当然也可以编辑成静态库或者动态库的形式。
一个pro可以包含多个pri,例如:
include(win32.pri)
include(macx.pri)
include(ios.pri)
include(android.pri)
实例1:(按照功能来设计架构)
实例2:(按照平台和主要功能进行架构)
4 Qt项目文件Pri详解
在Qt项目中,pri文件(.pri)是一种类似于makefile的文件,用于定义Qt项目中的编译规则。通常可以用pri文件来配置Qt库、头文件、源文件、链接库等信息,这样就可以把这些信息定义在一个文件中,避免在每个工程中都进行重复配置,提高了代码的可重用性。
对于Qt项目来说,pri文件是非常重要的,因为它可以方便地进行模块管理,让工程结构更加清晰。如果你需要在Qt项目中添加新的模块或者新的第三方库,可以在pri文件中添加相关的信息。同时,pri文件还可以使代码编译更加高效,这是因为它会更具不同平台自动选择最优化的编译器和编译选项。
在使用pri文件中,应该学会如何编写和使用自己的pri文件,以便能够根据自己的需要进行自定义配置。同时,可以将写好的pri文件分享给其他人使用,以提高整个团队的开发效率。
在Qt Creator编译器中,可以通过右键单击项目文件夹,选择“Add New…”菜单,选择"Add Existing Files or Director …",然后选择对应的pri文件添加到项目中。
需要注意的是,pri文件虽然非常强大,但同时也需要谨慎使用。如果错误的配置pri文件,会导致代码无法正常编译运行,因此在修改文件时一定要慎重。
4.1 Pri文件简介
在Qt中,Pri文件是一种项目文件,用于将C++文件、JavaScript文件、资源文件等链接在一起,并生成可执行文件。Pri文件中可以定义编译规则、链接规则、生成规则、部署规则等等,通过使用不同的变量和函数,来实现各种复杂的构建例程和部署流程。
Pri文件是基于Makefile语法的,因此需要使用一定的Makefile知识。同时,Qt Creator集成开发环境及其命令行工具Qt Build System(qbs)
可以方便地生成Pri文件并进行构建,使得在不需要编写完整的Makefile的情况下进行快速开发和构建称为可能。
4.2 Pri文件编写基础
Pri文件的编写离不开变量、函数和条件判断等基础语法。
4.2.1 变量的定义
Pri文件中的变量可以是预定义的系统变量,如$$PWD表示Pri文件所在的目录;也可以是用户自定义的变量,如SRC_DIR
表示源文件目录。变量定义的语法是:
VARIABLE_NAME = variable_value
其中,VARIABLE_NAME为变量名,variable_value为变量的值。在变量的值中,可以嵌入其他变量,例如:
SRC_DIR = $$PWD/src
OBJ_DIR = $$PWD/obj
OBJECTS_DIR = $$OBJ_DIR/$$TARGET
其中,$$TARGET表示生成文件的目标类型,可以使exe、dll、plugin等。
4.2.2 函数的使用
Pri文件中的函数可以大大简化复杂的构建流程,例如文件搜索、文件生成、文件拷贝、库链接等等。
函数的语法是:
FUNCTION_NAME(arg1,arg2,...)
其中,FUNCTION_NAME为函数名,arg1、arg2等为函数的参数。常用的函数包括:
files:用于搜索指定目录下的所有文件
subdirs:指定当前目录下的子目录
target.sources:为目标文件指定源文件
target.depends:指定目标文件所依赖的文件
target.commands:为目标文件指定编译命令、链接命令等
target.path:指定目标文件生成的路径
target.link:为目标文件指定需要链接的库文件及链接命令等
例如:
LIBS += -lfoo
target_link(&&TARGET,$$LIBS)
其中,target_link是一个自定义的函数,用于将
LIBS中指定的库链接到TARGET中。
4.2.3 条件判断
在Pri文件中,可以根据具体情况对不同的操作进行条件判断,例如:
win32:LIBS += -lwsock32
else:LIBS += -lsocket -lnsl
其中,win32表示在Windows平台下进行操作,else表示在其他平台下进行操作。
4.3 Pri文件高级应用
在掌握了基础的Pri文件语法之后,Pri文件可以进行更多更复杂的编译任务。
4.3.1 如何指定编译器
在Pri文件中,可以通过设置QMAKE_CXX
和QMAKE_CC
变量来指定编译器:
QMAKE_CXX = g++
QMAKE_CC = gcc
4.3.2 如何生成动态库和静态库
在Pri文件中,可以通过target.commands指定动态库和静态库的生成规则:
lib.path = /usr/lib
lib.name = foo
lib.files = source1.cpp source2.cpp
lib.commands = $$QMAKE_CXX -shared -o $$lib.target $$OBJECTS
其中,lib.path指定库文件生成的路径,lib.name指定库文件的名称,lib.files指定库文件的源文件,lib.commands指定库文件的生成命令。
4.3.3 如何生成可执行文件和文件拷贝
可执行文件和文件拷贝的生成规则如下:
executable.output = foo
executable.files = source1.cpp source2.cpp
executable.commands = $$QMAKE_CXX -o $$executable.target $$OBJECTS
INSTALLS += exe
exe.target = /usr/bin
exe.files = $$executable.target
exe.commands = $$QMAKE_COPY $$executable.target $$exe.target
其中,executable.output指定可执行文件的名称,executable.files指定可执行文件的源文件,executable.commands指定可执行文件的生成命令。
INSTALLS指定生成文件的部署规则,exe.target指定部署目标目录,exe.files指定需要部署的文件,exe.commands指定文件拷贝的命令。
4.4 Pri文件使用案例
以下是一个简单的Pri文件的示例:
SRC_DIR = $$PWD/src
OBJ_DIR = $$PWD/obj
TARGET_DIR = $$PWD/bin
INCLUDEPATH += $$PWD/include
LIBS += -ldl
target.path = $$TARGET_DIR
target.name = myapp
message(Building ... $$TARGET)
message(Source files: $$SOURCES)
contains(CONFIG,debug){
message(Building in debug mode ...)
TARGET = myappd
COMMON_FLAGS = -g -O0
}
contains(CONFIG,release){
message(Building in release mode ...)
TARGET = myapp
COMMON_FLAGS = -O2
}
sources = $$files($$SRC_DIR/*.cpp)
target.sources = $$sources
OBJECTS_DIR = $$OBJ_DIR/$$TARGET
mocable_headers = $$_PRO_FILE_PWD_/input.h
mocables = $$mocable_headers
mocables.headers = $$mocable_headers
mocables.commands = $$QTDIR/bin/moc $$mocables.headers -o $$mocables.target
QMAKE_EXTRA_TARGETS += mocables
unix{
target.commands = $$QMAKE_CXX -o $$TARGET $$OBJECTS $$LIBS
mocables.target = $${OBJECTS_DIR}/input.moc
mkdir($${OBJECTS_DIR})
}else{
target.commands = link -out:$$TARGET.exe $$OBJECTS $$LIBS
mocables.target = $${OBJECTS_DIR}/input.moc.obj
mkdir($$system_path($${OBJECTS_DIR}))
}
target.dependency_type = TYPE_C
target.CONFIG += dll
target.LIBS += lfoo
DISTFILES += $$PWD/post_install_script
mocables.CONFIG += no_link_target
INSTALLS += target mocables
target.files = $$TARGET
mocables.files = $${mocable_headers}
其中,该Pri文件实现了基本的编译和部署任务,具体实现方式如下:
- 定义了SRC_DIR、OBJ_DIR、TARGET_DIR三个变量,用于指定源文件目录、目标文件目录和可执行文件目录。
- 指定了头文件搜索路径和库文件搜索路径。
- 定义了BUILD_MODE变量,用于指定构建模式,debug或release。
- 根据BUILD_MODE的设置,确定了可执行文件的名称,以及编译选项。
- 依据源文件目录下的所有.cpp文件,为目标文件指定源文件。
- 指定了需要运行moc预编译器的头文件,用于生成mocable文件。
- 指定了可执行文件的链接库、库文件等。
- 配置了可执行文件的部署规则。