X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.h;h=f246af70d1b8645b75b9e56e627d3788032b0874;hb=ead7176d2ab818ec3a1275aeca2b2fc0c1ea1276;hp=df6c78c4243fe11f4ce95a38dd6f3a2c6e3fe56d;hpb=e4a587eb01e15cbd4c6cd200e656e83f9a3885b0;p=kdenlive diff --git a/src/monitor.h b/src/monitor.h index df6c78c4..f246af70 100644 --- a/src/monitor.h +++ b/src/monitor.h @@ -21,37 +21,68 @@ #ifndef MONITOR_H #define MONITOR_H +#include + #include #include #include #include +#include "gentime.h" #include "ui_monitor_ui.h" +#ifdef Q_WS_MAC +#include "videoglwidget.h" +#endif class MonitorManager; class Render; class SmallRuler; class DocClipBase; -class MonitorRefresh : public QWidget { +class MonitorRefresh : public QWidget +{ Q_OBJECT public: MonitorRefresh(QWidget* parent); virtual void paintEvent(QPaintEvent * event); void setRenderer(Render* render); + private: Render *m_renderer; }; -class Monitor : public QWidget { +class Overlay : public QLabel +{ + Q_OBJECT +public: + Overlay(QWidget* parent); + virtual void paintEvent(QPaintEvent * event); + void setOverlayText(const QString &, bool isZone = true); + +private: + bool m_isZone; +}; + +class Monitor : public QWidget +{ Q_OBJECT public: - Monitor(QString name, MonitorManager *manager, QWidget *parent = 0); + Monitor(QString name, MonitorManager *manager, QString profile = QString(), QWidget *parent = 0); + virtual ~Monitor(); Render *render; - void resetProfile(); + void resetProfile(const QString profile); QString name() const; void resetSize(); + bool isActive() const; + void pause(); + void setupMenu(QMenu *goMenu, QAction *playZone, QAction *loopZone, QMenu *markerMenu = NULL); + const QString sceneList(); + DocClipBase *activeClip(); + GenTime position(); + void checkOverlay(); + void updateTimecodeFormat(); + void updateMarkers(DocClipBase *source); protected: virtual void mousePressEvent(QMouseEvent * event); @@ -66,53 +97,75 @@ protected: // virtual void paintEvent(QPaintEvent * event); private: - Ui::Monitor_UI ui; - MonitorManager *m_monitorManager; - MonitorRefresh *m_monitorRefresh; + Ui::Monitor_UI m_ui; QString m_name; + MonitorManager *m_monitorManager; + DocClipBase *m_currentClip; + SmallRuler *m_ruler; + Overlay *m_overlay; + bool m_isActive; double m_scale; int m_length; - int m_position; - SmallRuler *m_ruler; + bool m_dragStarted; + MonitorRefresh *m_monitorRefresh; KIcon m_playIcon; KIcon m_pauseIcon; - bool m_isActive; KRestrictedLine *m_timePos; QAction *m_playAction; QMenu *m_contextMenu; - DocClipBase *m_currentClip; + QMenu *m_configMenu; + QMenu *m_playMenu; + QMenu *m_markerMenu; QPoint m_DragStartPosition; - bool m_dragStarted; +#ifdef Q_WS_MAC + VideoGLWidget *m_glWidget; +#endif + GenTime getSnapForPos(bool previous); + bool m_frametimecode; private slots: - void adjustRulerSize(int length); void seekCursor(int pos); void rendererStopped(int pos); void slotExtractCurrentFrame(); void slotSetThumbFrame(); void slotSetSizeOneToOne(); void slotSetSizeOneToTwo(); - void slotSetZoneStart(); - void slotSetZoneEnd(); + void slotSaveZone(); + void slotSeek(); + void setClipZone(QPoint pos); + void slotSwitchMonitorInfo(bool show); + void slotSwitchDropFrames(bool show); + void slotGoToMarker(QAction *action); public slots: void slotOpenFile(const QString &); - void slotSetXml(DocClipBase *clip, const int position = -1); + void slotSetXml(DocClipBase *clip, QPoint zone = QPoint(), const int position = -1); void initMonitor(); - void refreshMonitor(bool visible); + void refreshMonitor(bool visible = true); void slotSeek(int pos); void stop(); void start(); void activateMonitor(); void slotPlay(); + void slotPlayZone(); + void slotLoopZone(); void slotForward(double speed = 0); void slotRewind(double speed = 0); - void slotRewindOneFrame(); - void slotForwardOneFrame(); + void slotRewindOneFrame(int diff = 1); + void slotForwardOneFrame(int diff = 1); void saveSceneList(QString path, QDomElement info = QDomElement()); void slotStart(); void slotEnd(); + void slotSetZoneStart(); + void slotSetZoneEnd(); + void slotZoneStart(); + void slotZoneEnd(); void slotZoneMoved(int start, int end); + void slotSeekToNextSnap(); + void slotSeekToPreviousSnap(); + void adjustRulerSize(int length); + void setTimePos(const QString &pos); + QStringList getZoneInfo() const; signals: void renderPosition(int); @@ -120,6 +173,7 @@ signals: void refreshClipThumbnail(const QString &); void adjustMonitorSize(); void zoneUpdated(QPoint); + void saveZone(Render *, QPoint); }; #endif