- m_playButton(0),
- m_stopButton(0),
- m_media(0),
- m_seekSlider(0)
-{
- QHBoxLayout *innerLayout = new QHBoxLayout(this);
- innerLayout->setMargin(0);
- innerLayout->setSpacing(0);
- m_playButton = new QToolButton(this);
- m_stopButton = new QToolButton(this);
- m_seekSlider = new Phonon::SeekSlider(this);
- innerLayout->addWidget(m_playButton);
- innerLayout->addWidget(m_stopButton);
- innerLayout->addWidget(m_seekSlider);
-
- m_playButton->setToolTip(i18n("play"));
- m_playButton->setIconSize(QSize(16, 16));
- m_playButton->setIcon(KIcon("media-playback-start"));
- connect(m_playButton, SIGNAL(clicked()), this, SLOT(play()));
-
- m_stopButton->setToolTip(i18n("stop"));
- m_stopButton->setIconSize(QSize(16, 16));
- m_stopButton->setIcon(KIcon("media-playback-stop"));
- m_stopButton->hide();
- connect(m_stopButton, SIGNAL(clicked()), this, SLOT(stop()));
-
- m_seekSlider->setIconVisible(false);
-}
-
-void PhononWidget::setUrl(const KUrl &url)
-{
- m_url = url;
- if (m_media) {
- m_media->setCurrentSource(url);
+ m_playButton(nullptr),
+ m_pauseButton(nullptr),
+ m_topLayout(nullptr),
+ m_media(nullptr),
+ m_seekSlider(nullptr),
+ m_audioOutput(nullptr),
+ m_videoPlayer(nullptr)
+{
+}
+
+void PhononWidget::setUrl(const QUrl &url, MediaKind kind)
+{
+ if (m_url != url) {
+ m_url = url;
+ m_isVideo = kind == MediaKind::Video;
+ }
+ if (m_autoPlay) {
+ play();
+ } else {
+ stop();
+ }
+}
+
+void PhononWidget::setAutoPlay(bool autoPlay)
+{
+ m_autoPlay = autoPlay;
+ if (!m_url.isEmpty() && (m_media == nullptr || m_media->state() != Phonon::State::PlayingState) && m_autoPlay && isVisible()) {
+ play();
+ }
+}
+
+QUrl PhononWidget::url() const
+{
+ return m_url;
+}
+
+void PhononWidget::clearUrl()
+{
+ m_url.clear();
+}
+
+void PhononWidget::togglePlayback()
+{
+ if (m_media && m_media->state() == Phonon::State::PlayingState) {
+ m_media->pause();
+ } else {
+ play();
+ }
+}
+
+bool PhononWidget::eventFilter(QObject *object, QEvent *event)
+{
+ Q_UNUSED(object)
+ if (event->type() == QEvent::MouseButtonPress) {
+ const QMouseEvent *mouseEvent = static_cast<QMouseEvent*>(event);
+ if (mouseEvent->button() == Qt::LeftButton) {
+ // toggle playback
+ togglePlayback();
+ return true;
+ }
+ }
+ return false;
+}
+
+void PhononWidget::setVideoSize(const QSize& size)
+{
+ if (m_videoSize != size) {
+ m_videoSize = size;
+ applyVideoSize();
+ }
+}
+
+QSize PhononWidget::videoSize() const
+{
+ return m_videoSize;
+}
+
+void PhononWidget::showEvent(QShowEvent *event)
+{
+ if (event->spontaneous()) {
+ QWidget::showEvent(event);
+ return;
+ }
+
+ if (!m_topLayout) {
+ m_topLayout = new QVBoxLayout(this);
+ m_topLayout->setContentsMargins(0, 0, 0, 0);
+
+ QHBoxLayout *controlsLayout = new QHBoxLayout();
+ controlsLayout->setContentsMargins(0, 0, 0, 0);
+ controlsLayout->setSpacing(0);
+
+ m_playButton = new QToolButton(this);
+ m_pauseButton = new QToolButton(this);
+ m_seekSlider = new Phonon::SeekSlider(this);
+
+ controlsLayout->addWidget(m_playButton);
+ controlsLayout->addWidget(m_pauseButton);
+ controlsLayout->addWidget(m_seekSlider);
+
+ m_topLayout->addLayout(controlsLayout);
+
+ const int smallIconSize = style()->pixelMetric(QStyle::PM_SmallIconSize);
+ const QSize buttonSize(smallIconSize, smallIconSize);
+
+ m_playButton->setToolTip(i18n("play"));
+ m_playButton->setIconSize(buttonSize);
+ m_playButton->setIcon(QIcon::fromTheme(QStringLiteral("media-playback-start")));
+ m_playButton->setAutoRaise(true);
+ connect(m_playButton, &QToolButton::clicked, this, &PhononWidget::play);
+
+ m_pauseButton->setToolTip(i18n("pause"));
+ m_pauseButton->setIconSize(buttonSize);
+ m_pauseButton->setIcon(QIcon::fromTheme(QStringLiteral("media-playback-pause")));
+ m_pauseButton->setAutoRaise(true);
+ m_pauseButton->hide();
+ connect(m_pauseButton, &QToolButton::clicked, this, &PhononWidget::togglePlayback);
+
+ m_seekSlider->setIconVisible(false);
+
+ // Creating an audio player or video player instance might take up to
+ // 2 seconds when doing it the first time. To prevent that the user
+ // interface gets noticeable blocked, the creation is delayed until
+ // the play button has been pressed (see PhononWidget::play()).
+ }
+}
+
+void PhononWidget::hideEvent(QHideEvent *event)
+{
+ QWidget::hideEvent(event);
+ if (!event->spontaneous()) {
+ stop();