X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.h;h=23a41c2045961ace269f9a74163fe087e0e55890;hb=c42a026234a44a2d766e57bc64a6ac7bbd094000;hp=9e66b71d3764c712d68f4087cb3f84a0dce06149;hpb=250e2530273d33cce4b2ff095c09339bb8dbe89e;p=kdenlive diff --git a/src/monitor.h b/src/monitor.h index 9e66b71d..23a41c20 100644 --- a/src/monitor.h +++ b/src/monitor.h @@ -21,41 +21,74 @@ #ifndef MONITOR_H #define MONITOR_H +#include + #include #include #include #include +#include "gentime.h" #include "ui_monitor_ui.h" 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); + virtual ~Monitor(); Render *render; - void resetProfile(QString prof); + void resetProfile(); 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(); protected: virtual void mousePressEvent(QMouseEvent * event); + virtual void mouseReleaseEvent(QMouseEvent * event); virtual void wheelEvent(QWheelEvent * event); - virtual void resizeEvent(QResizeEvent * event); + virtual void mouseMoveEvent(QMouseEvent *event); + virtual QStringList mimeTypes() const; + /* virtual void dragMoveEvent(QDragMoveEvent * event); + virtual Qt::DropActions supportedDropActions() const;*/ + +// virtual void resizeEvent(QResizeEvent * event); // virtual void paintEvent(QPaintEvent * event); private: @@ -73,16 +106,29 @@ private: 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; + GenTime getSnapForPos(bool previous); private slots: - void adjustRulerSize(int length); void seekCursor(int pos); void rendererStopped(int pos); void slotExtractCurrentFrame(); + void slotSetThumbFrame(); + void slotSetSizeOneToOne(); + void slotSetSizeOneToTwo(); + void slotSaveZone(); + void slotSeek(); + void setClipZone(QPoint pos); + void slotSwitchMonitorInfo(bool show); public slots: void slotOpenFile(const QString &); - void slotSetXml(const QDomElement &e); + void slotSetXml(DocClipBase *clip, const int position = -1); void initMonitor(); void refreshMonitor(bool visible); void slotSeek(int pos); @@ -90,15 +136,31 @@ public slots: 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 saveSceneList(QString path, QDomElement e = QDomElement()); + 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); signals: void renderPosition(int); void durationChanged(int); + void refreshClipThumbnail(const QString &); + void adjustMonitorSize(); + void zoneUpdated(QPoint); + void saveZone(Render *, QPoint); }; #endif