共用方式為


IVMRWindowlessControl::GetCurrentImage 方法 (strmif.h)

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

方法 GetCurrentImage 會擷取 VMR 所顯示目前影像的複本。

語法

HRESULT GetCurrentImage(
  [out] BYTE **lpDib
);

參數

[out] lpDib

BYTE 陣列指標的位址。

傳回值

如果方法成功,它會傳回 S_OK。 如果方法失敗,則會傳回錯誤碼。

傳回碼 Description
VFW_E_WRONG_STATE
VMR 不在無視窗模式中。

備註

這個方法會傳回正在顯示的目前影像。 映射會以封裝的 Windows DIB 形式傳回。 影像以 BITMAPINFOHEADER 結構開頭,可能包含調色盤專案和/或色彩遮罩,後面接著影像數據。

VMR 會配置映像的記憶體,並在 lpDib 變數中傳回其指標。 呼叫端必須呼叫 CoTaskMemFree 來釋放記憶體。

不論篩選條件處於何種狀態,不論篩選條件處於何種狀態,不論執行中、已停止或暫停,都可以隨時呼叫這個方法。 不過,經常呼叫這個方法會降低視訊播放效能。

範例

C++
BYTE *lpDib = NULL;
hr = pWindowlessControl->GetCurrentImage(&lpDib);
if (SUCCEEDED(hr))
{
    BITMAPINFOHEADER *pBMIH = (BITMAPINFOHEADER*)lpDib;
    /* .... */
    CoTaskMemFree(lpDib);
}

規格需求

需求
最低支援的用戶端 Windows XP with SP1 [僅限傳統型應用程式]
最低支援的伺服器 Windows Server 2003 [僅限桌面應用程式]
目標平台 Windows
標頭 strmif.h (包含 Dshow.h)
程式庫 Strmiids.lib

另請參閱

錯誤和成功碼

IVMRWindowlessControl 介面

使用視訊混合轉譯器