Udostępnij przez


Wyliczanie typów multimediów

[Funkcja skojarzona z tą stroną, DirectShow, jest starszą funkcją. Został zastąpiony przez MediaPlayer, IMFMediaEnginei Audio/Video Capture w Media Foundation. Te funkcje zostały zoptymalizowane pod kątem systemów Windows 10 i Windows 11. Firma Microsoft zdecydowanie zaleca, aby nowy kod używał MediaPlayer, IMFMediaEngine i Audio/Video Capture w ramach Media Foundation zamiast DirectShow, jeśli to możliwe. Firma Microsoft sugeruje, że istniejący kod, który używa starszych interfejsów API, należy przepisać go do korzystania z nowych interfejsów API, jeśli to możliwe.]

Piny obsługują metodę IPin::EnumMediaTypes, która wylicza preferowane typy multimediów pinów. Zwraca wskaźnik do interfejsu IEnumMediaTypes. Metoda IEnumMediaTypes::Next pobiera wskaźniki do AM_MEDIA_TYPE struktur opisujących typy multimediów.

Wylicznik typów mediów istnieje głównie, aby pomóc Menedżerowi grafu filtrowania w tworzeniu inteligentnych połączeń, a twoje aplikacje prawdopodobnie nie będą z niego korzystać. Numer PIN nie musi zwracać żadnych preferowanych typów multimediów. Ponadto zwracane typy multimediów mogą zależeć od stanu połączenia filtru. Na przykład wyjściowy pin filtru może zwracać inny zestaw typów multimediów w zależności od tego, jaki typ multimediów został ustawiony dla pinu wejściowego filtru.

W poniższym przykładzie znajduje preferowany typ nośnika zgodny z określonym typem głównym, podtypem lub typem formatu.

// Given a pin, find a preferred media type 
//
// pPin         Pointer to the pin.
// majorType    Preferred major type (GUID_NULL = don't care).
// subType      Preferred subtype (GUID_NULL = don't care).
// formatType   Preferred format type (GUID_NULL = don't care).
// ppmt         Receives a pointer to the media type. Can be NULL.
//
// Note: If you want to check whether a pin supports a desired media type,
//       but do not need the format details, set ppmt to NULL.
//
//       If ppmt is not NULL and the method succeeds, the caller must
//       delete the media type, including the format block. 

HRESULT GetPinMediaType(
    IPin *pPin,             // pointer to the pin
    REFGUID majorType,      // desired major type, or GUID_NULL = don't care
    REFGUID subType,        // desired subtype, or GUID_NULL = don't care
    REFGUID formatType,     // desired format type, of GUID_NULL = don't care
    AM_MEDIA_TYPE **ppmt    // Receives a pointer to the media type. (Can be NULL)
    )
{
    *ppmt = NULL;

    IEnumMediaTypes *pEnum = NULL;
    AM_MEDIA_TYPE *pmt = NULL;
    BOOL bFound = FALSE;
    
    HRESULT hr = pPin->EnumMediaTypes(&pEnum);
    if (FAILED(hr))
    {
        return hr;
    }

    while (hr = pEnum->Next(1, &pmt, NULL), hr == S_OK)
    {
        if ((majorType == GUID_NULL) || (majorType == pmt->majortype))
        {
            if ((subType == GUID_NULL) || (subType == pmt->subtype))
            {
                if ((formatType == GUID_NULL) || 
                    (formatType == pmt->formattype))
                {
                    // Found a match. 
                    if (ppmt)
                    {
                        *ppmt = pmt;  // Return it to the caller
                    }
                    else
                    {
                        _DeleteMediaType(pmt);
                    }
                    bFound = TRUE;
                    break;
                }
            }
        }
        _DeleteMediaType(pmt);
    }

    SafeRelease(&pEnum);
    if (SUCCEEDED(hr))
    {
        if (!bFound)
        {
            hr = VFW_E_NOT_FOUND;
        }
    }
    return hr;
}

Notatka

W tym przykładzie użyto funkcji SafeRelease w celu zwolnienia wskaźników interfejsu.

 

wyliczanie obiektów w wykresu filtru

IEnumMediaTypes