Share via


IAMStreamConfig::GetFormat 方法 (strmif.h)

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

方法 GetFormat 會擷取目前或慣用的輸出格式。

語法

HRESULT GetFormat(
  [out] AM_MEDIA_TYPE **ppmt
);

參數

[out] ppmt

AM_MEDIA_TYPE 結構的指標位址。

傳回值

傳回 HRESULT 值。 可能的值如下。

傳回碼 描述
S_OK
成功。
E_OUTOFMEMORY
記憶體不足。
E_POINTER
NULL 指標值。
VFW_E_NOT_CONNECTED
輸入針腳未連接。

備註

如果連接針腳,這個方法會傳回目前使用針腳的格式。 否則,方法會傳回下一個針腳連接的針腳慣用格式。 如果您已經呼叫 IAMStreamConfig::SetFormat 方法來設定格式, GetFormat 則會傳回相同的格式。 如果沒有,它會傳回針腳慣用格式清單中的第一種格式,由 IPin::EnumMediaTypes 方法決定。

方法會配置 AM_MEDIA_TYPE 結構的記憶體、填入 結構,並在 pmt 參數中傳回它。 呼叫端必須釋放記憶體,包括格式區塊。 您可以在基類連結庫中使用 DeleteMediaType 協助程式函式。

在某些壓縮篩選條件上,如果篩選條件的輸入針腳未連線,方法就會失敗。

範例

C++
IAMStreamConfig *pConfig = NULL;
// Query the output pin for IAMStreamConfig (not shown).
AM_MEDIA_TYPE *pmt = NULL;
hr = pConfig->GetFormat(&pmt);
if (SUCCEEDED(hr))
{
    /* Examine the media type for any information you need. */
    DeleteMediaType(pmt);
}
pConfig->Release();

規格需求

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

另請參閱

錯誤和成功碼

IAMStreamConfig 介面