X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.h;h=37e3cc65f1cb56f072afcbf4e168ad4ca63d3908;hb=73e4527d1abd954f088b317e59c8f0cfc1cd2e16;hp=106d4bd9fa0787d1861d3f3f725c12b0f1f0cf9e;hpb=b72fb2155efb7cdbbcb57d90c3d908a6a4d1d70a;p=kdenlive diff --git a/src/monitor.h b/src/monitor.h index 106d4bd9..37e3cc65 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,18 +48,20 @@ private: Render *m_renderer; }; -class Overlay : public QWidget { +class Overlay : public QLabel +{ Q_OBJECT public: Overlay(QWidget* parent); virtual void paintEvent(QPaintEvent * event); - void setOverlayText(const QString &); + void setOverlayText(const QString &, bool isZone = true); private: - QString m_text; + bool m_isZone; }; -class Monitor : public QWidget { +class Monitor : public QWidget +{ Q_OBJECT public: @@ -67,8 +73,11 @@ public: 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); @@ -83,30 +92,29 @@ 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; QMenu *m_configMenu; QMenu *m_playMenu; - DocClipBase *m_currentClip; QPoint m_DragStartPosition; - bool m_dragStarted; - Overlay *m_overlay; - void checkOverlay(); + GenTime getSnapForPos(bool previous); private slots: - void adjustRulerSize(int length); void seekCursor(int pos); void rendererStopped(int pos); void slotExtractCurrentFrame(); @@ -115,12 +123,15 @@ private slots: void slotSetSizeOneToTwo(); void slotSaveZone(); void slotSeek(); + void setClipZone(QPoint pos); + void slotSwitchMonitorInfo(bool show); + void slotSwitchDropFrames(bool show); public slots: void slotOpenFile(const QString &); void slotSetXml(DocClipBase *clip, const int position = -1); void initMonitor(); - void refreshMonitor(bool visible); + void refreshMonitor(bool visible = true); void slotSeek(int pos); void stop(); void start(); @@ -130,8 +141,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(); @@ -140,6 +151,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); @@ -148,6 +163,7 @@ signals: void adjustMonitorSize(); void zoneUpdated(QPoint); void saveZone(Render *, QPoint); + void blockMonitors(); }; #endif