From dfb2493aa2a5295e03b8517583f9ff31b64484aa Mon Sep 17 00:00:00 2001 From: Thomas McGuire Date: Thu, 26 Jul 2012 16:02:57 +0200 Subject: [PATCH] Blackberry: Fix case of setting multiple media files Abort the singleshot timer when the media is changed, as otherwise continueLoadMedia() was called multiple times. Also, don't use a singleshot timer when setting a null media. Change-Id: I19d4838c9c70e7fcaa790c223cb19ac3e0246e6b Reviewed-by: Kevin Krammer Reviewed-by: Sean Harmer --- src/plugins/blackberry/bbmediaplayercontrol.cpp | 13 ++++++++++--- src/plugins/blackberry/bbmediaplayercontrol.h | 2 ++ 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/src/plugins/blackberry/bbmediaplayercontrol.cpp b/src/plugins/blackberry/bbmediaplayercontrol.cpp index 63437fc..3a84149 100644 --- a/src/plugins/blackberry/bbmediaplayercontrol.cpp +++ b/src/plugins/blackberry/bbmediaplayercontrol.cpp @@ -45,7 +45,6 @@ #include #include #include -#include #include #include #include @@ -84,6 +83,9 @@ BbMediaPlayerControl::BbMediaPlayerControl(QObject *parent) m_stopEventsToIgnore(0), m_bufferStatus(0) { + m_loadingTimer.setSingleShot(true); + m_loadingTimer.setInterval(0); + connect(&m_loadingTimer, SIGNAL(timeout()), this, SLOT(continueLoadMedia())); QCoreApplication::eventDispatcher()->installNativeEventFilter(this); openConnection(); } @@ -221,6 +223,7 @@ void BbMediaPlayerControl::detach() QFile::remove(m_tempMediaFileName); m_tempMediaFileName.clear(); } + m_loadingTimer.stop(); } QMediaPlayer::State BbMediaPlayerControl::state() const @@ -423,8 +426,12 @@ void BbMediaPlayerControl::setMedia(const QMediaContent &media, QIODevice *strea // canvas is ready. // The mmrenderer doesn't allow to attach video outputs after playing has started, otherwise // this would be unnecessary. - setMediaStatus(QMediaPlayer::LoadingMedia); - QTimer::singleShot(0, this, SLOT(continueLoadMedia())); + if (!m_media.isNull()) { + setMediaStatus(QMediaPlayer::LoadingMedia); + m_loadingTimer.start(); // singleshot timer to continueLoadMedia() + } else { + continueLoadMedia(); // still needed, as it will update the media status and clear metadata + } } void BbMediaPlayerControl::continueLoadMedia() diff --git a/src/plugins/blackberry/bbmediaplayercontrol.h b/src/plugins/blackberry/bbmediaplayercontrol.h index 519a435..e8a9ed8 100644 --- a/src/plugins/blackberry/bbmediaplayercontrol.h +++ b/src/plugins/blackberry/bbmediaplayercontrol.h @@ -45,6 +45,7 @@ #include #include #include +#include struct bps_event_t; typedef struct mmr_connection mmr_connection_t; @@ -145,6 +146,7 @@ private: int m_stopEventsToIgnore; int m_bufferStatus; QString m_tempMediaFileName; + QTimer m_loadingTimer; }; QT_END_NAMESPACE -- 2.7.4