]> git.sesse.net Git - kdenlive/commitdiff
Fix param update when switching between 2 transitions
authorJean-Baptiste Mardelle <jb@kdenlive.org>
Mon, 2 Jun 2008 22:50:58 +0000 (22:50 +0000)
committerJean-Baptiste Mardelle <jb@kdenlive.org>
Mon, 2 Jun 2008 22:50:58 +0000 (22:50 +0000)
svn path=/branches/KDE4/; revision=2222

src/transitionsettings.cpp
src/transitionsettings.h

index 292aab2d00816b30c66c0676d40bf1060062919b..dd4ff9652bd4ae93ef9b3ab752b65788e65e2124 100644 (file)
@@ -37,39 +37,31 @@ TransitionSettings::TransitionSettings(QWidget* parent): QWidget(parent) {
 }
 
 
-void TransitionSettings::slotTransitionChanged() {
-
-    QDomElement e = m_usedTransition->toXML();
-
-    //set old values from e in <ktransition> to desc (like reverse and so )
-    /* QDomElement desc = m_transitions->getEffectByName(ui.listWidget->currentItem()->text());
-     if (m_usedTransition) {
-         m_usedTransition->setTransitionParameters(desc);
-         m_usedTransition->update();
-     }
-     emit transitionUpdated(e, m_usedTransition->toXML());*/
-    /*QDomDocument doc;
-    doc.appendChild(doc.importNode(e, true));
-    kDebug()<<"///////////  TRANSITION CHANGED: "<<doc.toString();
-    kDebug()<<"///////////  TRANSITION CHANGED END...";*/
-
-    if (m_usedTransition && m_usedTransition->transitionName() == ui.listWidget->currentItem()->text() && !e.attribute("tag").isNull()) {
-        slotUpdateEffectParams(e, e);
-    } else
-        slotUpdateEffectParams(e, MainWindow::transitions.getEffectByName(ui.listWidget->currentItem()->text()));
-    emit transferParamDesc(e, 0, 0);
+void TransitionSettings::slotTransitionChanged(bool reinit) {
+    QDomElement e = m_usedTransition->toXML().cloneNode().toElement();
+       if (reinit) {
+               QDomElement newTransition = MainWindow::transitions.getEffectByName(ui.listWidget->currentItem()->text());
+               slotUpdateEffectParams(e, newTransition);
+               emit transferParamDesc(newTransition, 0, 0);
+       }
+       else {
+               //slotUpdateEffectParams(e, e);
+               emit transferParamDesc(e, 0, 0);
+       }
 }
 
 void TransitionSettings::slotTransitionItemSelected(Transition* t) {
     setEnabled(t != NULL);
-    if (t == m_usedTransition) return;
+    if (t == m_usedTransition) {
+               return;
+       }
     m_usedTransition = t;
     if (m_usedTransition) {
         QList<QListWidgetItem*> list = ui.listWidget->findItems(m_usedTransition->transitionName(), Qt::MatchExactly);
         if (list.size() > 0) {
             ui.listWidget->blockSignals(true);
             ui.listWidget->setCurrentItem(list[0]);
-            slotTransitionChanged();
+            slotTransitionChanged(false);
             ui.listWidget->blockSignals(false);
         }
     }
index 3bb93ee83599c4d71d4e49a894683b90f6168f56..d4b7ce24d54d791f8e979a03652e07f3148bc821 100644 (file)
@@ -32,10 +32,12 @@ private:
     Ui::TransitionSettings_UI ui;
     EffectStackEdit *effectEdit;
     Transition* m_usedTransition;
+
 public slots:
     void slotTransitionItemSelected(Transition*);
-    void slotTransitionChanged();
+    void slotTransitionChanged(bool reinit = true);
     void slotUpdateEffectParams(const QDomElement&, const QDomElement&);
+
 signals:
     void transitionUpdated(Transition *, QDomElement);
     void transferParamDesc(const QDomElement&, int , int);