建置 DirectShow 篩選

[與此頁面相關的功能 DirectShow是舊版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayerIMFMediaEngine音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議使用舊版 API 的現有程式碼盡可能重寫為使用新的 API。

建議使用 DirectShow 基類來實作 DirectShow 篩選。 若要使用基類進行建置,除了 設定建置環境中所述的步驟之外,還執行下列步驟:

  • 建置基類程式庫,位於 SDK 根目錄下的 Samples\Multimedia\DirectShow\BaseClasses 目錄中。 程式庫有兩個版本: (Strmbase.lib) 的零售版本,以及 strmbasd.lib) 的偵錯 (版本。
  • 包含標頭檔 Streams.h。
  • 使用__stdcall呼叫慣例。
  • 視需要) 使用多執行緒 C 執行時間程式庫 (偵錯或零售。
  • 包含匯出 DLL 函式的定義 (.def) 檔案。 以下是定義檔的範例。 它假設輸出檔名為 MyFilter.dll。
LIBRARY MYFILTER.DLL
EXPORTS 
    DllMain             PRIVATE
    DllGetClassObject   PRIVATE
    DllCanUnloadNow     PRIVATE
    DllRegisterServer   PRIVATE
    DllUnregisterServer PRIVATE
  • 連結至下列 lib 檔案。
標籤
偵錯組建 Strmbasd.lib、Msvcrtd.lib、Winmm.lib
零售組建 Strmbase.lib、Msvcrt.lib、Winmm.lib
  • 在連結器設定中選擇 [忽略預設程式庫] 選項。
  • 宣告原始程式碼中的 DLL 進入點,如下所示:
extern "C" BOOL WINAPI DllEntryPoint(HINSTANCE, ULONG, LPVOID);
BOOL APIENTRY DllMain(HANDLE hModule, DWORD dwReason, LPVOID lpReserved)
{
    return DllEntryPoint((HINSTANCE)(hModule), dwReason, lpReserved);
}

舊版本

針對 DirectShow 9.0 之前的基類程式庫版本,您也必須執行下列動作:

  • 針對偵錯組建,請定義預處理器旗標 DEBUG。

DirectShow 9.0 和更新版本中提供的基類程式庫版本不需要此步驟。

DirectShow 基類

撰寫 DirectShow 篩選