IMemInputPin::Receive 方法 (strmif.h)

该方法 Receive 在流中接收下一个媒体示例。

语法

HRESULT Receive(
  [in] IMediaSample *pSample
);

参数

[in] pSample

指向示例的 IMediaSample 接口的指针。

返回值

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

返回代码 说明
S_OK
成功。
S_FALSE
该示例被拒绝。
E_POINTER
NULL 指针参数。
VFW_E_INVALIDMEDIATYPE
媒体类型无效。
VFW_E_RUNTIME_ERROR
出现运行时错误。
VFW_E_WRONG_STATE
引脚已停止。

注解

此方法是同步的,可能阻止。 引脚执行以下操作之一:

  • 拒绝示例。
  • 立即返回并处理工作线程中的示例。
  • 在返回之前处理示例。
在最后一种情况下,该方法可能会无限期阻止。 如果发生这种情况, IMemInputPin::ReceiveCanBlock 方法将返回S_OK。

如果引脚使用工作线程来处理示例,则它保留样本的引用计数。 在任何情况下,输出引脚都不能直接重复使用此示例。 它必须调用 IMemAllocator::GetBuffer 方法以获取新示例。

如果此方法返回S_FALSE或错误代码,上游筛选器应停止发送样本,直到图形停止或完成刷新操作。 S_FALSE返回值的典型原因包括:

  • 下游引脚正在刷新;也就是说,它收到了 BeginFlush 呼叫,尚未收到 EndFlush 呼叫。
  • 下游筛选器检测到流的末尾。 (请参阅 流结束通知.)

要求

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

另请参阅

错误和成功代码

IMemInputPin 接口