CSourceStream.QueryId 方法

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

方法 QueryId 检索引脚的标识符。

语法

HRESULT QueryId(
   LPWSTR *Id
);

参数

Id

指向接收包含引脚标识符的字符串的变量的指针。

返回值

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

返回代码 说明
S_OK
成功。
E_OUTOFMEMORY
内存不足。
E_POINTER
NULL 指针参数。
VFW_E_NOT_FOUND
在筛选器上找不到 Pin。

备注

此方法实现 IPin::QueryId 方法。 为了构造标识符字符串,引脚调用 CSource::FindPinNumber 方法,并将自身作为 参数。 FindPinNumber 方法返回从零开始编制索引的引脚编号。 QueryId 将返回值递增 1 并将结果转换为字符串。 例如,第一个引脚变为“1”;第二个引脚变为“2”;等等。

如果此方法返回VFW_E_NOT_FOUND,则表示筛选器的引脚数组无效,可能是由筛选器中的 bug 引起的。

要求

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

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

另请参阅

CSourceStream 类