Share via


IAMBufferNegotiation::SuggestAllocatorProperties 方法 (strmif.h)

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

方法 SuggestAllocatorProperties 會通知應用程式的慣用配置器屬性釘選。 在針腳連接之前呼叫這個方法。

語法

HRESULT SuggestAllocatorProperties(
  [in] const ALLOCATOR_PROPERTIES *pprop
);

參數

[in] pprop

包含所要求屬性 之ALLOCATOR_PROPERTIES 結構的指標。 任何成員的負值表示針腳應該針對該屬性使用其預設設定。

傳回值

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

傳回碼 描述
S_OK
成功。
E_FAIL
失敗。
E_POINTER
NULL 指標自變數。
VFW_E_ALREADY_CONNECTED
Pin 已連線。

備註

如果連線中的兩個針腳都公開 IAMBufferNegotiation 介面,請在每個針腳上呼叫這個方法,以確保一個針腳不會覆寫另一個針腳。

若要要求特定數目的緩衝區,請設定 ALLOCATOR_PROPERTIES 結構的 cBuffers 成員。 若要要求特定的緩衝區大小,請設定 cbBuffer 成員。 應用程式通常不應該指定對齊或前置詞。 如果每個緩衝區的緩衝區數目或大小太小,篩選圖表可能會卸除樣本。

範例

C++
ALLOCATOR_PROPERTIES AllocProp;
AllocProp.cbAlign = -1;  // -1 means no preference.
AllocProp.cbBuffer = dwBytesPerSec *  dwLatencyInMilliseconds / 1000;
AllocProp.cbPrefix = -1;
AllocProp.cBuffers = -1;
pIAMBufferNegotiation->SuggestAllocatorProperties(&AllocProp);

規格需求

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

另請參閱

錯誤和成功碼

IAMBufferNegotiation 介面