IEnumMediaTypes::Clone 方法 (strmif.h)

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

方法 Clone 创建枚举器的副本。 返回的对象以与原始对象相同的枚举状态开头。

语法

HRESULT Clone(
  [out] IEnumMediaTypes **ppEnum
);

参数

[out] ppEnum

接收指向新枚举器的 IEnumMediaTypes 接口的指针。 调用方必须释放接口。

返回值

返回以下 HRESULT 值之一。

返回代码 说明
S_OK
成功。
E_OUTOFMEMORY
内存不足。
E_POINTER
NULL 指针参数。
VFW_E_ENUM_OUT_OF_SYNC
引脚的状态已更改,现在与枚举器不一致。

注解

如果媒体类型集发生更改,则枚举器不再与引脚一致,该方法将返回VFW_E_ENUM_OUT_OF_SYNC。 放弃从先前调用枚举器中获得的任何数据,因为它可能无效。 通过调用 Reset 方法更新枚举器。 然后,可以安全地调用 Clone 方法。

要求

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

另请参阅

枚举媒体类型

错误和成功代码

IEnumMediaTypes 接口