É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;
}