CSourceStream.FillBuffer 方法

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

方法 FillBuffer 使用数据填充媒体示例。

语法

virtual HRESULT FillBuffer(
   IMediaSample *pSample
) = 0;

参数

pSample

指向示例 IMediaSample 接口的指针。

返回值

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

返回代码 说明
S_FALSE
流结束
S_OK
成功

备注

派生类必须实现此方法。

提供给此方法的媒体示例没有时间戳。 派生类应调用 IMediaSample::SetTime 方法来设置时间戳。 如果适合媒体类型,派生类还应通过调用 IMediaSample::SetMediaTime 方法来设置媒体时间。 有关详细信息,请参阅 DirectShow 中的时间和时钟

在流末尾返回S_FALSE。 这会导致 CSourceStream 类发送流结束通知并停止缓冲区处理循环。 有关详细信息 ,请参阅 CSourceStream::D oBufferProcessingLoop

要求

要求
标头
Source.h (包括 Streams.h)

Strmbase.lib (零售版本) ;
Strmbasd.lib (调试生成)

另请参阅

CSourceStream 类