CBaseAllocator.SetProperties 方法
[與此頁面相關的功能 DirectShow是舊版功能。 它已被 MediaPlayer、 IMFMediaEngine和 Media Foundation 中的音訊/視訊擷取取代。 這些功能已針對Windows 10和Windows 11進行優化。 Microsoft 強烈建議新程式碼盡可能使用 MediaPlayer、 IMFMediaEngine 和 音訊/視訊擷取 ,而不是 DirectShow。 Microsoft 建議使用舊版 API 的現有程式碼盡可能重寫為使用新的 API。
方法 SetProperties
會指定要配置的緩衝區數目,以及每個緩衝區的大小。 這個方法會實作 IMemAllocator::SetProperties 方法。
語法
HRESULT SetProperties(
ALLOCATOR_PROPERTIES *pRequest,
ALLOCATOR_PROPERTIES *pActual
);
參數
-
pRequest
-
包含緩衝區需求的 ALLOCATOR_PROPERTIES 結構的指標。
-
pActual
-
接收實際緩衝區屬性 之ALLOCATOR_PROPERTIES 結構的指標。
傳回值
傳回下列其中一個 HRESULT 值。
傳回碼 | 描述 |
---|---|
|
成功。 |
|
Null 指標引數。 |
|
當篩選作用中時,無法變更配置的記憶體。 |
|
指定了不正確對齊方式。 |
|
一或多個緩衝區仍在使用中。 |
備註
這個方法會指定緩衝區需求,但不會配置任何緩衝區。 呼叫 CBaseAllocator::Commit 方法來配置緩衝區。
呼叫端會配置兩個ALLOCATOR_PROPERTIES結構。 pRequest參數包含呼叫端的緩衝區需求,包括緩衝區數目和每個緩衝區的大小。 當方法傳回時, pActual 參數會包含實際的緩衝區屬性,如配置器所設定。 在基類中,假設方法成功,實際屬性一律符合要求的屬性。 衍生類別可能會覆寫此行為。
配置器不得認可,而且不能有未處理的緩衝區。 在基類中,對齊方式必須等於 1。 CMemAllocator類別會覆寫此需求。
規格需求
需求 | 值 |
---|---|
標頭 |
|
程式庫 |
|