CBaseControlVideo.GetCurrentImage 方法

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

方法 GetCurrentImage 检索呈现器中当前图像的副本。

语法

HRESULT GetCurrentImage(
   long *pBufferSize,
   long *pVideoImage
);

参数

pBufferSize

指向输出缓冲区大小的指针。

pVideoImage

指向图像输出缓冲区的指针。

返回值

返回依赖于实现的 HRESULT 值;可以是下列值之一,也可以是未列出的其他值。

返回代码 说明
E_FAIL
失败。
E_INVALIDARG
无效的参数。
E_OUTOFMEMORY
内存不足。 当 pVideoInfo 参数为 NULL 时返回。
NOERROR
成功。
VFW_E_NOT_PAUSED
无法执行该操作,因为筛选器未暂停。

备注

此成员函数从示例中检索图像,并将其复制到输出缓冲区中。 复制到输出缓冲区中的视频部分反映通过 IBasicVideo 接口设置的源矩形。 它不反映目标矩形。

要求

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

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

另请参阅

CBaseControlVideo 类