- 深入理解Qt的pro文件
- 模板變量
- 生成目錄
- 生成的應用程序名
- 編譯選項
- 目標文件目錄
- 包含頭文件
- 包含源文件
- 包含資源文件
- 附加頭文件包含
- 鏈接庫
- 預編譯宏
- 平臺相關性處理
- 指定來自ui文件位置
- 指定界面翻譯文本列表
- 指定圖標
深入理解Qt的.pro文件
一般Qt項目我們是使用Qt Creator自動生成的,如果是沒有.pro的項目,可以使用qmake project來生成。
在一般的.pro里已經包含了幾個基本的選項,如TEMPLATE,TARGET,INCLUDEPATH,HEADS,SOURCES等選項,下面我們細講。
模板變量
TEMPLATE = app
- app 表示該工程建立一個應用程序的makefile。這是默認值,所以如果模板沒有被指定,這個將被使用
- lib 表示該工程建立一個庫的makefile
生成目錄
指定生成的可執行程序的目錄,可以絕對路徑和相對路徑。
DESTDIR += ../bin
生成的應用程序名
程序名即軟件名稱
TARGET = 3DAOI
編譯選項
增添后者移除某個模塊。
例如增添c++11和console模塊的支持,Qt的各模塊也在這里添加
CONFIG += console c++11 network
CONFIG -= qt
可以用空格分隔或者“\”來隔行。
如果是一些比較特殊的Qt模塊需要使用用以下方式加載:
QT += qml quick
QT += quick quickcontrols2
目標文件目錄
obj文件存放的目錄,也就是.o文件的生成路徑,可以絕對路徑或者相對路徑。
OBJECTS_DIR += ../tmp
補充:
- MOC_DIR 指定moc文件生成路徑
- UI_DIR 指定ui文件生成路徑
包含頭文件
表示本項目中頭文件。
HEADERS += \
libcurl/curl/curl.h\
libcurl/curl/curlbuild.h
只要Qt Creator目錄樹中add進去了就會自動追加到.pro文件中。
包含源文件
表示本項目中的源文件
SOURCES += main.cpp\
json.cpp
只要Qt Creator目錄樹里add進去了就會自動追加到.pro文件中。
包含資源文件
表示本項目包含的資源文件。
RESOURCES += qrc/painter.qrc
qrc文件格式類似如下:
<RCC><qresource prefix="/"><file>Chapter1/0_hello.qml</file><file>Chapter1/1_object_expression.qml</file></qresource>
</RCC>
只要Qt Creator目錄樹里add進去了就會自定追加,更改.pro文件會同步更新Qt Creator里的目錄樹,但不會影響硬盤上的自愿文件。
附加頭文件包含
一般要編譯鏈接第三方庫時配置include目錄。
例如:
INCLUDEPATH += ./boost/include\
src/thirdpart/includeINCLUDEPATH += D:/boost/include\
E:/cocos2dx/include
注意:
- 可以用絕對路徑或相對路徑
- 相對路徑中./可以省略
- 路徑中不允許出現空格
鏈接庫
對于靜態庫(.a)以及動態庫(.so)。
LIBS += -LD:/codetest/libcurlcpp/libcurl/lib/-llibcurl\
-LD:/codetest/libcurlcpp/libcurl/lib/-lws2_32\
-LD:/codetest/libcurlcpp/libcurl/lib/-lwldap32\
-LD:/codetest/libcurlcpp/libcurl/lib/-lopencv.so\
-LD:/codetest/libcurlcpp/libcurl/lib/-llibzmq.a
或者:
LIBS += D:/codetest/libcurlcpp/libcurl/lib/libcurl.lib\
D:/codetest/libcurlcpp/libcurl/lib/ws2_32.lib\
D:/codetest/libcurlcpp/libcurl/lib/wldap32.lib
D:/codetest/libcurlcpp/libcurl/lib/opencv.so\
D:/codetest/libcurlcpp/libcurl/lib/opencv.a
再或者:
LIBS += $$PWD/libcurl/lib/libcurl.lib\
$$PWD/libcurl/lib/ws2_32.lib\
$$PWD/libcurl/lib/wldap32.lib
- 可以用-L指定目錄,-l指定庫的名稱(無需后綴,.lib, .a,.so都適用),注意-l后面沒有空格
- 可以直接通過絕對路徑和相對路徑指定庫的完成path(需后綴, .lib, .a, .so都試用), 相對路徑用$$PWD前綴,路徑不允許有空格。
- LIBS += somepath這個可以寫多行,也可以使用”\”隔行
注意:
對于動態庫dll文件,必須拷貝到exe執行目錄或者在環境變量里配置路徑才可以。
預編譯宏
DEFINES += USE_OPENSSL\
CURL_STATICLIB
類似于vs里面在工程里設置預編譯選項 ,這個使用時自行google。
平臺相關性處理
根據qmake所運行的平臺來使用相應的作用域來進行處理。
win32
{
SOURCES += 1.cpp
}else{
SOURCES += 2.cpp
}
根據平臺進行條件編譯。
指定來自ui文件位置
這個我們不需要。
unix:UI_DIR = ../project/ui
win32:UI_DIR = D:/project/ui
指定界面翻譯文本列表
翻譯用戶界面時需要用到。
TRANSLATIONS += Resource/myapp_zh.ts \Resource/myapp_en.ts
指定圖標
如果RC_FILE 和RES_FILE變量都沒有設置這才可利用
RC_ICONS = logo.ico