IMemAllocator::SetProperties 方法 (strmif.h)

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

方法 SetProperties 會指定要配置的緩衝區數目,以及每個緩衝區的大小。

語法

HRESULT SetProperties(
  ALLOCATOR_PROPERTIES *pRequest,
  ALLOCATOR_PROPERTIES *pActual
);

參數

pRequest

包含緩衝區需求的 ALLOCATOR_PROPERTIES 結構的指標。

pActual

接收實際緩衝區屬性 之ALLOCATOR_PROPERTIES 結構的指標。

傳回值

傳回 HRESULT 值。 可能的值包括下表所示的值。

傳回碼 描述
S_OK
成功。
E_POINTER
Null 指標引數。
VFW_E_ALREADY_COMMITTED
當篩選作用中時,無法變更配置的記憶體。
VFW_E_BADALIGN
指定了不正確對齊方式。
VFW_E_BUFFERS_OUTSTANDING
一或多個緩衝區仍在使用中。

備註

這個方法會指定緩衝區需求,但不會配置任何緩衝區。 呼叫 IMemAllocator::Commit 方法來配置緩衝區。

呼叫端會配置兩個ALLOCATOR_PROPERTIES結構。 pRequest參數包含呼叫端的緩衝區需求,包括緩衝區數目和每個緩衝區的大小。 當方法傳回時, pActual 參數會包含實際的緩衝區屬性,如配置器所設定。

呼叫這個方法時,配置器不得認可或具有未處理的緩衝區。

規格需求

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

另請參閱

錯誤和成功碼

IMemAllocator 介面