1 /***************************************************************************
2 * Copyright (C) 2007 by Jean-Baptiste Mardelle (jb@kdenlive.org) *
4 * This program is free software; you can redistribute it and/or modify *
5 * it under the terms of the GNU General Public License as published by *
6 * the Free Software Foundation; either version 2 of the License, or *
7 * (at your option) any later version. *
9 * This program is distributed in the hope that it will be useful, *
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
12 * GNU General Public License for more details. *
14 * You should have received a copy of the GNU General Public License *
15 * along with this program; if not, write to the *
16 * Free Software Foundation, Inc., *
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
18 ***************************************************************************/
28 #include <KRestrictedLine>
29 #include <QDomElement>
32 #include "ui_monitor_ui.h"
33 #include "timecodedisplay.h"
35 #include "videoglwidget.h"
43 class AbstractClipItem;
47 class QGraphicsPixmapItem;
49 class MonitorRefresh : public QWidget
53 MonitorRefresh(QWidget *parent = 0);
54 virtual void paintEvent(QPaintEvent *event);
55 void setRenderer(Render* render);
61 class Overlay : public QLabel
65 Overlay(QWidget* parent);
66 void setOverlayText(const QString &, bool isZone = true);
72 class Monitor : public QWidget
77 Monitor(QString name, MonitorManager *manager, QString profile = QString(), QWidget *parent = 0);
80 void resetProfile(const QString profile);
83 bool isActive() const;
85 void setupMenu(QMenu *goMenu, QAction *playZone, QAction *loopZone, QMenu *markerMenu = NULL, QAction *loopClip = NULL);
86 const QString sceneList();
87 DocClipBase *activeClip();
90 void updateTimecodeFormat();
91 void updateMarkers(DocClipBase *source);
92 MonitorScene *getEffectScene();
95 virtual void mousePressEvent(QMouseEvent * event);
96 virtual void mouseReleaseEvent(QMouseEvent * event);
98 /** @brief Move to another position on mouse wheel event.
100 * Moves towards the end of the clip/timeline on mouse wheel down/back, the
101 * opposite on mouse wheel up/forward.
102 * Ctrl + wheel moves by a second, without Ctrl it moves by a single frame. */
103 virtual void wheelEvent(QWheelEvent * event);
104 virtual void mouseMoveEvent(QMouseEvent *event);
105 virtual QStringList mimeTypes() const;
106 /*virtual void dragMoveEvent(QDragMoveEvent * event);
107 virtual Qt::DropActions supportedDropActions() const;*/
109 //virtual void resizeEvent(QResizeEvent * event);
110 //virtual void paintEvent(QPaintEvent * event);
115 MonitorManager *m_monitorManager;
116 DocClipBase *m_currentClip;
123 MonitorRefresh *m_monitorRefresh;
126 TimecodeDisplay *m_timePos;
127 QAction *m_playAction;
128 /** Has to be available so we can enable and disable it. */
129 QAction *m_loopClipAction;
130 QMenu *m_contextMenu;
134 QPoint m_DragStartPosition;
135 MonitorScene *m_effectScene;
136 QGraphicsView *m_effectView;
137 /** Selected clip/transition in timeline. Used for looping it. */
138 AbstractClipItem *m_selectedClip;
139 /** true if selected clip is transition, false = selected clip is clip.
140 * Necessary because sometimes we get two signals, e.g. we get a clip and we get selected transition = NULL. */
141 bool m_loopClipTransition;
143 VideoGLWidget *m_glWidget;
146 GenTime getSnapForPos(bool previous);
149 void seekCursor(int pos);
150 void rendererStopped(int pos);
151 void slotExtractCurrentFrame();
152 void slotSetThumbFrame();
153 void slotSetSizeOneToOne();
154 void slotSetSizeOneToTwo();
157 void setClipZone(QPoint pos);
158 void slotSwitchMonitorInfo(bool show);
159 void slotSwitchDropFrames(bool show);
160 void slotGoToMarker(QAction *action);
163 void slotOpenFile(const QString &);
164 void slotSetXml(DocClipBase *clip, QPoint zone = QPoint(), const int position = -1);
166 void refreshMonitor(bool visible = true);
167 void slotSeek(int pos);
170 void activateMonitor();
174 /** @brief Loops the selected item (clip or transition). */
176 void slotForward(double speed = 0);
177 void slotRewind(double speed = 0);
178 void slotRewindOneFrame(int diff = 1);
179 void slotForwardOneFrame(int diff = 1);
180 void saveSceneList(QString path, QDomElement info = QDomElement());
183 void slotSetZoneStart();
184 void slotSetZoneEnd();
185 void slotZoneStart();
187 void slotZoneMoved(int start, int end);
188 void slotSeekToNextSnap();
189 void slotSeekToPreviousSnap();
190 void adjustRulerSize(int length);
191 void setTimePos(const QString &pos);
192 QStringList getZoneInfo() const;
193 void slotEffectScene(bool show = true);
194 bool effectSceneDisplayed();
196 /** @brief Sets m_selectedClip to @param item. Used for looping it. */
197 void slotSetSelectedClip(AbstractClipItem *item);
198 void slotSetSelectedClip(ClipItem *item);
199 void slotSetSelectedClip(Transition *item);
202 void renderPosition(int);
203 void durationChanged(int);
204 void refreshClipThumbnail(const QString &);
205 void adjustMonitorSize();
206 void zoneUpdated(QPoint);
207 void saveZone(Render *, QPoint);
208 /** @brief Editing transitions / effects over the monitor requires the renderer to send frames as QImage.
209 * This causes a major slowdown, so we only enable it if required */
210 void requestFrameForAnalysis(bool);