CBaseInputPin.ReceiveCanBlock 方法

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

方法 ReceiveCanBlock 确定是否可能会阻止对 IMemInputPin::Receive 方法的调用。 此方法实现 IMemInputPin::ReceiveCanBlock 方法。

语法

HRESULT ReceiveCanBlock();

参数

此方法没有任何参数。

返回值

返回 HRESULT 值。 可能的值包括下表中列出的值。

返回代码 说明
S_FALSE
引脚不会阻止对 Receive 的调用。
S_OK
引脚可能会在调用 Receive 时阻止。

备注

如果保证不阻止对 Receive 方法的调用,则返回S_FALSE。 否则,返回S_OK或错误代码。 如果 Receive 方法在下游引脚上调用 Receive ,则下游引脚可能会阻止; ReceiveCanBlock 必须考虑到这一因素。

上游筛选器可以使用此方法来确定其线程策略。 如果 Receive 方法可能会阻止,上游筛选器可能会决定使用缓冲数据的工作线程。 有关此策略的实现,请参阅 COutputQueue 类。

在基类中,当以下任一情况为 true 时,此方法将返回S_OK:

  • 筛选器没有输出引脚。
  • 连接到此筛选器的输入引脚发出信号,表明它可能会阻止。
  • 连接到此筛选器的输入引脚不支持 IMemInputPin 接口。

要求

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

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

另请参阅

CBaseInputPin 类