X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.h;h=bd0c0dda26141bdf84502a655dfa8a58aa647a14;hb=65e5040eb56dab1711adc95030fc7ee25fefed28;hp=6e989dc96af03e7c6faa70274e705f6c1f4d6a81;hpb=56f69242fee94baa6a0ed504b9cc51e0b5eb04ae;p=kdenlive diff --git a/src/monitor.h b/src/monitor.h index 6e989dc9..bd0c0dda 100644 --- a/src/monitor.h +++ b/src/monitor.h @@ -21,11 +21,14 @@ #ifndef MONITOR_H #define MONITOR_H +#include + #include #include #include #include +#include "gentime.h" #include "ui_monitor_ui.h" class MonitorManager; @@ -33,7 +36,8 @@ class Render; class SmallRuler; class DocClipBase; -class MonitorRefresh : public QWidget { +class MonitorRefresh : public QWidget +{ Q_OBJECT public: MonitorRefresh(QWidget* parent); @@ -44,19 +48,36 @@ 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); + virtual ~Monitor(); Render *render; void resetProfile(); QString name() const; void resetSize(); bool isActive() const; void pause(); - void setupMenu(QMenu *goMenu); - QDomDocument sceneList(); + void setupMenu(QMenu *goMenu, QAction *playZone, QAction *loopZone, QMenu *markerMenu = NULL); + const QString sceneList(); + DocClipBase *activeClip(); + GenTime position(); + void checkOverlay(); protected: virtual void mousePressEvent(QMouseEvent * event); @@ -71,7 +92,7 @@ protected: // virtual void paintEvent(QPaintEvent * event); private: - Ui::Monitor_UI ui; + Ui::Monitor_UI m_ui; MonitorManager *m_monitorManager; MonitorRefresh *m_monitorRefresh; QString m_name; @@ -90,9 +111,10 @@ private: DocClipBase *m_currentClip; QPoint m_DragStartPosition; bool m_dragStarted; + Overlay *m_overlay; + GenTime getSnapForPos(bool previous); private slots: - void adjustRulerSize(int length); void seekCursor(int pos); void rendererStopped(int pos); void slotExtractCurrentFrame(); @@ -101,6 +123,8 @@ private slots: void slotSetSizeOneToTwo(); void slotSaveZone(); void slotSeek(); + void setClipZone(QPoint pos); + void slotSwitchMonitorInfo(bool show); public slots: void slotOpenFile(const QString &); @@ -116,8 +140,8 @@ public slots: 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(); @@ -126,6 +150,10 @@ public slots: void slotZoneStart(); void slotZoneEnd(); void slotZoneMoved(int start, int end); + void slotSeekToNextSnap(); + void slotSeekToPreviousSnap(); + void adjustRulerSize(int length); + void setTimePos(const QString &pos); signals: void renderPosition(int);