CTransInPlaceInputPin.NotifyAllocator 方法

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

方法 NotifyAllocator 指定连接的分配器。 此方法实现 IMemInputPin::NotifyAllocator 方法。

语法

HRESULT NotifyAllocator(
   IMemAllocator *pAllocator,
   BOOL          bReadOnly
);

参数

pAllocator

指向分配器的 IMemAllocator 接口的指针。

bReadOnly

指定来自此分配器的示例是否为只读的标志。 如果 为 TRUE,则示例为只读。

返回值

返回 HRESULT 值。 可能的值包括下表中显示的值。

返回代码 说明
S_OK
成功
E_FAIL
失败
E_POINTER
NULL 指针参数

备注

筛选器尝试对两个引脚连接使用相同的分配器。

  • 如果未连接输出引脚,则输入引脚会自动接受分配器。 连接输出引脚后,筛选器将重新连接输入引脚。 此时,筛选器将再次尝试使用单个分配器。
  • 如果输出引脚已连接,则输入引脚接受分配器。 输出引脚也使用相同的分配器。 它在下游输入引脚上调用 NotifyAllocator

上一种情况有以下异常:

  • 如果建议的分配器为只读 (即 bReadOnly 参数为 TRUE) 且筛选器需要修改示例,则筛选器必须使用两个不同的分配器。 在这种情况下,如果上游筛选器建议使用下游筛选器的分配器,该方法将返回E_FAIL。

要求

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

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

另请参阅

CTransInPlaceInputPin 类