X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Ftransitionsettings.cpp;h=dc8c0f4717c42728d057b620a804885763b04756;hb=60765fc245b14766d297e6b0167e84d2672bf439;hp=6d87559b27700b064b6f36c23e5d9a33aa8a6285;hpb=aa49bce660baf4d4e29b0355024ff8b0556e3f18;p=kdenlive diff --git a/src/transitionsettings.cpp b/src/transitionsettings.cpp index 6d87559b..dc8c0f47 100644 --- a/src/transitionsettings.cpp +++ b/src/transitionsettings.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - effecstackedit.h - description + effecstackedit.cpp - description ------------------- begin : Mar 15 2008 copyright : (C) 2008 by Marco Gittler @@ -23,6 +23,8 @@ #include "effectstackedit.h" #include "kdenlivesettings.h" #include "mainwindow.h" +#include "monitoreditwidget.h" +#include "monitorscene.h" #include @@ -38,7 +40,9 @@ TransitionSettings::TransitionSettings(Monitor *monitor, QWidget* parent) : vbox1->setSpacing(0); vbox1->addWidget(m_effectEdit); frame->setSizePolicy(QSizePolicy(QSizePolicy::Expanding, QSizePolicy::Minimum)); - connect(m_effectEdit, SIGNAL(seekTimeline(int)), this, SIGNAL(seekTimeline(int))); + connect(m_effectEdit, SIGNAL(seekTimeline(int)), this, SLOT(slotSeekTimeline(int))); + connect(m_effectEdit, SIGNAL(importClipKeyframes()), this, SIGNAL(importClipKeyframes())); + setEnabled(false); QList transitionsList; @@ -62,8 +66,7 @@ TransitionSettings::TransitionSettings(Monitor *monitor, QWidget* parent) : connect(transitionList, SIGNAL(activated(int)), this, SLOT(slotTransitionChanged())); connect(transitionTrack, SIGNAL(activated(int)), this, SLOT(slotTransitionTrackChanged())); - connect(m_effectEdit, SIGNAL(parameterChanged(const QDomElement&, const QDomElement&)), this , SLOT(slotUpdateEffectParams(const QDomElement&, const QDomElement&))); - connect(monitor, SIGNAL(renderPosition(int)), this, SLOT(slotRenderPos(int))); + connect(m_effectEdit, SIGNAL(parameterChanged(const QDomElement, const QDomElement, int)), this , SLOT(slotUpdateEffectParams(const QDomElement, const QDomElement))); } void TransitionSettings::updateProjectFormat(MltVideoProfile profile, Timecode t, const QList info) @@ -87,13 +90,13 @@ void TransitionSettings::updateTrackList() int limit = 1; if (m_usedTransition) limit = m_usedTransition->track() + 1; - kDebug() << "/ / TRANS TRK: " << limit; + //kDebug() << "/ / TRANS TRK: " << limit; KIcon videoIcon("kdenlive-show-video"); KIcon audioIcon("kdenlive-show-audio"); for (int i = limit; i < m_tracks.count(); i++) { int ix = m_tracks.count() - i - 1; transitionTrack->addItem(m_tracks.at(ix).type == VIDEOTRACK ? videoIcon : audioIcon, - m_tracks.at(ix).trackName.isEmpty() ? QString::number(i) : m_tracks.at(ix).trackName + " (" + QString::number(i) + ")", + m_tracks.at(ix).trackName.isEmpty() ? QString::number(i) : m_tracks.at(ix).trackName + " (" + QString::number(i) + ')', m_tracks.count() - i); } transitionTrack->addItem(i18n("Black"), 0); @@ -107,19 +110,35 @@ void TransitionSettings::slotTransitionChanged(bool reinit, bool updateCurrent) QDomElement e = m_usedTransition->toXML().cloneNode().toElement(); if (reinit) { // Reset the transition parameters to the default one + disconnect(m_effectEdit->monitor(), SIGNAL(renderPosition(int)), this, SLOT(slotRenderPos(int))); QDomElement newTransition = MainWindow::transitions.getEffectByName(transitionList->currentText()).cloneNode().toElement(); slotUpdateEffectParams(e, newTransition); m_effectEdit->transferParamDesc(newTransition, m_usedTransition->info(), false); + if (m_effectEdit->needsMonitorEffectScene()) + connect(m_effectEdit->monitor(), SIGNAL(renderPosition(int)), this, SLOT(slotRenderPos(int))); } else if (!updateCurrent) { // Transition changed, update parameters dialog //slotUpdateEffectParams(e, e); m_effectEdit->transferParamDesc(e, m_usedTransition->info(), false); } else { // Same transition, we just want to update the parameters value - slotUpdateEffectParams(e, e); - if (m_usedTransition->hasGeometry()) - m_effectEdit->transferParamDesc(m_usedTransition->toXML(), m_usedTransition->info(), false); + int ix = transitionList->findData(m_usedTransition->transitionInfo(), Qt::UserRole, Qt::MatchExactly); + if (ix != transitionList->currentIndex()) { + // Transition type changed, reload params + transitionList->blockSignals(true); + transitionList->setCurrentIndex(ix); + transitionList->blockSignals(false); + m_effectEdit->transferParamDesc(e, m_usedTransition->info(), false); + } + else { + slotUpdateEffectParams(e, e); + if (m_usedTransition->hasGeometry()) + m_effectEdit->transferParamDesc(m_usedTransition->toXML(), m_usedTransition->info(), false); + } + if (m_effectEdit->needsMonitorEffectScene()) + connect(m_effectEdit->monitor(), SIGNAL(renderPosition(int)), this, SLOT(slotRenderPos(int))); } + slotCheckMonitorPosition(m_effectEdit->monitor()->render->seekFramePosition()); } void TransitionSettings::slotTransitionTrackChanged() @@ -145,7 +164,8 @@ void TransitionSettings::slotTransitionItemSelected(Transition* t, int nextTrack setEnabled(t != NULL); m_effectEdit->setFrameSize(p); m_autoTrackTransition = nextTrack; - if (t == m_usedTransition) { + disconnect(m_effectEdit->monitor(), SIGNAL(renderPosition(int)), this, SLOT(slotRenderPos(int))); + if (t == m_usedTransition) { if (t == NULL) return; if (update) { transitionTrack->blockSignals(true); @@ -179,16 +199,18 @@ void TransitionSettings::slotTransitionItemSelected(Transition* t, int nextTrack slotTransitionChanged(false, false); transitionList->blockSignals(false); } + if (m_effectEdit->needsMonitorEffectScene()) { + connect(m_effectEdit->monitor(), SIGNAL(renderPosition(int)), this, SLOT(slotRenderPos(int))); + } } else { // null transition selected m_usedTransition = NULL; ItemInfo info; m_effectEdit->transferParamDesc(QDomElement(), info, false); } - } -void TransitionSettings::slotUpdateEffectParams(const QDomElement &oldparam, const QDomElement ¶m) +void TransitionSettings::slotUpdateEffectParams(const QDomElement oldparam, const QDomElement param) { if (m_usedTransition) { m_usedTransition->setTransitionParameters(param); @@ -203,13 +225,42 @@ void TransitionSettings::raiseWindow(QWidget* dock) { if (dock && m_usedTransition) dock->raise(); - } void TransitionSettings::slotRenderPos(int pos) { - if (m_usedTransition) + if (m_usedTransition) { m_effectEdit->slotSyncEffectsPos(pos - m_usedTransition->startPos().frames(KdenliveSettings::project_fps())); + if (isEnabled()) slotCheckMonitorPosition(pos); + } +} + +void TransitionSettings::slotSeekTimeline(int pos) +{ + if (m_usedTransition) + emit seekTimeline(m_usedTransition->startPos().frames(KdenliveSettings::project_fps()) + pos); +} + +void TransitionSettings::slotCheckMonitorPosition(int renderPos) +{ + if (!isEnabled()) return; + if (m_effectEdit->needsMonitorEffectScene()) { + if (renderPos >= m_usedTransition->startPos().frames(KdenliveSettings::project_fps()) && renderPos <= m_usedTransition->endPos().frames(KdenliveSettings::project_fps())) { + if (!m_effectEdit->monitor()->effectSceneDisplayed()) { + m_effectEdit->monitor()->slotShowEffectScene(true); + } + } else { + m_effectEdit->monitor()->slotShowEffectScene(false); + } + } + else { + m_effectEdit->monitor()->slotShowEffectScene(false); + } +} + +void TransitionSettings::setKeyframes(const QString data, int maximum) +{ + m_effectEdit->setKeyframes(data, maximum); } #include "transitionsettings.moc"