X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Feffectslist.cpp;h=696fa44402b9803d6bfa33b59dae4d825ddb2ee9;hb=ec42e400f6e604f682903cfdfb16581cc8b34378;hp=1b400ae64020b3ba5fd0f692ea9cbc9cd50208cb;hpb=1bb5954abb1179a8cd75a3dbffec0911f297357e;p=kdenlive
diff --git a/src/effectslist.cpp b/src/effectslist.cpp
index 1b400ae6..696fa444 100644
--- a/src/effectslist.cpp
+++ b/src/effectslist.cpp
@@ -38,8 +38,8 @@ QDomElement EffectsList::getEffectByName(const QString & name) const
QDomNodeList effects = m_baseElement.childNodes();
for (int i = 0; i < effects.count(); i++) {
QDomElement effect = effects.at(i).toElement();
- QDomNode namenode = effect.elementsByTagName("name").item(0);
- if (!namenode.isNull()) effectName = i18n(namenode.toElement().text().toUtf8().data());
+ QDomElement namenode = effect.firstChildElement("name");
+ if (!namenode.isNull()) effectName = i18n(namenode.text().toUtf8().data());
if (name == effectName) {
QDomNodeList params = effect.elementsByTagName("parameter");
for (int i = 0; i < params.count(); i++) {
@@ -100,8 +100,8 @@ QStringList EffectsList::effectIdInfo(const int ix) const
{
QStringList info;
QDomElement effect = m_baseElement.childNodes().at(ix).toElement();
- QDomNode namenode = effect.elementsByTagName("name").item(0);
- info << i18n(namenode.toElement().text().toUtf8().data()) << effect.attribute("tag") << effect.attribute("id");
+ QDomElement namenode = effect.firstChildElement("name");
+ info << i18n(namenode.text().toUtf8().data()) << effect.attribute("tag") << effect.attribute("id");
return info;
}
@@ -111,8 +111,8 @@ QStringList EffectsList::effectNames()
QDomNodeList effects = m_baseElement.childNodes();
for (int i = 0; i < effects.count(); i++) {
QDomElement effect = effects.at(i).toElement();
- QDomNode namenode = effect.elementsByTagName("name").item(0);
- if (!namenode.isNull()) list.append(i18n(namenode.toElement().text().toUtf8().data()));
+ QDomElement namenode = effect.firstChildElement("name");
+ if (!namenode.isNull()) list.append(i18n(namenode.text().toUtf8().data()));
}
return list;
}
@@ -120,22 +120,30 @@ QStringList EffectsList::effectNames()
QString EffectsList::getInfo(const QString & tag, const QString & id) const
{
QString info;
- QDomElement effect = getEffectByTag(tag, id);
- QDomNode namenode = effect.elementsByTagName("description").item(0);
- if (!namenode.isNull()) info = i18n(namenode.toElement().text().toUtf8().data());
- namenode = effect.elementsByTagName("author").item(0);
- if (!namenode.isNull()) info.append("
" + i18n("Author:") + " " + i18n(namenode.toElement().text().toUtf8().data()));
- return info;
+ return getEffectInfo(getEffectByTag(tag, id));
}
QString EffectsList::getInfoFromIndex(const int ix) const
{
QString info;
- QDomElement effect = m_baseElement.childNodes().at(ix).toElement();
- QDomNode namenode = effect.elementsByTagName("description").item(0);
- if (!namenode.isNull()) info = i18n(namenode.toElement().text().toUtf8().data());
- namenode = effect.elementsByTagName("author").item(0);
- if (!namenode.isNull()) info.append("
" + i18n("Author:") + " " + i18n(namenode.toElement().text().toUtf8().data()));
+ return getEffectInfo(m_baseElement.childNodes().at(ix).toElement());
+}
+
+QString EffectsList::getEffectInfo(const QDomElement effect) const
+{
+ QString info;
+ QDomElement namenode = effect.firstChildElement("description");
+ if (!namenode.isNull())
+ info = i18n(namenode.firstChild().nodeValue().simplified().toUtf8().data());
+
+ namenode = effect.firstChildElement("author");
+ if (!namenode.isNull())
+ info.append("
" + i18n("Author:") + " " + i18n(namenode.text().toUtf8().data()));
+
+ namenode = effect.firstChildElement("version");
+ if (!namenode.isNull())
+ info.append(QString(" (%1)").arg(namenode.text()));
+
return info;
}
@@ -161,7 +169,19 @@ bool EffectsList::hasSimpleKeyFrames(QDomElement effect)
return false;
}
-void EffectsList::clone(const EffectsList original)
+// static
+bool EffectsList::hasGeometryKeyFrames(QDomElement effect)
+{
+ QDomNodeList params = effect.elementsByTagName("parameter");
+ for (int i = 0; i < params.count(); ++i) {
+ QDomElement param = params.item(i).toElement();
+ if (param.attribute("type") == "geometry" && !param.hasAttribute("fixed"))
+ return true;
+ }
+ return false;
+}
+
+void EffectsList::clone(const EffectsList &original)
{
setContent(original.toString());
m_baseElement = documentElement();
@@ -203,6 +223,7 @@ QString EffectsList::parameter(QDomElement effect, const QString &name)
void EffectsList::setProperty(QDomElement effect, const QString &name, const QString &value)
{
QDomNodeList params = effect.elementsByTagName("property");
+ // Update property if it already exists
for (int i = 0; i < params.count(); i++) {
QDomElement e = params.item(i).toElement();
if (e.attribute("name") == name) {
@@ -212,6 +233,20 @@ void EffectsList::setProperty(QDomElement effect, const QString &name, const QSt
}
}
+// static
+void EffectsList::renameProperty(QDomElement effect, const QString &oldName, const QString &newName)
+{
+ QDomNodeList params = effect.elementsByTagName("property");
+ // Update property if it already exists
+ for (int i = 0; i < params.count(); i++) {
+ QDomElement e = params.item(i).toElement();
+ if (e.attribute("name") == oldName) {
+ e.setAttribute("name", newName);
+ break;
+ }
+ }
+}
+
// static
QString EffectsList::property(QDomElement effect, const QString &name)
{
@@ -225,6 +260,19 @@ QString EffectsList::property(QDomElement effect, const QString &name)
return QString();
}
+// static
+void EffectsList::removeProperty(QDomElement effect, const QString &name)
+{
+ QDomNodeList params = effect.elementsByTagName("property");
+ for (int i = 0; i < params.count(); i++) {
+ QDomElement e = params.item(i).toElement();
+ if (e.attribute("name") == name) {
+ effect.removeChild(params.item(i));
+ break;
+ }
+ }
+}
+
void EffectsList::append(QDomElement e)
{
m_baseElement.appendChild(importNode(e, true));
@@ -237,33 +285,34 @@ int EffectsList::count() const
bool EffectsList::isEmpty() const
{
- return m_baseElement.childNodes().count() == 0;
+ return !m_baseElement.hasChildNodes();
}
const QDomElement EffectsList::at(int ix) const
{
QDomNodeList effects = m_baseElement.childNodes();
- if (ix >= effects.count()) return QDomElement();
+ if (ix < 0 || ix >= effects.count()) return QDomElement();
return effects.at(ix).toElement();
}
void EffectsList::removeAt(int ix)
{
QDomNodeList effects = m_baseElement.childNodes();
- if (ix >= effects.count()) return;
+ if (ix < 0 || ix >= effects.count()) return;
m_baseElement.removeChild(effects.at(ix));
}
QDomElement EffectsList::item(int ix)
{
QDomNodeList effects = m_baseElement.childNodes();
- if (ix >= effects.count()) return QDomElement();
+ if (ix < 0 || ix >= effects.count()) return QDomElement();
return effects.at(ix).toElement();
}
void EffectsList::insert(int ix, QDomElement effect)
{
QDomNodeList effects = m_baseElement.childNodes();
+ if (ix < 0) ix = 0;
if (ix >= effects.count()) m_baseElement.appendChild(importNode(effect, true));
else m_baseElement.insertBefore(importNode(effect, true), effects.at(ix));
}
@@ -271,6 +320,7 @@ void EffectsList::insert(int ix, QDomElement effect)
void EffectsList::replace(int ix, QDomElement effect)
{
QDomNodeList effects = m_baseElement.childNodes();
+ if (ix < 0) ix = 0;
if (ix < effects.count()) m_baseElement.removeChild(effects.at(ix));
if (ix == effects.count()) m_baseElement.appendChild(importNode(effect, true));
else m_baseElement.insertBefore(importNode(effect, true), effects.at(ix));