CSourceSeeking.CheckCapabilities 方法

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

方法 CheckCapabilities 查询流是否具有指定的查找功能。 此方法实现 IMediaSeeking::CheckCapabilities 方法。

语法

HRESULT CheckCapabilities(
   DWORD *pCapabilities
);

参数

pCapabilities

指向一个或多个 AM_SEEKING_SEEKING_CAPABILITIES 属性的按位组合的指针。

返回值

返回下表中列出的 HRESULT 值之一。

返回代码 说明
S_FALSE
pCapabilities 中并非所有功能都存在。
S_OK
pCapabilities 中的所有功能都存在。
E_POINTER
NULL 指针参数。

备注

实现时,此方法根据 CSourceSeeking::m_dwSeekingCaps 成员变量检查 *pCapabilities 的值。 但是,它不会将 *pCapabilities 设置为等于 m_dwSeekingCaps,如 IMediaSeeking::CheckCapabilities 方法中所述。 此外,如果指定的功能均不可用,该方法不会返回E_FAIL。 更完整的实现如下所示:

STDMETHODIMP CheckCapabilities(DWORD *pCapabilities)
{
    CheckPointer(pCapabilities, E_POINTER)
;
    DWORD dwCaps;
    HRESULT hr = GetCapabilities(&dwCaps);
    if (SUCCEEDED(hr))
    {
        dwCaps &= *pCapabilities;
        if (dwCaps)
        {
            hr =  (dwCaps == *pCapabilities ? S_OK : S_FALSE );
        }
        else 
        {
            hr = E_FAIL;
        }
        *pCapabilities = dwCaps;
    }
    else 
    {
        *pCapabilities = 0;
    }
    return hr;
}

要求

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

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

另请参阅

CSourceSeeking 类