qmake常用操作

在Qt中,有一個工具qmake可以生成一個Makefile文件,它是由.pro文件生成而來的,qmake不光可以在Qt中使用,也可以用來
.pro文件的寫法如下:

註釋

從“#”開始,到這一行結束。

指定生成目標可執行文件

TARGET = run_app_name

模板變量

告訴qmake爲這個應用程序生成哪種Makefile。下面是可供使用的選擇:
TEMPLATE = app

  • A: app -建立一個應用程序的makefile。這是默認值,所以如果模板沒有被指定,這個將被使用。
  • B: lib - 建立一個庫的makefile。
  • C: vcapp - 建立一個應用程序的VisualStudio項目文件。
  • D: vclib - 建立一個庫的VisualStudio項目文件。
  • E: subdirs -這是一個特殊的模板,它可以創建一個能夠進入特定目錄並且爲一個項目文件生成makefile並且爲它調用make的makefile。

指定生成文件的放置目錄

  • OBJECTS_DIR = ../obj #生成的各個文件的.o文件,如filename.o
  • DESTDIR += ../bin #生成的目標可執行文件
  • UI_DIR += ../forms #指定uic命令將.ui文件轉化成ui_*.h文件的存放的目錄,如ui_filename.h
  • RCC_DIR += ../rcc #指定rcc命令將.qrc文件轉換成qrc_*.h文件的存放目錄
  • MOC_DIR += ../moc #指定moc命令將含Q_OBJECT的頭文件轉換成標準.h文件的存放目錄,生成如moc_filename.cpp文件

配置信息

CONFIG用來告訴qmake關於應用程序的配置信息。

CONFIG += qt warn_on release

在這裏使用“+=”,是因爲我們添加我們的配置選項到任何一個已經存在中。這樣做比使用“=”那樣替換已經指定的所有選項是更安全的。
A> qt部分告訴qmake這個應用程序是使用Qt來連編的。這也就是說qmake在連接和爲編譯添加所需的包含路徑的時候會考慮到Qt庫的。
B> warn_on部分告訴qmake要把編譯器設置爲輸出警告信息的。
C> release部分告訴qmake應用程序必須被連編爲一個發佈的應用程序。在開發過程中,程序員也可以使用debug來替換release

程序編譯時依賴的相關路徑

DEPENDPATH += . forms include qrc sources

工程中源文件指定

  • HEADERS += sources/file.h #工程中包含的頭文件
  • FORMS += sources/file.ui #工程中包含的.ui設計文件
  • SOURCES += sources/main.cpp sources/file.cpp #工程中包含的源文件
  • RESOURCES += qrc/file.qrc #工程中包含的資源文件
  • LIBS += -L folderPath -lssl #引入的lib文件的路徑 -L:引入路徑,-l:庫名稱libssl.so,如果庫在環境變量中的話不需要-L指定目錄
  • DEFINES += XX_XX_XXX #定義編譯選項,在.h文件中就可以使用 :#ifdefine xx_xx_xxx
  • RC_FILE = xxx.icns
  • OTHER_FILES += filename #其他文件
  • TRANSLATIONS += Translate/file_en.ts #生成翻譯的ts文件

發佈編譯和調試編譯

CONFIG(debug, debug|release): { #debug

} else: { #release

}
debug {
CONFIG += console
}

平臺相關

不同平臺的寫法如下,不同平臺的配置寫在不同平臺的下面
unix {
linux* {
} else:macx {
} else {
}
}
win32 {
}

運行qmake

當你已經創建好你的項目文件,生成Makefile就很容易了,你所要做的就是先到你所生成的項目文件那裏然後輸入:

Makefile可以像這樣由“.pro”文件生成:

qmake -o Makefile hello.pro

對於VisualStudio的用戶,qmake也可以生成“.dsp”文件,例如:

qmake -tvcapp -o hello.dsp hello.pro
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章