Воспроизведение клипа файла
[MFPlay доступен для использования в операционных системах, указанных в разделе Требования. В последующих версиях он может быть изменен или недоступен. ]
В этом разделе описывается воспроизведение сегмента файла мультимедиа в MFPlay путем установки времени начала и остановки воспроизведения.
Воспроизведение клипа файла
- Вызовите IMFPMediaPlayer::CreateMediaItemFromURL или IMFPMediaPlayer::CreateMediaItemFromObject , чтобы создать элемент мультимедиа для файла.
- При необходимости получите общую продолжительность файла, как описано в разделе Получение длительности воспроизведения.
- Вызовите IMFPMediaItem::SetStartStopPosition , чтобы задать время начала и остановки. Время остановки не должно превышать длительность файла.
- Вызовите IMFPMediaPlayer::SetMediaItem , чтобы начать воспроизведение.
В следующем примере используется блокирующая версия CreateMediaItemFromURL. Если используется неблокирующая версия, код, отображаемый после CreateMediaItemFromURL , должен быть помещен в обработчик события MFP_EVENT_TYPE_MEDIAITEM_CREATED . Дополнительные сведения о событиях в MFPlay см. в разделе Получение событий из проигрывателя.
Чтобы получить длительность файла, в этом примере вызывается GetPlaybackDuration
функция, показанная в разделе How to Get the Playback Duration (Получение длительности воспроизведения).
HRESULT PlayMediaClip(
IMFPMediaPlayer *pPlayer,
PCWSTR pszURL,
LONGLONG hnsStart,
LONGLONG hnsEnd
)
{
IMFPMediaItem *pItem = NULL;
PROPVARIANT varStart, varEnd;
ULONGLONG hnsDuration = 0;
HRESULT hr = pPlayer->CreateMediaItemFromURL(pszURL, TRUE, 0, &pItem);
if (FAILED(hr))
{
goto done;
}
hr = GetPlaybackDuration(pItem, &hnsDuration);
if (FAILED(hr))
{
goto done;
}
if ((ULONGLONG)hnsEnd > hnsDuration)
{
hnsEnd = hnsDuration;
}
hr = InitPropVariantFromInt64(hnsStart, &varStart);
if (FAILED(hr))
{
goto done;
}
hr = InitPropVariantFromInt64(hnsEnd, &varEnd);
if (FAILED(hr))
{
goto done;
}
hr = pItem->SetStartStopPosition(
&MFP_POSITIONTYPE_100NS,
&varStart,
&MFP_POSITIONTYPE_100NS,
&varEnd
);
if (FAILED(hr))
{
goto done;
}
hr = pPlayer->SetMediaItem(pItem);
done:
SafeRelease(&pItem);
return hr;
}
Требования
Для MFPlay требуется Windows 7.
Связанные темы
Обратная связь
https://aka.ms/ContentUserFeedback.
Ожидается в ближайшее время: в течение 2024 года мы постепенно откажемся от GitHub Issues как механизма обратной связи для контента и заменим его новой системой обратной связи. Дополнительные сведения см. в разделеОтправить и просмотреть отзыв по