#include <QDialog>
#include <QMenu>
#include <QVBoxLayout>
+
#include <KDebug>
#include <KGlobalSettings>
#include <KLocale>
#include <KStandardDirs>
#include <KFileDialog>
#include <KUrlRequester>
+#include <KColorScheme>
+#include <KColorUtils>
class Boolval: public QWidget, public Ui::Boolval_UI
{
setFocusPolicy(Qt::StrongFocus);
}
-void MySpinBox::focusInEvent(QFocusEvent*)
+void MySpinBox::focusInEvent(QFocusEvent *e)
{
setFocusPolicy(Qt::WheelFocus);
+ e->accept();
}
-void MySpinBox::focusOutEvent(QFocusEvent*)
+void MySpinBox::focusOutEvent(QFocusEvent *e)
{
setFocusPolicy(Qt::StrongFocus);
+ e->accept();
}
-CollapsibleEffect::CollapsibleEffect(QDomElement effect, QDomElement original_effect, ItemInfo info, int ix, EffectMetaInfo *metaInfo, bool lastEffect, QWidget * parent) :
- QWidget(parent),
+CollapsibleEffect::CollapsibleEffect(QDomElement effect, QDomElement original_effect, ItemInfo info, EffectMetaInfo *metaInfo, bool lastEffect, QWidget * parent) :
+ AbstractCollapsibleWidget(parent),
m_paramWidget(NULL),
m_effect(effect),
m_original_effect(original_effect),
- m_lastEffect(lastEffect),
- m_active(false)
+ m_lastEffect(lastEffect)
{
- //setMouseTracking(true);
setupUi(this);
- frame->setBackgroundRole(QPalette::Midlight);
- frame->setAutoFillBackground(true);
+ filterWheelEvent = true;
+ m_info.fromString(effect.attribute("kdenlive_info"));
setFont(KGlobalSettings::smallestReadableFont());
-
- buttonUp->setIcon(KIcon("go-up"));
+ buttonUp->setIcon(KIcon("kdenlive-up"));
buttonUp->setToolTip(i18n("Move effect up"));
if (!lastEffect) {
- buttonDown->setIcon(KIcon("go-down"));
+ buttonDown->setIcon(KIcon("kdenlive-down"));
buttonDown->setToolTip(i18n("Move effect down"));
}
- buttonDel->setIcon(KIcon("edit-delete"));
+ buttonDel->setIcon(KIcon("kdenlive-deleffect"));
buttonDel->setToolTip(i18n("Delete effect"));
-
- buttonUp->setVisible(false);
- buttonDown->setVisible(false);
- buttonDel->setVisible(false);
+ if (effectIndex() == 1) buttonUp->setVisible(false);
+ if (m_lastEffect) buttonDown->setVisible(false);
+ //buttonUp->setVisible(false);
+ //buttonDown->setVisible(false);
/*buttonReset->setIcon(KIcon("view-refresh"));
buttonReset->setToolTip(i18n("Reset effect"));*/
//checkAll->setToolTip(i18n("Enable/Disable all effects"));
//buttonShowComments->setIcon(KIcon("help-about"));
//buttonShowComments->setToolTip(i18n("Show additional information for the parameters"));
+ m_menu = new QMenu;
+ m_menu->addAction(KIcon("view-refresh"), i18n("Reset Effect"), this, SLOT(slotResetEffect()));
+ m_menu->addAction(KIcon("document-save"), i18n("Save Effect"), this, SLOT(slotSaveEffect()));
+
QDomElement namenode = m_effect.firstChildElement("name");
if (namenode.isNull()) return;
title->setText(i18n(namenode.text().toUtf8().data()));
+ /*
+ * Do not show icon, makes too much visual noise
QString type = m_effect.attribute("type", QString());
KIcon icon;
if (type == "audio") icon = KIcon("kdenlive-show-audio");
else if (m_effect.attribute("tag") == "region") icon = KIcon("kdenlive-mask-effect");
else if (type == "custom") icon = KIcon("kdenlive-custom-effect");
else icon = KIcon("kdenlive-show-video");
- title->setIcon(icon);
-
- m_menu = new QMenu;
- m_menu->addAction(KIcon("view-refresh"), i18n("Reset effect"), this, SLOT(slotResetEffect()));
- m_menu->addAction(KIcon("document-save"), i18n("Save effect"), this, SLOT(slotSaveEffect()));
- title->setMenu(m_menu);
+ effecticon->setPixmap(icon.pixmap(16,16));*/
+
+ m_menu->addAction(KIcon("folder-new"), i18n("Create Group"), this, SLOT(slotCreateGroup()));
+ setupWidget(info, metaInfo);
+ setAcceptDrops(true);
+ menuButton->setIcon(KIcon("kdenlive-menu"));
+ menuButton->setMenu(m_menu);
if (m_effect.attribute("disable") == "1") {
- enabledBox->setCheckState(Qt::Unchecked);
title->setEnabled(false);
+ enabledButton->setChecked(true);
+ enabledButton->setIcon(KIcon("novisible"));
}
else {
- enabledBox->setCheckState(Qt::Checked);
+ enabledButton->setChecked(false);
+ enabledButton->setIcon(KIcon("visible"));
}
connect(collapseButton, SIGNAL(clicked()), this, SLOT(slotSwitch()));
- connect(enabledBox, SIGNAL(toggled(bool)), this, SLOT(slotEnable(bool)));
+ connect(enabledButton, SIGNAL(toggled(bool)), this, SLOT(slotEnable(bool)));
connect(buttonUp, SIGNAL(clicked()), this, SLOT(slotEffectUp()));
connect(buttonDown, SIGNAL(clicked()), this, SLOT(slotEffectDown()));
connect(buttonDel, SIGNAL(clicked()), this, SLOT(slotDeleteEffect()));
- setupWidget(info, ix, metaInfo);
Q_FOREACH( QSpinBox * sp, findChildren<QSpinBox*>() ) {
sp->installEventFilter( this );
sp->setFocusPolicy( Qt::StrongFocus );
delete m_menu;
}
+//static
+const QString CollapsibleEffect::getStyleSheet()
+{
+ KColorScheme scheme(QApplication::palette().currentColorGroup(), KColorScheme::View, KSharedConfig::openConfig(KdenliveSettings::colortheme()));
+ QColor selected_bg = scheme.decoration(KColorScheme::FocusColor).color();
+ QColor hgh = KColorUtils::mix(QApplication::palette().window().color(), selected_bg, 0.2);
+ QColor hover_bg = scheme.decoration(KColorScheme::HoverColor).color();
+ QColor light_bg = scheme.shade(KColorScheme::LightShade);
+ QColor alt_bg = scheme.background(KColorScheme::NormalBackground).color();
+
+ QString stylesheet;
+
+ // group editable labels
+ stylesheet.append(QString("MyEditableLabel { background-color: transparent;color: palette(bright-text);} "));
+
+ // effect background
+ stylesheet.append(QString("QFrame#decoframe {border-top-left-radius:5px;border-top-right-radius:5px;border-bottom:2px solid palette(mid);border-top:1px solid palette(light);} QFrame#decoframe[active=\"true\"] {background: %1;}").arg(hgh.name()));
+
+ // effect in group background
+ stylesheet.append(QString("QFrame#decoframesub {border-top:1px solid palette(light);} QFrame#decoframesub[active=\"true\"] {background: %1;}").arg(hgh.name()));
+
+ // group background
+ stylesheet.append(QString("QFrame#decoframegroup {border-top-left-radius:5px;border-top-right-radius:5px;border:2px solid palette(dark);margin:0px;margin-top:2px;} "));
+
+ // effect title bar
+ stylesheet.append(QString("QFrame#frame {margin-bottom:2px;border-top-left-radius:5px;border-top-right-radius:5px;} QFrame#frame[target=\"true\"] {background: palette(highlight);}"));
+
+ // group effect title bar
+ stylesheet.append(QString("QFrame#framegroup {border-top-left-radius:2px;border-top-right-radius:2px;background: palette(dark);} QFrame#framegroup[target=\"true\"] {background: palette(highlight);} "));
+
+ // draggable effect bar content
+ stylesheet.append(QString("QProgressBar::chunk:horizontal {background: palette(button);border-top-left-radius: 4px;border-bottom-left-radius: 4px;} QProgressBar::chunk:horizontal#dragOnly {background: %1;border-top-left-radius: 4px;border-bottom-left-radius: 4px;} QProgressBar::chunk:horizontal:hover {background: %2;}").arg(alt_bg.name()).arg(selected_bg.name()));
+
+ // draggable effect bar
+ stylesheet.append(QString("QProgressBar:horizontal {border: 1px solid palette(dark);border-top-left-radius: 4px;border-bottom-left-radius: 4px;border-right:0px;background:%3;padding: 0px;text-align:left center} QProgressBar:horizontal:disabled {border: 1px solid palette(button)} QProgressBar:horizontal#dragOnly {background: %3} QProgressBar:horizontal[inTimeline=\"true\"] { border: 1px solid %1;border-right: 0px;background: %2;padding: 0px;text-align:left center } QProgressBar::chunk:horizontal[inTimeline=\"true\"] {background: %1;}").arg(hover_bg.name()).arg(light_bg.name()).arg(alt_bg.name()));
+
+ // spin box for draggable widget
+ stylesheet.append(QString("QAbstractSpinBox#dragBox {border: 1px solid palette(dark);border-top-right-radius: 4px;border-bottom-right-radius: 4px;padding-right:0px;} QAbstractSpinBox::down-button#dragBox {width:0px;padding:0px;} QAbstractSpinBox:disabled#dragBox {border: 1px solid palette(button);} QAbstractSpinBox::up-button#dragBox {width:0px;padding:0px;} QAbstractSpinBox[inTimeline=\"true\"]#dragBox { border: 1px solid %1;} QAbstractSpinBox:hover#dragBox {border: 1px solid %2;} ").arg(hover_bg.name()).arg(selected_bg.name()));
+
+ return stylesheet;
+}
+
+void CollapsibleEffect::slotCreateGroup()
+{
+ emit createGroup(effectIndex());
+}
+
+void CollapsibleEffect::slotUnGroup()
+{
+ emit unGroup(this);
+}
+
bool CollapsibleEffect::eventFilter( QObject * o, QEvent * e )
{
+ if (e->type() == QEvent::Enter) {
+ frame->setProperty("mouseover", true);
+ frame->setStyleSheet(frame->styleSheet());
+ return QWidget::eventFilter(o, e);
+ }
if (e->type() == QEvent::Wheel) {
QWheelEvent *we = static_cast<QWheelEvent *>(e);
- if (we->modifiers() != Qt::NoModifier) {
+ if (!filterWheelEvent || we->modifiers() != Qt::NoModifier) {
e->accept();
return false;
}
return m_effect;
}
-void CollapsibleEffect::setActive(bool activate)
+bool CollapsibleEffect::isActive() const
{
- m_active = activate;
- frame->setBackgroundRole(m_active ? QPalette::Mid : QPalette::Midlight);
- frame->setAutoFillBackground(activate);
+ return decoframe->property("active").toBool();
}
-void CollapsibleEffect::mouseDoubleClickEvent ( QMouseEvent * event )
-{
- if (frame->underMouse() && collapseButton->isEnabled()) slotSwitch();
- QWidget::mouseDoubleClickEvent(event);
-}
-
-void CollapsibleEffect::mousePressEvent ( QMouseEvent *event )
+void CollapsibleEffect::setActive(bool activate)
{
- if (!m_active) emit activateEffect(m_paramWidget->index());
- QWidget::mousePressEvent(event);
+ decoframe->setProperty("active", activate);
+ decoframe->setStyleSheet(decoframe->styleSheet());
}
-void CollapsibleEffect::enterEvent ( QEvent * event )
+void CollapsibleEffect::mouseDoubleClickEvent ( QMouseEvent * event )
{
- if (m_paramWidget->index() > 0) buttonUp->setVisible(true);
- if (!m_lastEffect) buttonDown->setVisible(true);
- buttonDel->setVisible(true);
- if (!m_active) frame->setBackgroundRole(QPalette::Midlight);
- frame->setAutoFillBackground(true);
- QWidget::enterEvent(event);
+ if (frame->underMouse() && collapseButton->isEnabled()) {
+ event->accept();
+ slotSwitch();
+ }
+ else event->ignore();
}
-void CollapsibleEffect::leaveEvent ( QEvent * event )
+void CollapsibleEffect::mouseReleaseEvent( QMouseEvent *event )
{
- buttonUp->setVisible(false);
- buttonDown->setVisible(false);
- buttonDel->setVisible(false);
- if (!m_active) frame->setAutoFillBackground(false);
- QWidget::leaveEvent(event);
+ if (!decoframe->property("active").toBool()) emit activateEffect(effectIndex());
+ QWidget::mouseReleaseEvent(event);
}
-void CollapsibleEffect::slotEnable(bool enable)
+void CollapsibleEffect::slotEnable(bool disable, bool updateMainStatus)
{
- title->setEnabled(enable);
- m_effect.setAttribute("disable", enable ? 0 : 1);
- if (enable || KdenliveSettings::disable_effect_parameters()) {
- widgetFrame->setEnabled(enable);
+ title->setEnabled(!disable);
+ enabledButton->blockSignals(true);
+ enabledButton->setChecked(disable);
+ enabledButton->blockSignals(false);
+ enabledButton->setIcon(disable ? KIcon("novisible") : KIcon("visible"));
+ m_effect.setAttribute("disable", disable ? 1 : 0);
+ if (!disable || KdenliveSettings::disable_effect_parameters()) {
+ widgetFrame->setEnabled(!disable);
}
- emit effectStateChanged(!enable, m_paramWidget->index());
+ emit effectStateChanged(disable, effectIndex(), updateMainStatus);
}
void CollapsibleEffect::slotDeleteEffect()
{
- emit deleteEffect(m_effect, m_paramWidget->index());
+ emit deleteEffect(m_effect);
}
void CollapsibleEffect::slotEffectUp()
{
- emit changeEffectPosition(m_paramWidget->index(), true);
+ emit changeEffectPosition(effectIndex(), true);
}
void CollapsibleEffect::slotEffectDown()
{
- emit changeEffectPosition(m_paramWidget->index(), false);
+ emit changeEffectPosition(effectIndex(), false);
}
void CollapsibleEffect::slotSaveEffect()
void CollapsibleEffect::slotResetEffect()
{
- emit resetEffect(m_paramWidget->index());
+ emit resetEffect(effectIndex());
}
void CollapsibleEffect::slotSwitch()
widgetFrame->setVisible(show);
if (show) {
collapseButton->setArrowType(Qt::DownArrow);
- m_original_effect.removeAttribute("k_collapsed");
+ m_info.isCollapsed = false;
}
else {
collapseButton->setArrowType(Qt::RightArrow);
- m_original_effect.setAttribute("k_collapsed", 1);
+ m_info.isCollapsed = true;
}
+ m_effect.setAttribute("kdenlive_info", m_info.toString());
+ emit parameterChanged(m_original_effect, m_effect, effectIndex());
+}
+
+void CollapsibleEffect::setGroupIndex(int ix)
+{
+ m_info.groupIndex = ix;
+}
+
+void CollapsibleEffect::setGroupName(const QString &groupName)
+{
+ m_info.groupName = groupName;
+}
+
+QString CollapsibleEffect::infoString() const
+{
+ return m_info.toString();
+}
+
+void CollapsibleEffect::removeFromGroup()
+{
+ m_info.groupIndex = -1;
+ m_info.groupName.clear();
+ m_effect.setAttribute("kdenlive_info", m_info.toString());
+ emit parameterChanged(m_original_effect, m_effect, effectIndex());
}
-void CollapsibleEffect::updateWidget(ItemInfo info, int index, QDomElement effect, EffectMetaInfo *metaInfo)
+int CollapsibleEffect::groupIndex() const
+{
+ return m_info.groupIndex;
+}
+
+int CollapsibleEffect::effectIndex() const
+{
+ if (m_effect.isNull()) return -1;
+ return m_effect.attribute("kdenlive_ix").toInt();
+}
+
+void CollapsibleEffect::updateWidget(ItemInfo info, QDomElement effect, EffectMetaInfo *metaInfo)
{
if (m_paramWidget) {
- // cleanup
- delete m_paramWidget;
- m_paramWidget = NULL;
+ // cleanup
+ delete m_paramWidget;
+ m_paramWidget = NULL;
}
m_effect = effect;
- setupWidget(info, index, metaInfo);
+ setupWidget(info, metaInfo);
}
-void CollapsibleEffect::setupWidget(ItemInfo info, int index, EffectMetaInfo *metaInfo)
+void CollapsibleEffect::setupWidget(ItemInfo info, EffectMetaInfo *metaInfo)
{
if (m_effect.isNull()) {
// kDebug() << "// EMPTY EFFECT STACK";
if (m_effect.attribute("tag") == "region") {
QVBoxLayout *vbox = new QVBoxLayout(widgetFrame);
vbox->setContentsMargins(0, 0, 0, 0);
- vbox->setSpacing(2);
+ vbox->setSpacing(2);
QDomNodeList effects = m_effect.elementsByTagName("effect");
- QDomNodeList origin_effects = m_original_effect.elementsByTagName("effect");
+ QDomNodeList origin_effects = m_original_effect.elementsByTagName("effect");
QWidget *container = new QWidget(widgetFrame);
vbox->addWidget(container);
- m_paramWidget = new ParameterContainer(m_effect.toElement(), info, metaInfo, index, container);
+ m_paramWidget = new ParameterContainer(m_effect.toElement(), info, metaInfo, container);
for (int i = 0; i < effects.count(); i++) {
- CollapsibleEffect *coll = new CollapsibleEffect(effects.at(i).toElement(), origin_effects.at(i).toElement(), info, i, metaInfo, container);
+ CollapsibleEffect *coll = new CollapsibleEffect(effects.at(i).toElement(), origin_effects.at(i).toElement(), info, metaInfo, container);
m_subParamWidgets.append(coll);
//container = new QWidget(widgetFrame);
vbox->addWidget(coll);
}
else {
- m_paramWidget = new ParameterContainer(m_effect, info, metaInfo, index, widgetFrame);
+ m_paramWidget = new ParameterContainer(m_effect, info, metaInfo, widgetFrame);
if (m_effect.firstChildElement("parameter").isNull()) {
// Effect has no parameter, don't allow expand
collapseButton->setEnabled(false);
+ collapseButton->setVisible(false);
widgetFrame->setVisible(false);
}
}
- if (collapseButton->isEnabled()) slotShow(!m_effect.hasAttribute("k_collapsed"));
+ if (collapseButton->isEnabled() && m_info.isCollapsed) {
+ widgetFrame->setVisible(false);
+ collapseButton->setArrowType(Qt::RightArrow);
+
+ }
connect (m_paramWidget, SIGNAL(parameterChanged(const QDomElement, const QDomElement, int)), this, SIGNAL(parameterChanged(const QDomElement, const QDomElement, int)));
connect(m_paramWidget, SIGNAL(startFilterJob(QString,QString,QString,QString,QString,QString)), this, SIGNAL(startFilterJob(QString,QString,QString,QString,QString,QString)));
}
+bool CollapsibleEffect::isGroup() const
+{
+ return false;
+}
+
void CollapsibleEffect::updateTimecodeFormat()
{
m_paramWidget->updateTimecodeFormat();
emit syncEffectsPos(pos);
}
+void CollapsibleEffect::dragEnterEvent(QDragEnterEvent *event)
+{
+ if (event->mimeData()->hasFormat("kdenlive/effectslist")) {
+ frame->setProperty("target", true);
+ frame->setStyleSheet(frame->styleSheet());
+ event->acceptProposedAction();
+ }
+}
+void CollapsibleEffect::dragLeaveEvent(QDragLeaveEvent */*event*/)
+{
+ frame->setProperty("target", false);
+ frame->setStyleSheet(frame->styleSheet());
+}
-ParameterContainer::ParameterContainer(QDomElement effect, ItemInfo info, EffectMetaInfo *metaInfo, int index, QWidget * parent) :
- m_index(index),
+void CollapsibleEffect::dropEvent(QDropEvent *event)
+{
+ frame->setProperty("target", false);
+ frame->setStyleSheet(frame->styleSheet());
+ const QString effects = QString::fromUtf8(event->mimeData()->data("kdenlive/effectslist"));
+ //event->acceptProposedAction();
+ QDomDocument doc;
+ doc.setContent(effects, true);
+ QDomElement e = doc.documentElement();
+ int ix = e.attribute("kdenlive_ix").toInt();
+ if (ix == effectIndex()) {
+ // effect dropped on itself, reject
+ event->ignore();
+ return;
+ }
+ if (ix == 0) {
+ // effect dropped from effects list, add it
+ e.setAttribute("kdenlive_ix", ix);
+ event->setDropAction(Qt::CopyAction);
+ event->accept();
+ emit addEffect(e);
+ return;
+ }
+ emit moveEffect(ix, effectIndex(), m_info.groupIndex, m_info.groupName);
+ event->setDropAction(Qt::MoveAction);
+ event->accept();
+}
+
+ParameterContainer::ParameterContainer(QDomElement effect, ItemInfo info, EffectMetaInfo *metaInfo, QWidget * parent) :
m_keyframeEditor(NULL),
m_geometryWidget(NULL),
m_metaInfo(metaInfo),
bool stretch = true;
m_vbox = new QVBoxLayout(parent);
- m_vbox->setContentsMargins(0, 0, 0, 0);
+ m_vbox->setContentsMargins(4, 0, 4, 0);
m_vbox->setSpacing(2);
for (int i = 0; i < namenode.count() ; i++) {
m_keyframeEditor->addParameter(pa);
}
} else if (type == "color") {
+ if (pa.hasAttribute("paramprefix")) value.remove(0, pa.attribute("paramprefix").size());
if (value.startsWith('#'))
value = value.replace('#', "0x");
ChooseColorWidget *choosecolor = new ChooseColorWidget(paramName, value, parent);
+ choosecolor->setAlphaChannelEnabled(true);
m_vbox->addWidget(choosecolor);
m_valueItems[paramName] = choosecolor;
connect(choosecolor, SIGNAL(displayMessage(const QString&, int)), this, SIGNAL(displayMessage(const QString&, int)));
KisCurveWidget *curve = new KisCurveWidget(parent);
curve->setMaxPoints(pa.attribute("max").toInt());
QList<QPointF> points;
- int number = EffectsList::parameter(e, pa.attribute("number")).toInt();
+ int number;
+ if (e.attribute("version").toDouble() > 0.2) {
+ // Rounding gives really weird results. (int) (10 * 0.3) gives 2! So for now, add 0.5 to get correct result
+ number = EffectsList::parameter(e, pa.attribute("number")).toDouble() * 10 + 0.5;
+ } else {
+ number = EffectsList::parameter(e, pa.attribute("number")).toInt();
+ }
QString inName = pa.attribute("inpoints");
QString outName = pa.attribute("outpoints");
int start = pa.attribute("min").toInt();
ParameterContainer::~ParameterContainer()
{
- //clearLayout(m_vbox);
+ clearLayout(m_vbox);
delete m_vbox;
}
} else if (type == "bezier_spline") {
BezierSplineWidget *widget = (BezierSplineWidget*)m_valueItems[name];
if (widget) {
- widget->setMode((BezierSplineWidget::CurveModes)((int)(value.toDouble() * 10)));
+ widget->setMode((BezierSplineWidget::CurveModes)((int)(value.toDouble() * 10 + 0.5)));
}
}
}
QDomNodeList namenode = m_effect.elementsByTagName("parameter");
for (int i = 0; i < namenode.count() ; i++) {
- QDomNode pa = namenode.item(i);
+ QDomElement pa = namenode.item(i).toElement();
QDomElement na = pa.firstChildElement("name");
- QString type = pa.attributes().namedItem("type").nodeValue();
- QString paramName = na.isNull() ? pa.attributes().namedItem("name").nodeValue() : i18n(na.text().toUtf8().data());
+ QString type = pa.attribute("type");
+ QString paramName = na.isNull() ? pa.attribute("name") : i18n(na.text().toUtf8().data());
if (type == "complex")
paramName.append("complex");
else if (type == "position")
} else if (type == "color") {
ChooseColorWidget *choosecolor = ((ChooseColorWidget*)m_valueItems.value(paramName));
setValue = choosecolor->getColor();
+ if (pa.hasAttribute("paramprefix")) setValue.prepend(pa.attribute("paramprefix"));
} else if (type == "complex") {
ComplexParameter *complex = ((ComplexParameter*)m_valueItems.value(paramName));
namenode.item(i) = complex->getParamDesc();
} else if (type == "curve") {
KisCurveWidget *curve = ((KisCurveWidget*)m_valueItems.value(paramName));
QList<QPointF> points = curve->curve().points();
- QString number = pa.attributes().namedItem("number").nodeValue();
- QString inName = pa.attributes().namedItem("inpoints").nodeValue();
- QString outName = pa.attributes().namedItem("outpoints").nodeValue();
- int off = pa.attributes().namedItem("min").nodeValue().toInt();
- int end = pa.attributes().namedItem("max").nodeValue().toInt();
- EffectsList::setParameter(m_effect, number, QString::number(points.count()));
+ QString number = pa.attribute("number");
+ QString inName = pa.attribute("inpoints");
+ QString outName = pa.attribute("outpoints");
+ int off = pa.attribute("min").toInt();
+ int end = pa.attribute("max").toInt();
+ if (oldparam.attribute("version").toDouble() > 0.2) {
+ EffectsList::setParameter(m_effect, number, locale.toString(points.count() / 10.));
+ } else {
+ EffectsList::setParameter(m_effect, number, QString::number(points.count()));
+ }
for (int j = 0; (j < points.count() && j + off <= end); j++) {
QString in = inName;
in.replace("%i", QString::number(j + off));
EffectsList::setParameter(m_effect, in, locale.toString(points.at(j).x()));
EffectsList::setParameter(m_effect, out, locale.toString(points.at(j).y()));
}
- QString depends = pa.attributes().namedItem("depends").nodeValue();
+ QString depends = pa.attribute("depends");
if (!depends.isEmpty())
meetDependency(paramName, type, EffectsList::parameter(m_effect, depends));
} else if (type == "bezier_spline") {
BezierSplineWidget *widget = (BezierSplineWidget*)m_valueItems.value(paramName);
setValue = widget->spline();
- QString depends = pa.attributes().namedItem("depends").nodeValue();
+ QString depends = pa.attribute("depends");
if (!depends.isEmpty())
meetDependency(paramName, type, EffectsList::parameter(m_effect, depends));
#ifdef USE_QJSON
setValue = getWipeString(info);
} else if ((type == "simplekeyframe" || type == "keyframe") && m_keyframeEditor) {
- QDomElement elem = pa.toElement();
QString realName = i18n(na.toElement().text().toUtf8().data());
QString val = m_keyframeEditor->getValue(realName);
- elem.setAttribute("keyframes", val);
+ pa.setAttribute("keyframes", val);
- if (m_keyframeEditor->isVisibleParam(realName))
- elem.setAttribute("intimeline", "1");
- else if (elem.hasAttribute("intimeline"))
- elem.removeAttribute("intimeline");
+ if (m_keyframeEditor->isVisibleParam(realName)) {
+ pa.setAttribute("intimeline", "1");
+ }
+ else if (pa.hasAttribute("intimeline"))
+ pa.removeAttribute("intimeline");
} else if (type == "url") {
KUrlRequester *req = ((Urlval*)m_valueItems.value(paramName))->urlwidget;
setValue = req->url().path();
setValue = fontfamily->currentFont().family();
}
if (!setValue.isNull())
- pa.attributes().namedItem("value").setNodeValue(setValue);
+ pa.setAttribute("value", setValue);
}
- emit parameterChanged(oldparam, m_effect, m_index);
+ kDebug()<<"// PARAM STK CHANGED";
+ emit parameterChanged(oldparam, m_effect, m_effect.attribute("kdenlive_ix").toInt());
}
QString ParameterContainer::getWipeString(wipeInfo info)
return QString(start + ";-1=" + end);
}
-int ParameterContainer::index()
-{
- return m_index;
-}
-
void ParameterContainer::slotStartFilterJobAction()
{
QDomNodeList namenode = m_effect.elementsByTagName("parameter");