天天看點

Qt使用第三方庫簡述第三方庫源代碼庫檔案目标目錄

在 qt 中經常會用到第三方庫,例如:ffmpeg、opencv 等。第三方庫的使用比較簡單,隻需要一些基本的配置就可以搞定,一起來看看吧!

<a href="#%e7%ae%80%e8%bf%b0">簡述</a>

<a href="#%e7%ac%ac%e4%b8%89%e6%96%b9%e5%ba%93">第三方庫</a>

<a href="#%e6%ba%90%e4%bb%a3%e7%a0%81">源代碼</a>

<a href="#%e5%ba%93%e6%96%87%e4%bb%b6">庫檔案</a>

<a href="#%e7%9b%ae%e6%a0%87%e7%9b%ae%e5%bd%95">目标目錄</a>

假設你需要依賴一個跨平台的庫 - mylibrary,并且有幾個檔案作為庫的一部分。我們的項目 myqtapp 将這些檔案存儲在名為 3rdparty 的檔案夾中:

myqtapp/

myqtapp.pro

src/

main.cpp

3rdparty/

mylibrary

include/

mylibrary.h

lib/

libmylibrary.so

mylibrary.lib

bin/

mylibrary.dll

要在 myqtapp 中使用 mylibrary 庫,qmake 需要 mylibrary 庫的位置和名稱。你也可以選擇:

提供 mylibrary 源代碼的位置,以便在将它們包含在自己的代碼中時,不必輸入每個檔案的完整路徑。

選擇 myqtapp 可執行檔案将被建立的目标目錄。

上面的資訊在 .pro 檔案中提供,以便 qmake 可以解析它并生成 makefiles。makefiles 包含編譯器和連結器生成輸出所需的所有資訊,無論它是可執行檔案,另一個庫檔案等。

使用 includepath 變量提供 mylibrary 的 include 目錄路徑:

然後,就可以這樣使用:

而不是:

要讓 qmake 知道在哪裡可以找到 mylibrary 庫檔案,使用 libs 變量:

表達式的第一部分(<code>-l...</code>):使連結器知道應該在哪個目錄中查找庫檔案。雙引号隻在路徑包含空格時才需要,是以此處可以省略。

表達式的第二部分(<code>-l...</code>):告訴連結器連結哪些庫。對于 windows 和 unix 平台,有兩個不同的庫檔案:mylibrary.lib 和 libmylibrary.so,沒有必要指定 .lib 擴充名,也不必指定 lib 字首(在 unix 平台上)。

預設情況下,qmake 在與 .pro 檔案相同的目錄中建立可執行檔案,可以使用 destdir 變量來選擇自己的目錄:

就這麼簡單,現在可以在項目中使用 mylibrary 庫了。最終的 .pro 檔案如下所示:

無論使用什麼庫,配置基本都大同小異,good luck!

繼續閱讀