IAsyncReader::RequestAllocator 方法 (strmif.h)

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

方法 RequestAllocator 在引脚连接期间请求分配器。

语法

HRESULT RequestAllocator(
  [in]  IMemAllocator        *pPreferred,
  [in]  ALLOCATOR_PROPERTIES *pProps,
  [out] IMemAllocator        **ppActual
);

参数

[in] pPreferred

指向输入引脚的首选分配 器上的 IMemAllocator 接口的指针,或 NULL

[in] pProps

指定 ALLOCATOR_PROPERTIES结构的地址 ,由调用方分配。 调用方应填写输入引脚所需的任何分配器属性,并将其余成员设置为零。

[out] ppActual

接收 IMemAllocator 接口指针的变量的地址。

返回值

返回 HRESULT 值。 可能的值包括以下值。

返回代码 说明
E_FAIL
无法初始化分配器。
VFW_E_BADALIGN
指定的对齐方式无效。
S_OK
分配器已返回。

注解

下游输入引脚应在连接过程中调用此方法。 如果引脚具有首选分配器,请在 pPreferred 参数中指定它。 在 pProps 参数中指定任何缓冲区要求,例如缓冲区大小或对齐方式。 输出引脚选择分配器,并在 ppActual 参数中返回指向该分配器的指针。

不需要输出引脚即可接受输入引脚的请求。 如果输入引脚有任何绝对要求,则应在返回的分配器上调用 IMemAllocator::GetProperties 方法。 如果分配器属性不适用,则连接可能会失败。 建立连接后,输入引脚必须使用输出引脚选择的分配器。

输入引脚负责提交和解除分配器。

要求

要求
最低受支持的客户端 Windows 2000 Professional [仅限桌面应用]
最低受支持的服务器 Windows 2000 Server [仅限桌面应用]
目标平台 Windows
标头 strmif.h (包括 Dshow.h)
Library Strmiids.lib

另请参阅

错误和成功代码

IAsyncReader 接口