Шаг 2. Создание объекта CPlayer
Этот раздел является шагом 2 руководства Воспроизведение файлов мультимедиа с помощью Media Foundation. Полный код показан в разделе Пример воспроизведения сеанса мультимедиа.
Чтобы создать экземпляр CPlayer
класса , приложение вызывает статический CPlayer::CreateInstance
метод . Этот метод принимает следующие параметры:
- hVideo указывает окно для отображения видео.
- hEvent указывает окно для получения событий. Допустимо передавать один и тот же дескриптор для обоих дескрипторов окна.
-
ppPlayer получает указатель на новый
CPlayer
экземпляр.
В следующем примере кода показан метод CreateInstance
:
// Static class method to create the CPlayer object.
HRESULT CPlayer::CreateInstance(
HWND hVideo, // Video window.
HWND hEvent, // Window to receive notifications.
CPlayer **ppPlayer) // Receives a pointer to the CPlayer object.
{
if (ppPlayer == NULL)
{
return E_POINTER;
}
CPlayer *pPlayer = new (std::nothrow) CPlayer(hVideo, hEvent);
if (pPlayer == NULL)
{
return E_OUTOFMEMORY;
}
HRESULT hr = pPlayer->Initialize();
if (SUCCEEDED(hr))
{
*ppPlayer = pPlayer;
}
else
{
pPlayer->Release();
}
return hr;
}
HRESULT CPlayer::Initialize()
{
// Start up Media Foundation platform.
HRESULT hr = MFStartup(MF_VERSION);
if (SUCCEEDED(hr))
{
m_hCloseEvent = CreateEvent(NULL, FALSE, FALSE, NULL);
if (m_hCloseEvent == NULL)
{
hr = HRESULT_FROM_WIN32(GetLastError());
}
}
return hr;
}
В следующем коде CPlayer
показан конструктор:
CPlayer::CPlayer(HWND hVideo, HWND hEvent) :
m_pSession(NULL),
m_pSource(NULL),
m_pVideoDisplay(NULL),
m_hwndVideo(hVideo),
m_hwndEvent(hEvent),
m_state(Closed),
m_hCloseEvent(NULL),
m_nRefCount(1)
{
}
Конструктор выполняет следующие действия:
- Вызывает MFStartup для инициализации платформы Media Foundation.
- Создает событие автоматического сброса. Это событие используется при закрытии сеанса мультимедиа; См . раздел Шаг 7. Завершение сеанса мультимедиа.
Деструктор завершает сеанс мультимедиа, как описано в разделе Шаг 7. Завершение сеанса мультимедиа.
CPlayer::~CPlayer()
{
assert(m_pSession == NULL);
// If FALSE, the app did not call Shutdown().
// When CPlayer calls IMediaEventGenerator::BeginGetEvent on the
// media session, it causes the media session to hold a reference
// count on the CPlayer.
// This creates a circular reference count between CPlayer and the
// media session. Calling Shutdown breaks the circular reference
// count.
// If CreateInstance fails, the application will not call
// Shutdown. To handle that case, call Shutdown in the destructor.
Shutdown();
}
Обратите внимание, что конструктор и деструктор являются защищенными методами класса. Приложение создает объект с помощью статического CreateInstance
метода . Он уничтожает объект путем вызова IUnknown::Release, а не явным образом с помощью удаления.
Далее: Шаг 3. Открытие файла мультимедиа
Связанные темы