/***************************************************************************
- geomeytrval.cpp - description
+ keyframedit.cpp - description
-------------------
begin : 03 Aug 2008
copyright : (C) 2008 by Marco Gittler
#include "keyframeedit.h"
#include "doubleparameterwidget.h"
+#include "positionedit.h"
#include "kdenlivesettings.h"
#include <KDebug>
buttonSeek->setChecked(KdenliveSettings::keyframeseek());
connect(buttonSeek, SIGNAL(toggled(bool)), this, SLOT(slotSetSeeking(bool)));
- buttonKeyframes->setIcon(KIcon("list-add"));
+ buttonKeyframes->setIcon(KIcon("chronometer"));
button_add->setIcon(KIcon("list-add"));
button_add->setToolTip(i18n("Add keyframe"));
button_delete->setIcon(KIcon("list-remove"));
connect(keyframe_list, SIGNAL(itemSelectionChanged()), this, SLOT(slotAdjustKeyframeInfo()));
connect(keyframe_list, SIGNAL(cellChanged(int, int)), this, SLOT(slotGenerateParams(int, int)));
+ m_position = new PositionEdit(i18n("Position"), 0, 0, 1, tc, widgetTable);
+ ((QGridLayout*)widgetTable->layout())->addWidget(m_position, 3, 0, 1, -1);
+
m_showButtons = new QButtonGroup(this);
m_slidersLayout = new QGridLayout(param_sliders);
keyframe_list->setSelectionBehavior(QAbstractItemView::SelectRows);
connect(button_add, SIGNAL(clicked()), this, SLOT(slotAddKeyframe()));
connect(buttonKeyframes, SIGNAL(clicked()), this, SLOT(slotKeyframeMode()));
connect(buttonResetKeyframe, SIGNAL(clicked()), this, SLOT(slotResetKeyframe()));
- connect(keyframe_pos, SIGNAL(valueChanged(int)), this, SLOT(slotAdjustKeyframePos(int)));
+ connect(m_position, SIGNAL(parameterChanged(int)), this, SLOT(slotAdjustKeyframePos(int)));
connect(m_showButtons, SIGNAL(buttonClicked(int)), this, SLOT(slotUpdateVisibleParameter(int)));
//connect(keyframe_list, SIGNAL(itemDoubleClicked(QTreeWidgetItem *, int)), this, SLOT(slotSaveCurrentParam(QTreeWidgetItem *, int)));
- keyframe_pos->setPageStep(1);
if (!keyframe_list->currentItem()) {
keyframe_list->setCurrentCell(0, 0);
keyframe_list->selectRow(0);
keyframe_list->blockSignals(true);
m_params.append(e.cloneNode().toElement());
- QDomNode na = e.firstChildElement("name");
- QString paramName = i18n(na.toElement().text().toUtf8().data());
- QDomNode commentNode = e.firstChildElement("comment");
+ QDomElement na = e.firstChildElement("name");
+ QString paramName = i18n(na.text().toUtf8().data());
+ QDomElement commentElem = e.firstChildElement("comment");
QString comment;
- if (!commentNode.isNull())
- comment = i18n(commentNode.toElement().text().toUtf8().data());
+ if (!commentElem.isNull())
+ comment = i18n(commentElem.text().toUtf8().data());
int columnId = keyframe_list->columnCount();
keyframe_list->insertColumn(columnId);
m_params.at(columnId).attribute("min").toInt(), m_params.at(columnId).attribute("max").toInt(),
m_params.at(columnId).attribute("default").toInt(), comment, m_params.at(columnId).attribute("suffix"), this);
connect(doubleparam, SIGNAL(valueChanged(int)), this, SLOT(slotAdjustKeyframeValue(int)));
- connect(doubleparam, SIGNAL(showComment(const QString&)), this, SIGNAL(showComment(const QString&)));
+ connect(this, SIGNAL(showComments(bool)), doubleparam, SLOT(slotShowComment(bool)));
m_slidersLayout->addWidget(doubleparam, columnId, 0);
QRadioButton *radio = new QRadioButton(this);
+ radio->setToolTip(i18n("Show %1 in timeline").arg(paramName));
m_showButtons->addButton(radio, columnId);
if (e.attribute("intimeline") == "1")
radio->setChecked(true);
- m_slidersLayout->addWidget(radio, columnId, 1);
+
+ QVBoxLayout *radioLayout = new QVBoxLayout;
+ radioLayout->addWidget(radio, 0, Qt::AlignTop);
+ m_slidersLayout->addLayout(radioLayout, columnId, 1);
QStringList frames = e.attribute("keyframes").split(";", QString::SkipEmptyParts);
for (int i = 0; i < frames.count(); i++) {
keyframe_list->setCurrentCell(row, col);
keyframe_list->selectRow(row);
generateAllParams();
- button_delete->setEnabled(keyframe_list->rowCount() > 1);
+
+ bool disable = keyframe_list->rowCount() < 2;
+ button_delete->setEnabled(!disable);
+ disable &= getPos(0) == m_min;
+ widgetTable->setHidden(disable);
+ buttonKeyframes->setHidden(!disable);
}
void KeyframeEdit::slotAddKeyframe()
result = m_min;
}
} else {
- int pos2 = getPos(row - 1);
- result = pos2 + (pos1 - pos2) / 2;
+ if (pos1 < m_max - 1) {
+ // last keyframe selected and it is not at end of clip -> add keyframe at the end
+ result = m_max - 1;
+ newrow++;
+ } else {
+ int pos2 = getPos(row - 1);
+ result = pos2 + (pos1 - pos2) / 2;
+ }
}
keyframe_list->insertRow(newrow);
if (below)
max = getPos(below->row()) - 1;
- keyframe_pos->blockSignals(true);
- keyframe_pos->setRange(min, max);
- keyframe_pos->setValue(getPos(item->row()));
- keyframe_pos->blockSignals(false);
+ m_position->blockSignals(true);
+ m_position->setRange(min, max);
+ m_position->setPosition(getPos(item->row()));
+ m_position->blockSignals(false);
+
for (int col = 0; col < keyframe_list->columnCount(); col++) {
DoubleParameterWidget *doubleparam = static_cast <DoubleParameterWidget*>(m_slidersLayout->itemAtPosition(col, 0)->widget());
if (!doubleparam)
doubleparam->blockSignals(false);
}
if (KdenliveSettings::keyframeseek() && seek)
- emit seekToPos(keyframe_pos->value() - m_min);
+ emit seekToPos(m_position->getPosition() - m_min);
}
void KeyframeEdit::slotAdjustKeyframePos(int value)
continue;
int val = doubleparam->getValue();
QTableWidgetItem *nitem = keyframe_list->item(item->row(), col);
- if (nitem->text().toInt() != val)
+ if (nitem && nitem->text().toInt() != val)
nitem->setText(QString::number(val));
}
//keyframe_list->item(item->row() - 1, item->column());
else
keyframe_list->verticalHeaderItem(row)->setText(m_timecode.getTimecodeFromFrames(pos.toInt()));
}
+
+ m_position->updateTimecodeFormat();
}
void KeyframeEdit::slotKeyframeMode()
return;
}
- slotUpdateVisibleParameter(0, false);
- QRadioButton *radio = static_cast<QRadioButton*>(m_slidersLayout->itemAtPosition(0, 1)->widget());
+ slotUpdateVisibleParameter(0);
+ QRadioButton *radio = static_cast<QRadioButton*>(m_slidersLayout->itemAtPosition(0, 1)->layout()->itemAt(0)->widget());
if (radio)
radio->setChecked(true);
}