Поделиться через


Использование сопоставителя источника

Средство выбора источника принимает URL-адрес или поток байтов и создает соответствующий источник мультимедиа для этого контента. Чтобы создать сопоставитель источника, вызовите MFCreateSourceResolver. Эта функция возвращает указатель интерфейса IMFSourceResolver .

Сопоставитель источника имеет синхронные и асинхронные методы. Если вы используете сопоставитель источника из потока приложения main, асинхронные методы сделают пользовательский интерфейс более быстрым. Синхронные методы могут блокироваться в течение заметного количества времени, особенно если сопоставителю источника необходимо открыть сетевой ресурс.

Синхронные методы:

Асинхронные методы:

Для асинхронных методов каждый метод имеет соответствующий метод End... для выполнения асинхронного запроса и метод Cancel... для отмены ожидающего запроса. Дополнительные сведения об асинхронных методах в Media Foundation см. в разделе Асинхронные методы обратного вызова.

В следующем примере кода создается источник мультимедиа на основе URL-адреса. В этом примере используется синхронный метод .

//  Create a media source from a URL.
HRESULT CreateMediaSource(PCWSTR sURL, IMFMediaSource **ppSource)
{
    MF_OBJECT_TYPE ObjectType = MF_OBJECT_INVALID;

    IMFSourceResolver* pSourceResolver = NULL;
    IUnknown* pSource = NULL;

    // Create the source resolver.
    HRESULT hr = MFCreateSourceResolver(&pSourceResolver);
    if (FAILED(hr))
    {
        goto done;
    }

    // Use the source resolver to create the media source.

    // Note: For simplicity this sample uses the synchronous method to create 
    // the media source. However, creating a media source can take a noticeable
    // amount of time, especially for a network source. For a more responsive 
    // UI, use the asynchronous BeginCreateObjectFromURL method.

    hr = pSourceResolver->CreateObjectFromURL(
        sURL,                       // URL of the source.
        MF_RESOLUTION_MEDIASOURCE,  // Create a source object.
        NULL,                       // Optional property store.
        &ObjectType,        // Receives the created object type. 
        &pSource            // Receives a pointer to the media source.
        );
    if (FAILED(hr))
    {
        goto done;
    }

    // Get the IMFMediaSource interface from the media source.
    hr = pSource->QueryInterface(IID_PPV_ARGS(ppSource));

done:
    SafeRelease(&pSourceResolver);
    SafeRelease(&pSource);
    return hr;
}

Сопоставитель источника