X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.cpp;h=88184ff453309de236837e98538c990288e35903;hb=1ff1bfd2d8b7c02532d00cf20b971dcf29816f60;hp=b446886ec3304d31030b0f017df0413db7c2a1b5;hpb=5a403d4a2689486dbdef95fb4c529a44636e8753;p=kdenlive diff --git a/src/monitor.cpp b/src/monitor.cpp index b446886e..88184ff4 100644 --- a/src/monitor.cpp +++ b/src/monitor.cpp @@ -180,6 +180,7 @@ Monitor::Monitor(QString name, MonitorManager *manager, QString profile, QWidget connect(m_ruler, SIGNAL(seekRenderer(int)), this, SLOT(slotSeek(int))); connect(render, SIGNAL(durationChanged(int)), this, SLOT(adjustRulerSize(int))); connect(render, SIGNAL(rendererStopped(int)), this, SLOT(rendererStopped(int))); + connect(render, SIGNAL(rendererPosition(int)), this, SLOT(seekCursor(int))); if (name != "clip") { connect(render, SIGNAL(rendererPosition(int)), this, SIGNAL(renderPosition(int))); @@ -428,7 +429,7 @@ void Monitor::slotZoneMoved(int start, int end) void Monitor::slotSetZoneStart() { - m_ruler->setZone(render->seekFramePosition(), -1); + m_ruler->setZone(m_ruler->position(), -1); emit zoneUpdated(m_ruler->zone()); checkOverlay(); setClipZone(m_ruler->zone()); @@ -436,7 +437,7 @@ void Monitor::slotSetZoneStart() void Monitor::slotSetZoneEnd() { - m_ruler->setZone(-1, render->seekFramePosition()); + m_ruler->setZone(-1, m_ruler->position()); emit zoneUpdated(m_ruler->zone()); checkOverlay(); setClipZone(m_ruler->zone()); @@ -455,6 +456,13 @@ void Monitor::mousePressEvent(QMouseEvent * event) } } +void Monitor::resizeEvent(QResizeEvent *event) +{ + Q_UNUSED(event); + if (render && isVisible() && isActive()) render->doRefresh(); +} + + void Monitor::slotSwitchFullScreen() { m_videoBox->switchFullScreen(); @@ -542,7 +550,7 @@ void Monitor::slotMouseSeek(int eventDelta, bool fast) if (fast) { int delta = m_monitorManager->timecode().fps(); if (eventDelta > 0) delta = 0 - delta; - slotSeek(render->seekFramePosition() - delta); + slotSeek(m_ruler->position() - delta); } else { if (eventDelta >= 0) slotForwardOneFrame(); else slotRewindOneFrame(); @@ -587,9 +595,9 @@ bool Monitor::isActive() const return m_monitorManager->isActive(m_name); } -void Monitor::activateMonitor() +bool Monitor::activateMonitor() { - m_monitorManager->activateMonitor(m_name); + return m_monitorManager->activateMonitor(m_name); } void Monitor::setTimePos(const QString &pos) @@ -605,15 +613,15 @@ void Monitor::slotSeek() void Monitor::slotSeek(int pos) { - //activateMonitor(); if (render == NULL) return; + activateMonitor(); render->seekToFrame(pos); } void Monitor::checkOverlay() { if (m_overlay == NULL) return; - int pos = render->seekFramePosition(); + int pos = m_ruler->position(); QPoint zone = m_ruler->zone(); if (pos == zone.x()) m_overlay->setOverlayText(i18n("In Point")); @@ -726,21 +734,22 @@ void Monitor::adjustRulerSize(int length) void Monitor::stop() { - disconnect(render, SIGNAL(rendererPosition(int)), this, SLOT(seekCursor(int))); if (render) render->stop(); } void Monitor::start() { - if (render && (m_name != "clip" || m_currentClip != NULL)) render->start(); - connect(render, SIGNAL(rendererPosition(int)), this, SLOT(seekCursor(int))); + if (!isVisible()) return; + if (render) render->start(); } void Monitor::refreshMonitor(bool visible) { if (visible && render) { - activateMonitor(); - render->doRefresh(); //askForRefresh(); + if (!activateMonitor()) { + // the monitor was already active, simply refreshClipThumbnail + render->doRefresh(); + } } } @@ -764,7 +773,7 @@ void Monitor::slotPlay() { if (render == NULL) return; activateMonitor(); - if (render->playSpeed() == 0) { + if (render->playSpeed() == 0.0) { m_playAction->setIcon(m_pauseIcon); render->switchPlay(true); } else { @@ -806,7 +815,7 @@ void Monitor::slotLoopClip() void Monitor::updateClipProducer(Mlt::Producer *prod) { if (render == NULL) return; - render->setProducer(prod, render->seekFramePosition()); + render->setProducer(prod, render->seekFramePosition()); } void Monitor::slotSetClipProducer(DocClipBase *clip, QPoint zone, int position) @@ -819,6 +828,7 @@ void Monitor::slotSetClipProducer(DocClipBase *clip, QPoint zone, int position) render->setProducer(NULL, -1); return; } + if (clip != m_currentClip) { m_currentClip = clip; if (m_currentClip) activateMonitor(); @@ -868,7 +878,10 @@ void Monitor::resetProfile(const QString &profile) { m_timePos->updateTimeCode(m_monitorManager->timecode()); if (render == NULL) return; - render->resetProfile(profile); + if (!render->hasProfile(profile)) { + activateMonitor(); + render->resetProfile(profile); + } if (m_effectWidget) m_effectWidget->resetProfile(render); } @@ -992,8 +1005,8 @@ void Monitor::slotEffectScene(bool show) emit requestFrameForAnalysis(show); if (show) { m_effectWidget->getScene()->slotZoomFit(); - render->doRefresh(); } + render->doRefresh(); } } @@ -1051,12 +1064,6 @@ void MonitorRefresh::setRenderer(Render* render) } -void MonitorRefresh::resizeEvent(QResizeEvent *event) -{ - Q_UNUSED(event); - if (m_renderer) m_renderer->doRefresh(); -} - Overlay::Overlay(QWidget* parent) : QLabel(parent) {