天天看點

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 += 3rdparty/MyLibrary/include           

然後,就可以這樣使用:

#include <MyLibrary.h>           

而不是:

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

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

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

表達式的第一部分(

-L...

):使連結器知道應該在哪個目錄中查找庫檔案。雙引号隻在路徑包含空格時才需要,是以此處可以省略。

表達式的第二部分(

-l...

):告訴連結器連結哪些庫。對于 Windows 和 UNIX 平台,有兩個不同的庫檔案:MyLibrary.lib 和 libMyLibrary.so,沒有必要指定 .lib 擴充名,也不必指定 lib 字首(在 UNIX 平台上)。

DESTDIR = bin           
TARGET = MyQtApp

TEMPLATE = app

INCLUDEPATH += 3rdparty/MyLibrary/include

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

SOURCES += src/main.cpp