IMemAllocator::SetProperties 方法 (strmif.h)

[与此页面关联的功能 DirectShow 是旧版功能。 它已被 MediaPlayerIMFMediaEngineMedia Foundation 中的音频/视频捕获所取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能在 Media Foundation 中使用 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 Professional [仅限桌面应用]
最低受支持的服务器 Windows 2000 Server [仅限桌面应用]
目标平台 Windows
标头 strmif.h (包括 Dshow.h)
Library Strmiids.lib

另请参阅

错误和成功代码

IMemAllocator 接口