CBaseInputPin.ReceiveCanBlock 方法
[与此页面关联的功能 DirectShow 是旧版功能。 它已被 MediaPlayer、 IMFMediaEngine 和 Media Foundation 中的音频/视频捕获所取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能在 Media Foundation 中使用 MediaPlayer、 IMFMediaEngine 和 音频/视频捕获 ,而不是 DirectShow。 如果可能,Microsoft 建议重写使用旧 API 的现有代码以使用新 API。]
方法 ReceiveCanBlock
确定是否可能会阻止对 IMemInputPin::Receive 方法的调用。 此方法实现 IMemInputPin::ReceiveCanBlock 方法。
语法
HRESULT ReceiveCanBlock();
参数
此方法没有任何参数。
返回值
返回 HRESULT 值。 可能的值包括下表中列出的值。
返回代码 | 说明 |
---|---|
|
引脚不会阻止对 Receive 的调用。 |
|
引脚可能会在调用 Receive 时阻止。 |
备注
如果保证不阻止对 Receive 方法的调用,则返回S_FALSE。 否则,返回S_OK或错误代码。 如果 Receive 方法在下游引脚上调用 Receive ,则下游引脚可能会阻止; ReceiveCanBlock
必须考虑到这一因素。
上游筛选器可以使用此方法来确定其线程策略。 如果 Receive 方法可能会阻止,上游筛选器可能会决定使用缓冲数据的工作线程。 有关此策略的实现,请参阅 COutputQueue 类。
在基类中,当以下任一情况为 true 时,此方法将返回S_OK:
- 筛选器没有输出引脚。
- 连接到此筛选器的输入引脚发出信号,表明它可能会阻止。
- 连接到此筛选器的输入引脚不支持 IMemInputPin 接口。
要求
要求 | 值 |
---|---|
标头 |
|
库 |
|