]> git.sesse.net Git - kdenlive/blob - src/transition.cpp
4004435fa9e58c52b086c3704636fc7bff1eefc5
[kdenlive] / src / transition.cpp
1 /***************************************************************************
2                           transition.cpp  -  description
3                              -------------------
4     begin                : Tue Jan 24 2006
5     copyright            : (C) 2006 by Jean-Baptiste Mardelle
6     email                : jb@ader.ch
7  ***************************************************************************/
8
9 /***************************************************************************
10  *                                                                         *
11  *   This program is free software; you can redistribute it and/or modify  *
12  *   it under the terms of the GNU General Public License as published by  *
13  *   the Free Software Foundation; either version 2 of the License, or     *
14  *   (at your option) any later version.                                   *
15  *                                                                         *
16  ***************************************************************************/
17
18 #include <QBrush>
19 #include <QDomElement>
20 #include <QPainter>
21 #include <QGraphicsScene>
22 #include <QGraphicsView>
23 #include <QScrollBar>
24 #include <QStyleOptionGraphicsItem>
25
26 #include <kdebug.h>
27 #include <KIcon>
28 #include <klocale.h>
29
30 #include "transition.h"
31 #include "clipitem.h"
32 #include "kdenlivesettings.h"
33 #include "mainwindow.h"
34
35 Transition::Transition(const ItemInfo info, int transitiontrack, double scale, double fps, QDomElement params) : AbstractClipItem(info, QRectF(info.startPos.frames(fps) *scale , info.track * KdenliveSettings::trackheight() + KdenliveSettings::trackheight() / 3 * 2, (info.endPos - info.startPos).frames(fps) * scale , KdenliveSettings::trackheight() / 3 * 2 - 1), fps), m_gradient(QLinearGradient(0, 0, 0, 0)) {
36     m_singleClip = true;
37     m_transitionTrack = transitiontrack;
38     m_secondClip = NULL;
39     m_cropStart = GenTime();
40     m_maxDuration = GenTime(10000, fps);
41
42     m_gradient.setColorAt(0, QColor(200, 200, 0, 150));
43     m_gradient.setColorAt(1, QColor(200, 200, 200, 120));
44
45     //m_referenceClip = clipa;
46     if (params.isNull()) {
47         m_parameters = MainWindow::transitions.getEffectByName("Luma");
48     } else {
49         m_parameters = params;
50     }
51
52     m_name = m_parameters.elementsByTagName("name").item(0).toElement().text();
53     m_secondClip = 0;
54     setFlags(QGraphicsItem::ItemClipsToShape | QGraphicsItem::ItemIsMovable | QGraphicsItem::ItemIsSelectable);
55     setZValue(2);
56
57     //m_referenceClip->addTransition(this);
58 }
59
60 Transition::~Transition() {
61 }
62
63 QString Transition::transitionName() const {
64     return m_name;
65 }
66
67 QString Transition::transitionTag() const {
68     return m_parameters.attribute("tag");
69 }
70
71 void Transition::setTransitionParameters(const QDomElement params) {
72     m_parameters = params;
73     m_name = m_parameters.elementsByTagName("name").item(0).toElement().text();
74     update();
75 }
76
77
78 bool Transition::invertedTransition() const {
79     return false; //m_parameters.attribute("reverse").toInt();
80 }
81
82 QPixmap Transition::transitionPixmap() const {
83     KIcon icon;
84     QString tag = transitionTag();
85     if (tag == "luma") {
86         if (invertedTransition()) icon = KIcon("kdenlive_trans_up");
87         else icon = KIcon("kdenlive_trans_down");
88     } else if (tag == "composite") {
89         icon = KIcon("kdenlive_trans_wiper");
90     } else if (tag == "lumafile") {
91         icon = KIcon("kdenlive_trans_luma");
92     } else icon = KIcon("kdenlive_trans_pip");
93     return icon.pixmap(QSize(15, 15));
94 }
95
96
97 void Transition::setTransitionDirection(bool inv) {
98     //m_parameters.setAttribute("reverse", inv);
99 }
100
101 int Transition::transitionEndTrack() const {
102     return m_transitionTrack;
103 }
104
105 void Transition::updateTransitionEndTrack(int newtrack) {
106     m_transitionTrack = newtrack;
107 }
108
109 void Transition::paint(QPainter *painter,
110                        const QStyleOptionGraphicsItem *option,
111                        QWidget *widget) {
112
113     painter->setClipRect(option->exposedRect);
114     QRectF br = rect();
115     QPainterPath roundRectPathUpper = upperRectPart(br), roundRectPathLower = lowerRectPart(br);
116     QPainterPath resultClipPath = roundRectPathUpper.united(roundRectPathLower);
117
118
119 #if 0
120     QRadialGradient radialGrad(QPointF(br.x() + 50, br.y() + 20), 70);
121     radialGrad.setColorAt(0, QColor(200, 200, 0, 100));
122     radialGrad.setColorAt(0.5, QColor(150, 150, 0, 100));
123     radialGrad.setColorAt(1, QColor(100, 100, 0, 100));
124     painter->fillRect(br.intersected(rectInView), QBrush(radialGrad)/*,Qt::Dense4Pattern*/);
125 #else
126     m_gradient.setStart(0, br.y());
127     m_gradient.setFinalStop(0, br.bottom());
128     painter->fillPath(resultClipPath, m_gradient);
129 #endif
130
131     int top = (int)(br.y() + br.height() / 2 - 7);
132     painter->drawPixmap((int)(br.x() + 10), top, transitionPixmap());
133     painter->setPen(QColor(0, 0, 0, 180));
134     top += painter->fontInfo().pixelSize();
135     painter->drawText((int)br.x() + 31, top + 1, transitionName());
136     painter->setPen(QColor(255, 255, 255, 180));
137     painter->drawText((int)br.x() + 30, top, transitionName());
138     QPen pen = painter->pen();
139     if (isSelected()) {
140         pen.setColor(Qt::red);
141         //pen.setWidth(2);
142     } else {
143         pen.setColor(Qt::black);
144         //pen.setWidth(1);
145     }
146     painter->setPen(pen);
147     painter->drawPath(resultClipPath);
148 }
149
150 int Transition::type() const {
151     return TRANSITIONWIDGET;
152 }
153
154 OPERATIONTYPE Transition::operationMode(QPointF pos, double scale) {
155     if (qAbs((int)(pos.x() - rect().x())) < 6) return RESIZESTART;
156     else if (qAbs((int)(pos.x() - (rect().x() + rect().width()))) < 6) return RESIZEEND;
157     return MOVE;
158 }
159
160 bool Transition::hasClip(const ClipItem * clip) const {
161     if (clip == m_secondClip) return true;
162     return false;
163 }
164
165 bool Transition::belongsToClip(const ClipItem * clip) const {
166     if (clip == m_referenceClip) return true;
167     return false;
168 }
169
170 /*
171 Transition *Transition::clone() {
172     return new Transition::Transition(rect(), m_referenceClip, this->toXML() , m_fps);
173 }*/
174
175 /*
176 Transition *Transition::reparent(ClipItem * clip) {
177     return new Transition::Transition(rect(), clip, this->toXML(), m_fps, m_referenceClip->startPos());
178 }*/
179
180 bool Transition::isValid() const {
181     return true; //(m_transitionDuration != GenTime());
182 }
183
184 const ClipItem *Transition::referencedClip() const {
185     return m_referenceClip;
186 }
187
188 QDomElement Transition::toXML() {
189     m_parameters.setAttribute("type", transitionTag());
190     //m_transitionParameters.setAttribute("inverted", invertTransition());
191     m_parameters.setAttribute("transition_atrack", track());
192     m_parameters.setAttribute("transition_btrack", m_transitionTrack);
193     m_parameters.setAttribute("start", startPos().frames(m_fps));
194     m_parameters.setAttribute("end", endPos().frames(m_fps));
195
196     if (m_secondClip) {
197         m_parameters.setAttribute("clipb_starttime", m_secondClip->startPos().frames(m_referenceClip->fps()));
198         m_parameters.setAttribute("clipb_track", transitionEndTrack());
199     }
200
201     return m_parameters;
202 }
203