IMemInputPin::Receive 方法 (strmif.h)
[与此页面关联的功能 DirectShow 是旧版功能。 它已被 MediaPlayer、 IMFMediaEngine 和 Media Foundation 中的音频/视频捕获所取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能在 Media Foundation 中使用 MediaPlayer、 IMFMediaEngine 和 音频/视频捕获 ,而不是 DirectShow。 如果可能,Microsoft 建议重写使用旧 API 的现有代码以使用新 API。]
方法 Receive
接收流中的下一个媒体示例。
语法
HRESULT Receive(
[in] IMediaSample *pSample
);
参数
[in] pSample
指向示例 IMediaSample 接口的指针。
返回值
返回 HRESULT 值。 可能的值包括下表中显示的值。
返回代码 | 说明 |
---|---|
|
成功。 |
|
示例被拒绝。 |
|
NULL 指针参数。 |
|
媒体类型无效。 |
|
发生运行时错误。 |
|
引脚已停止。 |
注解
此方法是同步的,可能会阻止。 引脚执行以下操作之一:
- 拒绝示例。
- 立即返回并处理工作线程中的示例。
- 在返回之前处理示例。
如果引脚使用工作线程来处理示例,它将保留样本的引用计数。 在任何情况下,输出引脚都不能直接重复使用此示例。 它必须调用 IMemAllocator::GetBuffer 方法以获取新示例。
如果此方法返回S_FALSE或错误代码,则上游筛选器应停止发送样本,直到图形停止或完成刷新操作。 S_FALSE返回值的典型原因包括:
- 正在刷新下游引脚;也就是说,它已收到 BeginFlush 调用,但尚未收到 EndFlush 调用。
- 下游筛选器检测到流的末尾。 (请参阅Stream终止通知.)
要求
要求 | 值 |
---|---|
最低受支持的客户端 | Windows 2000 Professional [仅限桌面应用] |
最低受支持的服务器 | Windows 2000 Server [仅限桌面应用] |
目标平台 | Windows |
标头 | strmif.h (包括 Dshow.h) |
Library | Strmiids.lib |