Qt 使用第三方庫

簡述

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

第三方庫

假設你需要依賴一個跨平臺的庫 - 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 目錄路徑:

INCLUDEPATH += $$PWD/3rdparty/MyLibrary/include
  • 1

然後,就可以這樣使用:

#include <MyLibrary.h>
  • 1

而不是:

#include <3rdparty/MyLibrary/include/MyLibrary.h>
  • 1

庫文件

要讓 qmake 知道在哪裏可以找到 MyLibrary 庫文件,使用 LIBS 變量:

LIBS += -L$$PWD/"3rdparty/MyLibrary/lib" -lMyLibrary
  • 1

表達式的第一部分(-L...):使鏈接器知道應該在哪個目錄中查找庫文件。雙引號只在路徑包含空格時才需要,因此此處可以省略。

表達式的第二部分(-l...):告訴鏈接器鏈接哪些庫。對於 Windows 和 UNIX 平臺,有兩個不同的庫文件:MyLibrary.lib 和 libMyLibrary.so,沒有必要指定 .lib 擴展名,也不必指定 lib 前綴(在 UNIX 平臺上)。

目標目錄

默認情況下,qmake 在與 .pro 文件相同的目錄中創建可執行文件,可以使用 DESTDIR 變量來選擇自己的目錄:

DESTDIR = bin
  • 1

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

TARGET = MyQtApp

TEMPLATE = app

INCLUDEPATH += $$PWD/3rdparty/MyLibrary/include

LIBS += -L$$PWD/"3rdparty/MyLibrary/lib" -lMyLibrary

SOURCES += src/main.cpp
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

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


轉載自:一去丶二三裏 博客地址:http://blog.csdn.net/liang19890820

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