Énumération des filtres

le gestionnaire de Graph de filtre prend en charge la méthode IFilterGraph :: EnumFilters , qui énumère tous les filtres dans le graphique de filtre. Elle retourne un pointeur vers l’interface IEnumFilters . La méthode IEnumFilters :: Next récupère les pointeurs d’interface IBaseFilter .

L’exemple suivant montre une fonction qui énumère les filtres dans un graphique et affiche une boîte de message avec le nom de chaque filtre. Elle utilise la méthode IBaseFilter :: QueryFilterInfo pour récupérer le nom du filtre. Notez les emplacements où la fonction appelle Release sur une interface pour décrémenter le décompte de références.

HRESULT EnumFilters (IFilterGraph *pGraph) 
{
    IEnumFilters *pEnum = NULL;
    IBaseFilter *pFilter;
    ULONG cFetched;

    HRESULT hr = pGraph->EnumFilters(&pEnum);
    if (FAILED(hr)) return hr;

    while(pEnum->Next(1, &pFilter, &cFetched) == S_OK)
    {
        FILTER_INFO FilterInfo;
        hr = pFilter->QueryFilterInfo(&FilterInfo);
        if (FAILED(hr))
        {
            MessageBox(NULL, TEXT("Could not get the filter info"),
                TEXT("Error"), MB_OK | MB_ICONERROR);
            continue;  // Maybe the next one will work.
        }

#ifdef UNICODE
        MessageBox(NULL, FilterInfo.achName, TEXT("Filter Name"), MB_OK);
#else
        char szName[MAX_FILTER_NAME];
        int cch = WideCharToMultiByte(CP_ACP, 0, FilterInfo.achName,
            MAX_FILTER_NAME, szName, MAX_FILTER_NAME, 0, 0);
        if (cch > 0)
            MessageBox(NULL, szName, TEXT("Filter Name"), MB_OK);
#endif

        // The FILTER_INFO structure holds a pointer to the Filter Graph
        // Manager, with a reference count that must be released.
        if (FilterInfo.pGraph != NULL)
        {
            FilterInfo.pGraph->Release();
        }
        pFilter->Release();
    }

    pEnum->Release();
    return S_OK;
}

Énumération d’objets dans un filtre Graph