X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fediteffectcommand.cpp;h=9bbebc748651bf0efb4652c8098db84ab33a8861;hb=7faa196f9b4a7c03dd2442439500efed29e6c53b;hp=5b6a0d80846d571080c4d095b9b5f2c8eca4a4ac;hpb=fafd8661e13df4401f1d28723a0262c6b3226e34;p=kdenlive diff --git a/src/editeffectcommand.cpp b/src/editeffectcommand.cpp index 5b6a0d80..9bbebc74 100644 --- a/src/editeffectcommand.cpp +++ b/src/editeffectcommand.cpp @@ -17,43 +17,55 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * ***************************************************************************/ -#include #include "editeffectcommand.h" +#include "customtrackview.h" + +#include -EditEffectCommand::EditEffectCommand(CustomTrackView *view, const int track, GenTime pos, QDomElement oldeffect, QDomElement effect, bool doIt) - : m_view(view), m_track(track), m_pos(pos), m_oldeffect(oldeffect), m_doIt(doIt) { - m_effect = effect.cloneNode().toElement(); - setText(i18n("Edit effect")); - } +EditEffectCommand::EditEffectCommand(CustomTrackView *view, const int track, GenTime pos, QDomElement oldeffect, QDomElement effect, int stackPos, bool doIt, QUndoCommand *parent) : + QUndoCommand(parent), + m_view(view), + m_track(track), + m_oldeffect(oldeffect), + m_effect(effect), + m_pos(pos), + m_stackPos(stackPos), + m_doIt(doIt) +{ + QString effectName; + QDomNode namenode = effect.elementsByTagName("name").item(0); + if (!namenode.isNull()) effectName = i18n(namenode.toElement().text().toUtf8().data()); + else effectName = i18n("effect"); + setText(i18n("Edit effect %1", effectName)); +} // virtual int EditEffectCommand::id() const { - return 1; + return 1; } // virtual -bool EditEffectCommand::mergeWith ( const QUndoCommand * other ) +bool EditEffectCommand::mergeWith(const QUndoCommand * other) { - if (other->id() != id()) return false; - if (m_track != static_cast(other)->m_track) return false; - if (m_pos != static_cast(other)->m_pos) return false; - m_effect = static_cast(other)->m_effect; - return true; + if (other->id() != id()) return false; + if (m_track != static_cast(other)->m_track) return false; + if (m_pos != static_cast(other)->m_pos) return false; + m_effect = static_cast(other)->m_effect.cloneNode().toElement(); + return true; } -// virtual +// virtual void EditEffectCommand::undo() { -kDebug()<<"---- undoing action"; - m_view->updateEffect(m_track, m_pos, m_oldeffect); + m_view->updateEffect(m_track, m_pos, m_oldeffect, m_stackPos, false); } -// virtual +// virtual void EditEffectCommand::redo() { -kDebug()<<"---- redoing action"; - m_view->updateEffect(m_track, m_pos, m_effect); + m_view->updateEffect(m_track, m_pos, m_effect, m_stackPos, m_doIt); + m_doIt = false; } -#include "editeffectcommand.moc" +