IMemInputPin::Receive 方法 (strmif.h)

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

方法 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 调用。
  • 下游筛选器检测到流的末尾。 (请参阅Stream终止通知.)

要求

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

另请参阅

错误和成功代码

IMemInputPin 接口