CVideoTransformFilter.Receive 方法
[与此页面关联的功能 DirectShow 是旧版功能。 它已被 MediaPlayer、 IMFMediaEngine 和 Media Foundation 中的音频/视频捕获所取代。 这些功能已针对Windows 10和Windows 11进行了优化。 Microsoft 强烈建议新代码尽可能在 Media Foundation 中使用 MediaPlayer、 IMFMediaEngine 和 音频/视频捕获 ,而不是 DirectShow。 如果可能,Microsoft 建议重写使用旧 API 的现有代码以使用新 API。]
方法 Receive
接收媒体示例,对其进行处理,并将输出示例传送到下游筛选器。 此方法替代 CTransformFilter::Receive 方法。
语法
HRESULT Receive(
IMediaSample *pSample
);
参数
-
pSample
-
指向输入示例上的 IMediaSample 接口的指针。
返回值
返回 HRESULT 值。 可能的值如下所示:
返回代码 | 说明 |
---|---|
|
上游筛选器应停止发送示例。 |
|
成功。 |
备注
此方法调用 CVideoTransformFilter::ShouldSkipFrame ,以确定它是应提供此示例还是直接放弃它。 如果 ShouldSkipFrame 返回 FALSE (指示示例应) 传递,则 方法将执行以下操作:
- 调用 CTransformFilter::InitializeOutputSample 来准备输出示例
- 调用 CTransformFilter::Transform 来处理输入示例。 此方法是纯虚拟的,必须在派生类中实现。
- 调用 CBaseOutputPin::D eliver 传递输出示例。
此外,此方法通过调用 IMediaSample::GetMediaType 来检查输入或输出示例的格式更改。 如果存在格式更改,方法将在相应的引脚上设置连接类型。 在设置新类型之前,它调用 StopStreaming。 设置新类型后,它将调用 StartStreaming。 派生类可以使用这些方法来更新其内部状态。 派生类可能还需要在其 Transform 方法中检查新格式。
要求
要求 | 值 |
---|---|
标头 |
|
库 |
|