IVMRFilterConfig::SetNumberOfStreams 方法 (strmif.h)

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

方法 SetNumberOfStreams 设置要混合的流数,并指示 VMR 进入混合器模式。

语法

HRESULT SetNumberOfStreams(
  [in] DWORD dwMaxStreams
);

参数

[in] dwMaxStreams

包含 VMR 混合所需的最大输入流数的双字。 不得大于 MAX_MIXER_STREAMS (16) 。

返回值

如果该方法成功,则它会返回 S_OK。 如果该方法失败,则会返回错误代码。

返回代码 说明
E_FAIL
已配置混音器。
E_INVALIDARG
尝试为超过 16 个输入流配置混音器。
E_OUTOFMEMORY
无法分配用于管理流的内存。

注解

dwMaxStreams 应等于所需的输入引脚数。 连接 VMR 后,无法添加或删除引脚。 如果事先不知道需要多少个输入流,请将 dxMaxStreams 设置为可能需要的最大数量。 值为 1 对 dwMaxStreams 有效。 此值不会导致创建任何额外的引脚,但它会强制 VMR 进入“混合器模式”。因此,调用此方法后,无法调用 SetRenderingMode 将模式设置为 VMRMode_Renderless

VMR 会创建指定数量的输入引脚,而无需尝试确定是否有足够的视频内存来支持所有这些引脚。 这是因为它目前无法知道媒体类型或矩形尺寸。 稍后,当上游筛选器尝试连接到引脚时,此时媒体类型已知,VMR 将检查视频内存,如果没有足够的处理流,则连接失败。

注意 尽管 VMR 支持多个流,但它们都共享一个时钟,因此不能单独查找一个流。 如果需要独立查找输入流,则必须使用不同的技术。 有关详细信息,请参阅 VMRMulti 示例。
 

要求

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

另请参阅

错误和成功代码

IVMRFilterConfig 接口

IVMRFilterConfig::GetNumberOfStreams

使用视频混合呈现器