CBaseAllocator.SetProperties 方法

[与此页面关联的功能 DirectShow 是一项旧功能。 它已被 MediaPlayerIMFMediaEngine媒体基金会中的音频/视频捕获取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能使用 MediaPlayerIMFMediaEngineMedia Foundation 中的音频/视频捕获 ,而不是 DirectShow。 如果可能,Microsoft 建议重写使用旧 API 的现有代码以使用新 API。]

方法 SetProperties 指定要分配的缓冲区数和每个缓冲区的大小。 此方法实现 IMemAllocator::SetProperties 方法。

语法

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

参数

pRequest

指向包含缓冲区要求的 ALLOCATOR_PROPERTIES 结构的指针。

p 实际

指向接收实际缓冲区属性 的 ALLOCATOR_PROPERTIES 结构的指针。

返回值

返回以下 HRESULT 值之一。

返回代码 说明
S_OK
成功。
E_POINTER
NULL 指针参数。
VFW_E_ALREADY_COMMITTED
筛选器处于活动状态时,无法更改分配的内存。
VFW_E_BADALIGN
指定的对齐方式无效。
VFW_E_BUFFERS_OUTSTANDING
一个或多个缓冲区仍处于活动状态。

备注

此方法指定缓冲区要求,但不分配任何缓冲区。 调用 CBaseAllocator::Commit 方法以分配缓冲区。

调用方分配两个ALLOCATOR_PROPERTIES结构。 pRequest 参数包含调用方缓冲区要求,包括缓冲区数和每个缓冲区的大小。 当方法返回时, pActual 参数包含分配器设置的实际缓冲区属性。 在基类中,假定方法成功,实际属性始终与请求的属性匹配。 派生类可能会重写此行为。

分配器不得提交,并且不得具有未完成的缓冲区。 在基类中,对齐方式必须等于 1。 CMemAllocator 类替代此要求。

要求

要求
标头
Amfilter.h (包括 Streams.h)

Strmbase.lib (零售版本) ;
Strmbasd.lib (调试生成)

另请参阅

CBaseAllocator 类