X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.cpp;h=1090112d00ba652867d3109e2004f0d12de4d257;hb=5391828a0c103944aff2b21c4bea5d86d1903f1b;hp=dbe677190b43f481894b1b220723194d90836a8a;hpb=f6cbca73b639b4250db86bd32a3e1ef27c5ecd75;p=kdenlive diff --git a/src/monitor.cpp b/src/monitor.cpp index dbe67719..1090112d 100644 --- a/src/monitor.cpp +++ b/src/monitor.cpp @@ -19,8 +19,6 @@ #include "monitor.h" -#include "renderer.h" -#include "monitormanager.h" #include "smallruler.h" #include "docclipbase.h" #include "abstractclipitem.h" @@ -46,22 +44,21 @@ Monitor::Monitor(QString name, MonitorManager *manager, QString profile, QWidget *parent) : - QWidget(parent), + AbstractMonitor(parent), render(NULL), m_name(name), m_monitorManager(manager), m_currentClip(NULL), m_ruler(new SmallRuler(m_monitorManager)), m_overlay(NULL), - m_isActive(false), m_scale(1), m_length(0), m_dragStarted(false), m_monitorRefresh(NULL), m_effectWidget(NULL), m_selectedClip(NULL), - m_loopClipTransition(true) - + m_loopClipTransition(true), + m_editMarker(NULL) { QVBoxLayout *layout = new QVBoxLayout; layout->setContentsMargins(0, 0, 0, 0); @@ -158,7 +155,7 @@ Monitor::Monitor(QString name, MonitorManager *manager, QString profile, QWidget createOpenGlWidget(m_videoBox, profile); monitorCreated = true; //m_glWidget->setFixedSize(width, height); -#elif defined (USE_OPEN_GL) +#elif defined(USE_OPENGL) if (KdenliveSettings::openglmonitors()) { monitorCreated = createOpenGlWidget(m_videoBox, profile); } @@ -172,7 +169,7 @@ Monitor::Monitor(QString name, MonitorManager *manager, QString profile, QWidget render = new Render(m_name, (int) m_monitorRefresh->winId(), profile, this); m_monitorRefresh->setRenderer(render); } -#if defined (USE_OPEN_GL) +#ifdef USE_OPENGL else if (m_glWidget) { lay->addWidget(m_glWidget); m_videoBox->setLayout(lay); @@ -184,8 +181,6 @@ Monitor::Monitor(QString name, MonitorManager *manager, QString profile, QWidget connect(render, SIGNAL(durationChanged(int)), this, SLOT(adjustRulerSize(int))); connect(render, SIGNAL(rendererStopped(int)), this, SLOT(rendererStopped(int))); - //render->createVideoXWindow(m_ui.video_frame->winId(), -1); - if (name != "clip") { connect(render, SIGNAL(rendererPosition(int)), this, SIGNAL(renderPosition(int))); connect(render, SIGNAL(durationChanged(int)), this, SIGNAL(durationChanged(int))); @@ -204,7 +199,7 @@ Monitor::Monitor(QString name, MonitorManager *manager, QString profile, QWidget } QWidget *spacer = new QWidget(this); - spacer->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding); + spacer->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::Preferred); m_toolbar->addWidget(spacer); m_timePos = new TimecodeDisplay(m_monitorManager->timecode(), this); m_toolbar->addWidget(m_timePos); @@ -229,12 +224,12 @@ QWidget *Monitor::container() return m_videoBox; } -QString Monitor::name() const +const QString Monitor::name() const { return m_name; } -#if defined(Q_WS_MAC) || defined(USE_OPEN_GL) +#ifdef USE_OPENGL bool Monitor::createOpenGlWidget(QWidget *parent, const QString profile) { render = new Render(m_name, 0, profile, this); @@ -256,8 +251,16 @@ void Monitor::setupMenu(QMenu *goMenu, QAction *playZone, QAction *loopZone, QMe m_contextMenu->addMenu(m_playMenu); if (goMenu) m_contextMenu->addMenu(goMenu); - if (markerMenu) + if (markerMenu) { m_contextMenu->addMenu(markerMenu); + QList list = markerMenu->actions(); + for (int i = 0; i < list.count(); i++) { + if (list.at(i)->data().toString() == "edit_marker") { + m_editMarker = list.at(i); + break; + } + } + } m_playMenu->addAction(playZone); m_playMenu->addAction(loopZone); @@ -425,7 +428,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()); @@ -433,7 +436,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()); @@ -443,13 +446,22 @@ void Monitor::slotSetZoneEnd() void Monitor::mousePressEvent(QMouseEvent * event) { if (event->button() != Qt::RightButton) { - if (m_videoBox->underMouse()) { + if (m_videoBox->underMouse() && (!m_overlay || !m_overlay->underMouse())) { m_dragStarted = true; m_DragStartPosition = event->pos(); } - } else m_contextMenu->popup(event->globalPos()); + } else if (!m_effectWidget || !m_effectWidget->isVisible()) { + m_contextMenu->popup(event->globalPos()); + } +} + +void Monitor::resizeEvent(QResizeEvent *event) +{ + Q_UNUSED(event); + if (render && isVisible() && isActive()) render->doRefresh(); } + void Monitor::slotSwitchFullScreen() { m_videoBox->switchFullScreen(); @@ -537,7 +549,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(); @@ -550,18 +562,22 @@ void Monitor::slotSetThumbFrame() return; } m_currentClip->setClipThumbFrame((uint) render->seekFramePosition()); - emit refreshClipThumbnail(m_currentClip->getId()); + emit refreshClipThumbnail(m_currentClip->getId(), true); } void Monitor::slotExtractCurrentFrame() { - QImage frame = render->extractFrame(render->seekFramePosition()); + QImage frame; + // check if we are using a proxy + if (m_currentClip && !m_currentClip->getProperty("proxy").isEmpty() && m_currentClip->getProperty("proxy") != "-") { + // using proxy, use original clip url to get frame + frame = render->extractFrame(render->seekFramePosition(), m_currentClip->fileURL().path()); + } + else frame = render->extractFrame(render->seekFramePosition()); KFileDialog *fs = new KFileDialog(KUrl(), "image/png", this); fs->setOperationMode(KFileDialog::Saving); fs->setMode(KFile::File); -#if KDE_IS_VERSION(4,2,0) fs->setConfirmOverwrite(true); -#endif fs->setKeepLocation(true); fs->exec(); QString path = fs->selectedFile(); @@ -573,14 +589,12 @@ void Monitor::slotExtractCurrentFrame() bool Monitor::isActive() const { - return m_isActive; + return m_monitorManager->isActive(m_name); } -void Monitor::activateMonitor() +bool Monitor::activateMonitor() { - if (!m_isActive) { - m_monitorManager->slotSwitchMonitors(m_name == "clip"); - } + return m_monitorManager->activateMonitor(m_name); } void Monitor::setTimePos(const QString &pos) @@ -596,15 +610,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")); @@ -689,7 +703,7 @@ void Monitor::slotForwardOneFrame(int diff) void Monitor::seekCursor(int pos) { - activateMonitor(); + //activateMonitor(); if (m_ruler->slotNewValue(pos)) { checkOverlay(); m_timePos->setValue(pos); @@ -702,9 +716,6 @@ void Monitor::rendererStopped(int pos) checkOverlay(); m_timePos->setValue(pos); } - disconnect(m_playAction, SIGNAL(triggered()), this, SLOT(slotPlay())); - //m_playAction->setChecked(false); - connect(m_playAction, SIGNAL(triggered()), this, SLOT(slotPlay())); m_playAction->setIcon(m_playIcon); } @@ -720,29 +731,30 @@ void Monitor::adjustRulerSize(int length) void Monitor::stop() { - m_isActive = false; disconnect(render, SIGNAL(rendererPosition(int)), this, SLOT(seekCursor(int))); if (render) render->stop(); } void Monitor::start() { - m_isActive = true; + if (!isVisible()) return; if (render) render->start(); connect(render, SIGNAL(rendererPosition(int)), this, SLOT(seekCursor(int))); } void Monitor::refreshMonitor(bool visible) { - if (visible && render && !m_isActive) { - activateMonitor(); - render->doRefresh(); //askForRefresh(); + if (visible && render) { + if (!activateMonitor()) { + // the monitor was already active, simply refreshClipThumbnail + render->doRefresh(); + } } } void Monitor::refreshMonitor() { - if (m_isActive) { + if (isActive()) { render->doRefresh(); } } @@ -760,14 +772,13 @@ void Monitor::slotPlay() { if (render == NULL) return; activateMonitor(); - if (render->playSpeed() == 0) { - //m_playAction->setChecked(true); + if (render->playSpeed() == 0.0) { m_playAction->setIcon(m_pauseIcon); + render->switchPlay(true); } else { - //m_playAction->setChecked(false); m_playAction->setIcon(m_playIcon); + render->switchPlay(false); } - render->switchPlay(); } void Monitor::slotPlayZone() @@ -800,24 +811,40 @@ void Monitor::slotLoopClip() m_playAction->setIcon(m_pauseIcon); } -void Monitor::slotSetXml(DocClipBase *clip, QPoint zone, const int position) +void Monitor::updateClipProducer(Mlt::Producer *prod) +{ + if (render == NULL) return; + render->setProducer(prod, render->seekFramePosition()); +} + +void Monitor::slotSetClipProducer(DocClipBase *clip, QPoint zone, int position) { if (render == NULL) return; if (clip == NULL && m_currentClip != NULL) { + kDebug()<<"// SETTING NULL CLIP MONITOR"; m_currentClip = NULL; m_length = -1; render->setProducer(NULL, -1); return; } - if (m_currentClip != NULL || clip != NULL) activateMonitor(); + if (clip != m_currentClip) { m_currentClip = clip; + if (m_currentClip) activateMonitor(); updateMarkers(clip); - if (render->setProducer(clip->producer(), position) == -1) { + Mlt::Producer *prod = NULL; + if (clip) prod = clip->getCloneProducer(); + if (render->setProducer(prod, position) == -1) { // MLT CONSUMER is broken kDebug(QtWarningMsg) << "ERROR, Cannot start monitor"; } - } else if (position != -1) render->seek(position); + } else { + if (m_currentClip) { + activateMonitor(); + if (position == -1) position = render->seekFramePosition(); + render->seek(position); + } + } if (!zone.isNull()) { m_ruler->setZone(zone.x(), zone.y()); render->seek(zone.x()); @@ -841,12 +868,12 @@ void Monitor::slotOpenFile(const QString &file) void Monitor::slotSaveZone() { if (render == NULL) return; - emit saveZone(render, m_ruler->zone()); + emit saveZone(render, m_ruler->zone(), m_currentClip); //render->setSceneList(doc, 0); } -void Monitor::resetProfile(const QString profile) +void Monitor::resetProfile(const QString &profile) { m_timePos->updateTimeCode(m_monitorManager->timecode()); if (render == NULL) return; @@ -885,20 +912,38 @@ void Monitor::slotSwitchMonitorInfo(bool show) if (m_overlay) return; if (m_monitorRefresh == NULL) { // Using OpenGL display -#if defined(Q_WS_MAC) || defined(USE_OPEN_GL) - m_overlay = new Overlay(m_glWidget); +#ifdef USE_OPENGL + if (m_glWidget->layout()) delete m_glWidget->layout(); + m_overlay = new Overlay(); + connect(m_overlay, SIGNAL(editMarker()), this, SLOT(slotEditMarker())); + QVBoxLayout *layout = new QVBoxLayout; + layout->addStretch(10); + layout->addWidget(m_overlay); + m_glWidget->setLayout(layout); #endif } else { - m_overlay = new Overlay(m_monitorRefresh); + if (m_monitorRefresh->layout()) delete m_monitorRefresh->layout(); + m_overlay = new Overlay(); + connect(m_overlay, SIGNAL(editMarker()), this, SLOT(slotEditMarker())); + QVBoxLayout *layout = new QVBoxLayout; + layout->addStretch(10); + layout->addWidget(m_overlay); + m_monitorRefresh->setLayout(layout); m_overlay->raise(); m_overlay->setHidden(true); } + checkOverlay(); } else { delete m_overlay; m_overlay = NULL; } } +void Monitor::slotEditMarker() +{ + if (m_editMarker) m_editMarker->trigger(); +} + void Monitor::updateTimecodeFormat() { m_timePos->slotUpdateTimeCodeFormat(); @@ -947,7 +992,7 @@ void Monitor::slotEffectScene(bool show) if (m_monitorRefresh) { m_monitorRefresh->setVisible(!show); } else { -#if defined(Q_WS_MAC) || defined(USE_OPEN_GL) +#ifdef USE_OPENGL m_glWidget->setVisible(!show); #endif } @@ -993,6 +1038,11 @@ void Monitor::slotShowVolume() m_volumePopup->show(); } +AbstractRender *Monitor::abstractRender() +{ + return render; +} + MonitorRefresh::MonitorRefresh(QWidget* parent) : QWidget(parent) , m_renderer(NULL) @@ -1000,6 +1050,7 @@ MonitorRefresh::MonitorRefresh(QWidget* parent) : // MonitorRefresh is used as container for the SDL display (it's window id is passed to SDL) setAttribute(Qt::WA_PaintOnScreen); setAttribute(Qt::WA_OpaquePaintEvent); + setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding); //setAttribute(Qt::WA_NoSystemBackground); } @@ -1008,20 +1059,34 @@ void MonitorRefresh::setRenderer(Render* render) m_renderer = render; } -void MonitorRefresh::paintEvent(QPaintEvent *event) -{ - Q_UNUSED(event); - if (m_renderer) m_renderer->doRefresh(); -} Overlay::Overlay(QWidget* parent) : QLabel(parent) { - setAttribute(Qt::WA_TransparentForMouseEvents); - //setAttribute(Qt::WA_OpaquePaintEvent); - //setAttribute(Qt::WA_NoSystemBackground); + //setAttribute(Qt::WA_TransparentForMouseEvents); setAutoFillBackground(true); setBackgroundRole(QPalette::Base); + setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred); + setCursor(Qt::PointingHandCursor); +} + +// virtual +void Overlay::mouseReleaseEvent ( QMouseEvent * event ) +{ + event->accept(); +} + +// virtual +void Overlay::mousePressEvent( QMouseEvent * event ) +{ + event->accept(); +} + +// virtual +void Overlay::mouseDoubleClickEvent ( QMouseEvent * event ) +{ + emit editMarker(); + event->accept(); } void Overlay::setOverlayText(const QString &text, bool isZone) @@ -1093,7 +1158,7 @@ void VideoContainer::wheelEvent(QWheelEvent * event) void VideoContainer::mouseDoubleClickEvent(QMouseEvent * event) { - Q_UNUSED(event); + Q_UNUSED(event) if (!KdenliveSettings::openglmonitors()) switchFullScreen();