X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Ftransition.cpp;h=f713709477461d796d6edb66b07290e2147865e9;hb=a0b31d454dcbbd7c31f1dca4cd22c71da61e8920;hp=cfabafcd488548f1f5d4de271044b2374c1e4fd5;hpb=725b4ed939ef73109813f91891d638e08adfc874;p=kdenlive diff --git a/src/transition.cpp b/src/transition.cpp index cfabafcd..f7137094 100644 --- a/src/transition.cpp +++ b/src/transition.cpp @@ -39,10 +39,23 @@ Transition::Transition(const ItemInfo info, int transitiontrack, double fps, QDo m_transitionTrack(transitiontrack) { setZValue(3); - setRect(0, 0, (info.endPos - info.startPos).frames(fps) - 0.02, (qreal)(KdenliveSettings::trackheight() / 3 * 2 - 1)); + m_info.cropDuration = info.endPos - info.startPos; setPos(info.startPos.frames(fps), (qreal)(info.track * KdenliveSettings::trackheight() + KdenliveSettings::trackheight() / 3 * 2)); - - m_cropStart = GenTime(); + +#if QT_VERSION >= 0x040600 + m_startAnimation = new QPropertyAnimation(this, "rect"); + m_startAnimation->setDuration(200); + QRectF r(0, 0, m_info.cropDuration.frames(fps) - 0.02, (qreal)(KdenliveSettings::trackheight() / 3 + 5)); + QRectF r2(0, 0, m_info.cropDuration.frames(fps) - 0.02, (qreal)(KdenliveSettings::trackheight() / 3 * 2 - 1)); + m_startAnimation->setStartValue(r); + m_startAnimation->setEndValue(r2); + m_startAnimation->setEasingCurve(QEasingCurve::OutQuad); + m_startAnimation->start(); +#else + setRect(0, 0, m_info.cropDuration.frames(fps) - 0.02, (qreal)(KdenliveSettings::trackheight() / 3 * 2 - 1)); +#endif + + m_info.cropStart = GenTime(); m_maxDuration = GenTime(600); if (m_automaticTransition) setBrush(QColor(200, 200, 50, 100)); @@ -57,15 +70,19 @@ Transition::Transition(const ItemInfo info, int transitiontrack, double fps, QDo if (m_automaticTransition) m_parameters.setAttribute("automatic", 1); else if (m_parameters.attribute("automatic") == "1") m_automaticTransition = true; if (m_parameters.attribute("force_track") == "1") m_forceTransitionTrack = true; - m_name = m_parameters.elementsByTagName("name").item(0).toElement().text(); + m_name = i18n(m_parameters.elementsByTagName("name").item(0).toElement().text().toUtf8().data()); m_secondClip = 0; - setFlags(QGraphicsItem::ItemClipsToShape | QGraphicsItem::ItemIsMovable | QGraphicsItem::ItemIsSelectable); //m_referenceClip->addTransition(this); } Transition::~Transition() { + blockSignals(true); +#if QT_VERSION >= 0x040600 + delete m_startAnimation; +#endif + if (scene()) scene()->removeItem(this); } Transition *Transition::clone() @@ -75,14 +92,16 @@ Transition *Transition::clone() return tr; } -QString Transition::transitionName() const +QString Transition::transitionTag() const { - return m_name; + return m_parameters.attribute("tag"); } -QString Transition::transitionTag() const +QStringList Transition::transitionInfo() const { - return m_parameters.attribute("tag"); + QStringList info; + info << m_name << m_parameters.attribute("tag") << m_parameters.attribute("id"); + return info; } bool Transition::isAutomatic() const @@ -108,7 +127,7 @@ void Transition::setTransitionParameters(const QDomElement params) m_parameters = params; if (m_parameters.attribute("force_track") == "1") setForcedTrack(true, m_parameters.attribute("transition_btrack").toInt()); else if (m_parameters.attribute("force_track") == "0") setForcedTrack(false, m_parameters.attribute("transition_btrack").toInt()); - m_name = m_parameters.elementsByTagName("name").item(0).toElement().text(); + m_name = i18n(m_parameters.elementsByTagName("name").item(0).toElement().text().toUtf8().data()); update(); } @@ -118,22 +137,6 @@ bool Transition::invertedTransition() const return false; //m_parameters.attribute("reverse").toInt(); } -QPixmap Transition::transitionPixmap() const -{ - KIcon icon; - QString tag = transitionTag(); - if (tag == "luma") { - if (invertedTransition()) icon = KIcon("kdenlive_trans_up"); - else icon = KIcon("kdenlive_trans_down"); - } else if (tag == "composite") { - icon = KIcon("kdenlive_trans_wiper"); - } else if (tag == "lumafile") { - icon = KIcon("kdenlive_trans_luma"); - } else icon = KIcon("kdenlive_trans_pip"); - return icon.pixmap(QSize(15, 15)); -} - - void Transition::setTransitionDirection(bool /*inv*/) { //m_parameters.setAttribute("reverse", inv); @@ -164,11 +167,10 @@ void Transition::paint(QPainter *painter, const QStyleOptionGraphicsItem *option, QWidget */*widget*/) { - const double scale = option->matrix.m11(); - QRectF exposed = option->exposedRect; + const QRectF exposed = option->exposedRect; painter->setClipRect(exposed); - QRectF br = rect(); - QRectF mapped = painter->matrix().mapRect(br); + const QRectF br = rect(); + const QRectF mapped = painter->matrix().mapRect(br); painter->fillRect(exposed, brush()); @@ -176,37 +178,31 @@ void Transition::paint(QPainter *painter, QPointF p1(br.x(), br.y() + br.height() / 2 - 7); painter->setMatrixEnabled(false); //painter->drawPixmap(painter->matrix().map(p1) + QPointF(5, 0), transitionPixmap()); - QString text = transitionName(); - if (m_forceTransitionTrack) text.append("|>"); - QRectF txtBounding = painter->boundingRect(mapped, Qt::AlignHCenter | Qt::AlignVCenter, ' ' + text + ' '); - painter->fillRect(txtBounding, QBrush(QColor(50, 50, 0, 150))); - txtBounding.translate(QPointF(1, 1)); - painter->setPen(QColor(255, 255, 255, 255)); - painter->drawText(txtBounding, Qt::AlignCenter, text); + const QString text = m_name + (m_forceTransitionTrack ? "|>" : QString()); - /* painter->setPen(QColor(0, 0, 0, 180)); - top += painter->fontInfo().pixelSize(); - QPointF p2(br.x(), top); - painter->drawText(painter->matrix().map(p2) + QPointF(26, 1), transitionName()); - painter->setPen(QColor(255, 255, 255, 180)); - QPointF p3(br.x(), top); - painter->drawText(painter->matrix().map(p3) + QPointF(25, 0), transitionName());*/ - painter->setMatrixEnabled(true); - QPen pen = painter->pen(); - - if (isSelected()) { - pen.setColor(Qt::red); - //pen.setWidth(2); - } else { - pen.setColor(Qt::black); - //pen.setWidth(1); + // Draw clip name + QColor frameColor(brush().color().darker()); + if (isSelected() || (parentItem() && parentItem()->isSelected())) { + frameColor = QColor(Qt::red); } + frameColor.setAlpha(160); + + const QRectF txtBounding = painter->boundingRect(mapped, Qt::AlignHCenter | Qt::AlignVCenter, ' ' + text + ' '); + //painter->fillRect(txtBounding2, frameColor); + painter->setBrush(frameColor); + painter->setPen(Qt::NoPen); + painter->drawRoundedRect(txtBounding, 3, 3); + painter->setBrush(QBrush(Qt::NoBrush)); + + painter->setPen(Qt::white); + painter->drawText(txtBounding, Qt::AlignCenter, text); - pen.setWidthF(1.0); - pen.setCosmetic(true); + // Draw frame + QPen pen = painter->pen(); + pen.setColor(frameColor); painter->setPen(pen); painter->setClipping(false); - painter->drawRect(br.adjusted(0, 0, -1 / scale, 0)); + painter->drawRect(painter->matrix().mapRect(rect())); } int Transition::type() const @@ -217,6 +213,10 @@ int Transition::type() const //virtual QVariant Transition::itemChange(GraphicsItemChange change, const QVariant &value) { + if (change == QGraphicsItem::ItemSelectedChange) { + if (value.toBool()) setZValue(10); + else setZValue(3); + } if (change == ItemPositionChange && scene()) { // calculate new position. QPointF newPos = value.toPointF(); @@ -230,11 +230,14 @@ QVariant Transition::itemChange(GraphicsItemChange change, const QVariant &value // Only one clip is moving QRectF sceneShape = rect(); sceneShape.translate(newPos); - QList items = scene()->items(sceneShape, Qt::IntersectsItemShape); + QList items; + if (projectScene()->editMode() == NORMALEDIT) + items = scene()->items(sceneShape, Qt::IntersectsItemShape); items.removeAll(this); if (!items.isEmpty()) { for (int i = 0; i < items.count(); i++) { + if (!items.at(i)->isEnabled()) continue; if (items.at(i)->type() == type()) { // Collision! Don't move. //kDebug()<<"/// COLLISION WITH ITEM: "<boundingRect()<<", POS: "<pos()<<", ME: "<(items.at(i))->startPos() - m_cropDuration).frames(m_fps); + int npos = (static_cast < AbstractClipItem* >(items.at(i))->startPos() - m_info.cropDuration).frames(m_fps); newPos.setX(npos); } else { // get pos just after colliding clip int npos = static_cast < AbstractClipItem* >(items.at(i))->endPos().frames(m_fps); newPos.setX(npos); } - m_track = newTrack; + m_info.track = newTrack; //kDebug()<<"// ITEM NEW POS: "<startPos().frames(m_referenceClip->fps())); m_parameters.setAttribute("clipb_track", transitionEndTrack()); } - return m_parameters; + return m_parameters.cloneNode().toElement(); } bool Transition::hasGeometry() @@ -337,3 +341,8 @@ bool Transition::hasGeometry() return false; } +int Transition::defaultZValue() const +{ + return 3; +} +