X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.h;h=d01f5b9f58b4c9af051cbc0056558316670c8e53;hb=8fb1c990f30da000125c48476fc738a84d45e2b2;hp=04e5af2d98bee6b4736d3829e70e3a2f78e5ac8e;hpb=fe9316d603bb2da1f779493975ac12051f7e04b9;p=kdenlive diff --git a/src/monitor.h b/src/monitor.h index 04e5af2d..d01f5b9f 100644 --- a/src/monitor.h +++ b/src/monitor.h @@ -23,6 +23,7 @@ #include "gentime.h" #include "renderer.h" +#include "definitions.h" #include "timecodedisplay.h" #include "abstractmonitor.h" #ifdef USE_OPENGL @@ -47,36 +48,6 @@ class MonitorEditWidget; class Monitor; class MonitorManager; -class VideoContainer : public QFrame -{ - Q_OBJECT -public: - VideoContainer(Monitor *parent = 0); - void switchFullScreen(); - -protected: - virtual void mouseDoubleClickEvent(QMouseEvent * event); - virtual void mousePressEvent(QMouseEvent * event); - virtual void mouseReleaseEvent(QMouseEvent *event); - virtual void mouseMoveEvent(QMouseEvent *event); - void keyPressEvent(QKeyEvent *event); - virtual void wheelEvent(QWheelEvent * event); - -private: - Qt::WindowFlags m_baseFlags; - Monitor *m_monitor; -}; - -class MonitorRefresh : public QWidget -{ - Q_OBJECT -public: - MonitorRefresh(QWidget *parent = 0); - void setRenderer(Render* render); - -private: - Render *m_renderer; -}; class Overlay : public QLabel { @@ -85,9 +56,6 @@ public: Overlay(QWidget* parent = 0); void setOverlayText(const QString &, bool isZone = true); -private: - bool m_isZone; - protected: virtual void mouseDoubleClickEvent ( QMouseEvent * event ); virtual void mousePressEvent ( QMouseEvent * event ); @@ -102,15 +70,14 @@ class Monitor : public AbstractMonitor Q_OBJECT public: - Monitor(QString name, MonitorManager *manager, QString profile = QString(), QWidget *parent = 0); + Monitor(Kdenlive::MONITORID id, MonitorManager *manager, QString profile = QString(), QWidget *parent = 0); ~Monitor(); Render *render; AbstractRender *abstractRender(); void resetProfile(const QString &profile); - const QString name() const; void resetSize(); - bool isActive() const; void pause(); + void unpause(); void setupMenu(QMenu *goMenu, QAction *playZone, QAction *loopZone, QMenu *markerMenu = NULL, QAction *loopClip = NULL); const QString sceneList(); DocClipBase *activeClip(); @@ -122,10 +89,13 @@ public: QWidget *container(); void reloadProducer(const QString &id); QFrame *m_volumePopup; + /** @brief Reimplemented from QWidget, updates the palette colors. */ + void setPalette ( const QPalette & p); protected: virtual void mousePressEvent(QMouseEvent * event); virtual void mouseReleaseEvent(QMouseEvent * event); + virtual void mouseDoubleClickEvent(QMouseEvent * event); virtual void resizeEvent(QResizeEvent *event); /** @brief Move to another position on mouse wheel event. @@ -136,6 +106,7 @@ protected: virtual void wheelEvent(QWheelEvent * event); virtual void mouseMoveEvent(QMouseEvent *event); virtual QStringList mimeTypes() const; + /*virtual void dragMoveEvent(QDragMoveEvent * event); virtual Qt::DropActions supportedDropActions() const;*/ @@ -143,15 +114,13 @@ protected: //virtual void paintEvent(QPaintEvent * event); private: - QString m_name; - MonitorManager *m_monitorManager; + Kdenlive::MONITORID m_name; DocClipBase *m_currentClip; SmallRuler *m_ruler; Overlay *m_overlay; double m_scale; int m_length; bool m_dragStarted; - MonitorRefresh *m_monitorRefresh; KIcon m_playIcon; KIcon m_pauseIcon; TimecodeDisplay *m_timePos; @@ -199,6 +168,7 @@ private slots: void slotSetVolume(int volume); void slotShowVolume(); void slotEditMarker(); + void slotExtractCurrentZone(); public slots: void slotOpenFile(const QString &); @@ -209,7 +179,6 @@ public slots: void slotSeek(int pos); void stop(); void start(); - bool activateMonitor(); void slotPlay(); void slotPlayZone(); void slotLoopZone(); @@ -232,7 +201,8 @@ public slots: void adjustRulerSize(int length); void setTimePos(const QString &pos); QStringList getZoneInfo() const; - void slotEffectScene(bool show = true); + /** @brief Display the on monitor effect scene (to adjust geometry over monitor). */ + void slotShowEffectScene(bool show = true, bool manuallyTriggered = false); bool effectSceneDisplayed(); /** @brief Sets m_selectedClip to @param item. Used for looping it. */ @@ -252,6 +222,8 @@ signals: /** @brief Editing transitions / effects over the monitor requires the renderer to send frames as QImage. * This causes a major slowdown, so we only enable it if required */ void requestFrameForAnalysis(bool); + /** @brief Request a zone extraction (ffmpeg transcoding). */ + void extractZone(const QString &id, QPoint zone); }; #endif