}
}
- painter->setClipRect(option->exposedRect);
QPen pen = painter->pen();
- pen.setColor(Qt::red);
- pen.setStyle(Qt::DashDotDotLine); //Qt::DotLine);
-
+ pen.setColor(Qt::white);
+ //pen.setStyle(Qt::DashDotDotLine); //Qt::DotLine);
// Draw clip name
+ QString effects = effectNames().join(" / ");
+ if (!effects.isEmpty()) {
+ painter->setPen(pen);
+ QFont font = painter->font();
+ QFont smallFont = font;
+ smallFont.setPointSize(8);
+ painter->setFont(smallFont);
+ QRectF txtBounding = painter->boundingRect(br, Qt::AlignLeft | Qt::AlignTop, " " + effects + " ");
+ painter->fillRect(txtBounding, QBrush(QColor(0,0,0,150)));
+ painter->drawText(txtBounding, Qt::AlignCenter, effects);
+ pen.setColor(Qt::black);
+ painter->setPen(pen);
+ painter->setFont(font);
+ }
+
QRectF txtBounding = painter->boundingRect(br, Qt::AlignCenter, " " + m_clipName + " ");
painter->fillRect(txtBounding, QBrush(QColor(255,255,255,150)));
painter->drawText(txtBounding, Qt::AlignCenter, m_clipName);
+ pen.setColor(Qt::red);
+ pen.setStyle(Qt::DashDotDotLine); //Qt::DotLine);
if (isSelected()) painter->setPen(pen);
+ painter->setClipRect(option->exposedRect);
painter->drawPath(roundRectPath);
//painter->fillRect(QRect(br.x(), br.y(), roundingX, roundingY), QBrush(QColor(Qt::green)));
m_track = track;
}
+QStringList ClipItem::effectNames()
+{
+ QStringList result;
+ for (int i = 0; i < m_effectList.size(); ++i) {
+ result.append(m_effectList.at(i).value("name"));
+ }
+ kDebug()<<"/// EFFECT LIST FOR CLIP IS: "<<result;
+ return result;
+}
+
+void ClipItem::addEffect(QMap <QString, QString> args)
+{
+ m_effectList.append(args);
+ update(boundingRect());
+}
+
+void ClipItem::deleteEffect(QString tag)
+{
+ for (int i = 0; i < m_effectList.size(); ++i) {
+ if (m_effectList.at(i).value("mlt_service") == tag) {
+ m_effectList.removeAt(i);
+ break;
+ }
+ }
+ update(boundingRect());
+}
+
// virtual
/*
void CustomTrackView::addEffect(int track, GenTime pos, QString tag, QMap <QString, QString> args)
{
- m_document->renderer()->mltAddEffect(track, pos, tag, args);
+ m_document->renderer()->mltAddEffect(track, pos, tag, args);
+ ClipItem *clip = getClipItemAt(pos.frames(m_document->fps()) + 1, m_tracksCount - track);
+ if (clip) clip->addEffect(args);
}
void CustomTrackView::deleteEffect(int track, GenTime pos, QString tag)
{
m_document->renderer()->mltRemoveEffect(track, pos, tag, -1);
+ ClipItem *clip = getClipItemAt(pos.frames(m_document->fps()) + 1, m_tracksCount - track);
+ if (clip) clip->deleteEffect(tag);
}
void CustomTrackView::slotAddEffect(QMap <QString, QString> filter)
if (itemList.at(i)->type() == 70000 && itemList.at(i)->isSelected()) {
ClipItem *item = (ClipItem *)itemList.at(i);
QString tag = filter.value("mlt_service");
- AddEffectCommand *command = new AddEffectCommand(this, m_tracksCount - item->track(),GenTime(item->startPos(), 25), tag, filter, true);
+ AddEffectCommand *command = new AddEffectCommand(this, m_tracksCount - item->track(),GenTime(item->startPos(), m_document->fps()), tag, filter, true);
m_commandStack->push(command);
}
}
m_dropItem->baseClip()->addReference();
m_document->updateClip(m_dropItem->baseClip()->getId());
kDebug()<<"IIIIIIIIIIIIIIIIIIIIIIII TRAX CNT: "<<m_tracksCount<<", DROP: "<<m_dropItem->track();
- m_document->renderer()->mltInsertClip(m_tracksCount - m_dropItem->track(), GenTime(m_dropItem->startPos(), 25), m_dropItem->xml());
+ m_document->renderer()->mltInsertClip(m_tracksCount - m_dropItem->track(), GenTime(m_dropItem->startPos(), m_document->fps()), m_dropItem->xml());
}
m_dropItem = NULL;
}
m_cursorPos = pos;
m_cursorLine->setPos(pos, 0);
int frame = mapToScene(QPoint(pos, 0)).x() / m_scale;
- if (seek) m_document->renderer()->seek(GenTime(frame, 25));
+ if (seek) m_document->renderer()->seek(GenTime(frame, m_document->fps()));
}
int CustomTrackView::cursorPos()
// resize start
ResizeClipCommand *command = new ResizeClipCommand(this, m_startPos, QPointF(m_dragItem->startPos(), m_dragItem->track()), true, false);
- m_document->renderer()->mltResizeClipStart(m_tracksCount - m_dragItem->track(), GenTime(m_dragItem->endPos(), 25), GenTime(m_dragItem->startPos(), 25), GenTime(m_startPos.x(), 25), GenTime(m_dragItem->cropStart(), 25), GenTime(m_dragItem->cropStart(), 25) + GenTime(m_dragItem->endPos(), 25) - GenTime(m_dragItem->startPos(), 25));
+ m_document->renderer()->mltResizeClipStart(m_tracksCount - m_dragItem->track(), GenTime(m_dragItem->endPos(), m_document->fps()), GenTime(m_dragItem->startPos(), m_document->fps()), GenTime(m_startPos.x(), m_document->fps()), GenTime(m_dragItem->cropStart(), m_document->fps()), GenTime(m_dragItem->cropStart(), m_document->fps()) + GenTime(m_dragItem->endPos(), m_document->fps()) - GenTime(m_dragItem->startPos(), m_document->fps()));
m_commandStack->push(command);
m_document->renderer()->doRefresh();
}
// resize end
ResizeClipCommand *command = new ResizeClipCommand(this, m_startPos, QPointF(m_dragItem->endPos(), m_dragItem->track()), false, false);
- m_document->renderer()->mltResizeClipEnd(m_tracksCount - m_dragItem->track(), GenTime(m_dragItem->startPos(), 25), GenTime(m_dragItem->cropStart(), 25), GenTime(m_dragItem->cropStart(), 25) + GenTime(m_dragItem->endPos(), 25) - GenTime(m_dragItem->startPos(), 25));
+ m_document->renderer()->mltResizeClipEnd(m_tracksCount - m_dragItem->track(), GenTime(m_dragItem->startPos(), m_document->fps()), GenTime(m_dragItem->cropStart(), m_document->fps()), GenTime(m_dragItem->cropStart(), m_document->fps()) + GenTime(m_dragItem->endPos(), m_document->fps()) - GenTime(m_dragItem->startPos(), m_document->fps()));
m_commandStack->push(command);
m_document->renderer()->doRefresh();
}
void CustomTrackView::deleteClip (int track, int startpos, const QRectF &rect )
{
- ClipItem *item = (ClipItem *) scene()->itemAt(rect.x() + 1, rect.y() + 1);
+ ClipItem *item = getClipItemAt(startpos, track);
if (!item) {
kDebug()<<"---------------- ERROR, CANNOT find clip to move at: "<<rect.x();
return;
item->baseClip()->removeReference();
m_document->updateClip(item->baseClip()->getId());
delete item;
- m_document->renderer()->mltRemoveClip(m_tracksCount - track, GenTime(startpos, 25));
+ m_document->renderer()->mltRemoveClip(m_tracksCount - track, GenTime(startpos, m_document->fps()));
m_document->renderer()->doRefresh();
}
scene()->addItem(item);
baseclip->addReference();
m_document->updateClip(baseclip->getId());
- m_document->renderer()->mltInsertClip(m_tracksCount - track, GenTime(startpos, 25), xml);
+ m_document->renderer()->mltInsertClip(m_tracksCount - track, GenTime(startpos, m_document->fps()), xml);
m_document->renderer()->doRefresh();
}
+ClipItem *CustomTrackView::getClipItemAt(int pos, int track)
+{
+ return (ClipItem *) scene()->itemAt(pos * m_scale, track * 50 + 25);
+}
+
void CustomTrackView::moveClip ( const QPointF &startPos, const QPointF &endPos )
{
- ClipItem *item = (ClipItem *) scene()->itemAt((startPos.x() + 1) * m_scale, startPos.y() * 50 + 25);
+ ClipItem *item = getClipItemAt(startPos.x() + 1, startPos.y());
if (!item) {
kDebug()<<"---------------- ERROR, CANNOT find clip to move at: "<<startPos.x() * m_scale * FRAME_SIZE + 1<<", "<<startPos.y() * 50 + 25;
return;
int offset;
if (resizeClipStart) offset = 1;
else offset = -1;
- ClipItem *item = (ClipItem *) scene()->itemAt((startPos.x() + offset) * m_scale, startPos.y() * 50 + 25);
+ ClipItem *item = getClipItemAt(startPos.x() + offset, startPos.y());
if (!item) {
kDebug()<<"---------------- ERROR, CANNOT find clip to resize at: "<<startPos;
return;
}
qreal diff = endPos.x() - startPos.x();
if (resizeClipStart) {
- m_document->renderer()->mltResizeClipStart(m_tracksCount - item->track(), GenTime(item->endPos(), 25), GenTime(endPos.x(), 25), GenTime(item->startPos(), 25), GenTime(item->cropStart() + diff, 25), GenTime(item->cropStart() + diff, 25) + GenTime(item->endPos(), 25) - GenTime(endPos.x(), 25));
+ m_document->renderer()->mltResizeClipStart(m_tracksCount - item->track(), GenTime(item->endPos(), m_document->fps()), GenTime(endPos.x(), m_document->fps()), GenTime(item->startPos(), m_document->fps()), GenTime(item->cropStart() + diff, m_document->fps()), GenTime(item->cropStart() + diff, m_document->fps()) + GenTime(item->endPos(), m_document->fps()) - GenTime(endPos.x(), m_document->fps()));
item->resizeStart(endPos.x(), m_scale);
}
else {
- m_document->renderer()->mltResizeClipEnd(m_tracksCount - item->track(), GenTime(item->startPos(), 25), GenTime(item->cropStart(), 25), GenTime(item->cropStart(), 25) + GenTime(endPos.x(), 25) - GenTime(item->startPos(), 25));
+ m_document->renderer()->mltResizeClipEnd(m_tracksCount - item->track(), GenTime(item->startPos(), m_document->fps()), GenTime(item->cropStart(), m_document->fps()), GenTime(item->cropStart(), m_document->fps()) + GenTime(endPos.x(), m_document->fps()) - GenTime(item->startPos(), m_document->fps()));
item->resizeEnd(endPos.x(), m_scale);
}
m_document->renderer()->doRefresh();