]> git.sesse.net Git - kdenlive/commitdiff
Fix adding effect group from timeline context menu:
authorJean-Baptiste Mardelle <jb@kdenlive.org>
Thu, 12 Apr 2012 15:20:48 +0000 (17:20 +0200)
committerJean-Baptiste Mardelle <jb@kdenlive.org>
Thu, 12 Apr 2012 15:20:48 +0000 (17:20 +0200)
http://kdenlive.org/mantis/view.php?id=2578

src/effectslist.cpp
src/effectslist.h
src/mainwindow.cpp

index af064380b8658094ae91d9756f617254f0a2ad2e..cff4941893ff030fabb476c4d5e01b14afe5ed0c 100644 (file)
@@ -54,6 +54,17 @@ QDomElement EffectsList::getEffectByName(const QString & name) const
     return QDomElement();
 }
 
+
+void EffectsList::initEffect(QDomElement effect) const
+{
+    QDomNodeList params = effect.elementsByTagName("parameter");
+    for (int i = 0; i < params.count(); i++) {
+       QDomElement e = params.item(i).toElement();
+       if (!e.hasAttribute("value"))
+           e.setAttribute("value", e.attribute("default"));
+    }
+}
+
 QDomElement EffectsList::getEffectByTag(const QString & tag, const QString & id) const
 {
     QDomNodeList effects = m_baseElement.childNodes();
@@ -61,22 +72,20 @@ QDomElement EffectsList::getEffectByTag(const QString & tag, const QString & id)
         QDomElement effect =  effects.at(i).toElement();
         if (!id.isEmpty()) {
             if (effect.attribute("id") == id) {
-                QDomNodeList params = effect.elementsByTagName("parameter");
-                for (int i = 0; i < params.count(); i++) {
-                    QDomElement e = params.item(i).toElement();
-                    if (!e.hasAttribute("value"))
-                        e.setAttribute("value", e.attribute("default"));
-                }
+               if (effect.tagName() == "effectgroup") {
+                   // Effect group
+                   QDomNodeList subeffects = effect.elementsByTagName("effect");
+                   for (int j = 0; j < subeffects.count(); j++) {
+                       QDomElement sub = subeffects.at(j).toElement();
+                       initEffect(sub);
+                   }
+               }
+               else initEffect(effect);
                 return effect;
             }
         } else if (!tag.isEmpty()) {
             if (effect.attribute("tag") == tag) {
-                QDomNodeList params = effect.elementsByTagName("parameter");
-                for (int i = 0; i < params.count(); i++) {
-                    QDomElement e = params.item(i).toElement();
-                    if (!e.hasAttribute("value"))
-                        e.setAttribute("value", e.attribute("default"));
-                }
+                initEffect(effect);
                 return effect;
             }
         }
@@ -102,7 +111,7 @@ QStringList EffectsList::effectIdInfo(const int ix) const
     QDomElement effect = m_baseElement.childNodes().at(ix).toElement();
     if (effect.tagName() == "effectgroup") {
        QString groupName = effect.attribute("name");
-       info << groupName << groupName << groupName << QString::number(Kdenlive::groupEffect);
+       info << groupName << groupName << effect.attribute("id") << QString::number(Kdenlive::groupEffect);
     }
     else {
        QDomElement namenode = effect.firstChildElement("name");
index 8a851a79c15270eb77c7f69bb1763b5ac07e8dcf..b0abdc1b27705d17c95142e17299d0a42f673a30 100644 (file)
@@ -96,6 +96,9 @@ public:
 private:
     QDomElement m_baseElement;
     bool m_useIndex;
+    
+    /** @brief Init effect default parameter values. */
+    void initEffect(QDomElement effect) const;
 
 };
 
index b16cafd6d6e4891ba21e71bf38a77abb825b8fb4..409dfaa91aa0bf49157b8cba2eefb78f7c77cb07 100644 (file)
@@ -3082,9 +3082,9 @@ void MainWindow::slotAddVideoEffect(QAction *result)
 
     if (info.isEmpty() || info.size() < 3) return;
     QDomElement effect ;
-    if (info.at(2) == QString::number((int) EFFECT_VIDEO))
+    if (info.last() == QString::number((int) EFFECT_VIDEO))
             effect = videoEffects.getEffectByTag(info.at(0), info.at(1));
-    else if (info.at(2) == QString::number((int) EFFECT_AUDIO))
+    else if (info.last() == QString::number((int) EFFECT_AUDIO))
             effect = audioEffects.getEffectByTag(info.at(0), info.at(1));
     else
             effect = customEffects.getEffectByTag(info.at(0), info.at(1));