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