X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=src%2Fmonitor.h;h=04e5af2d98bee6b4736d3829e70e3a2f78e5ac8e;hb=fe9316d603bb2da1f779493975ac12051f7e04b9;hp=faaf50213c7681bed426ba2bf955cc54d78494b4;hpb=c25ab9b9c4e14e3d3e8b0cfb37868e87152ae8c9;p=kdenlive diff --git a/src/monitor.h b/src/monitor.h index faaf5021..04e5af2d 100644 --- a/src/monitor.h +++ b/src/monitor.h @@ -22,8 +22,10 @@ #include "gentime.h" +#include "renderer.h" #include "timecodedisplay.h" -#if defined(Q_WS_MAC) || defined(USE_OPEN_GL) +#include "abstractmonitor.h" +#ifdef USE_OPENGL #include "videoglwidget.h" #endif @@ -36,17 +38,14 @@ #include #include - -class MonitorManager; -class Render; class SmallRuler; class DocClipBase; class AbstractClipItem; class Transition; class ClipItem; class MonitorEditWidget; - class Monitor; +class MonitorManager; class VideoContainer : public QFrame { @@ -75,39 +74,40 @@ public: MonitorRefresh(QWidget *parent = 0); void setRenderer(Render* render); -protected: - virtual void paintEvent(QPaintEvent *event); - private: Render *m_renderer; - -signals: - void switchFullScreen(); - void switchPlay(); - void mouseSeek(int, bool); }; class Overlay : public QLabel { Q_OBJECT public: - Overlay(QWidget* parent); + 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 ); + virtual void mouseReleaseEvent ( QMouseEvent * event ); + +signals: + void editMarker(); }; -class Monitor : public QWidget +class Monitor : public AbstractMonitor { Q_OBJECT public: Monitor(QString name, MonitorManager *manager, QString profile = QString(), QWidget *parent = 0); - virtual ~Monitor(); + ~Monitor(); Render *render; - void resetProfile(const QString profile); - QString name() const; + AbstractRender *abstractRender(); + void resetProfile(const QString &profile); + const QString name() const; void resetSize(); bool isActive() const; void pause(); @@ -120,11 +120,13 @@ public: void updateMarkers(DocClipBase *source); MonitorEditWidget *getEffectEdit(); QWidget *container(); + void reloadProducer(const QString &id); QFrame *m_volumePopup; protected: virtual void mousePressEvent(QMouseEvent * event); virtual void mouseReleaseEvent(QMouseEvent * event); + virtual void resizeEvent(QResizeEvent *event); /** @brief Move to another position on mouse wheel event. * @@ -146,7 +148,6 @@ private: DocClipBase *m_currentClip; SmallRuler *m_ruler; Overlay *m_overlay; - bool m_isActive; double m_scale; int m_length; bool m_dragStarted; @@ -169,7 +170,8 @@ private: /** true if selected clip is transition, false = selected clip is clip. * Necessary because sometimes we get two signals, e.g. we get a clip and we get selected transition = NULL. */ bool m_loopClipTransition; -#if defined(Q_WS_MAC) || defined(USE_OPEN_GL) + +#ifdef USE_OPENGL VideoGLWidget *m_glWidget; bool createOpenGlWidget(QWidget *parent, const QString profile); #endif @@ -179,6 +181,7 @@ private: QToolBar *m_toolbar; QWidget *m_volumeWidget; QSlider *m_audioSlider; + QAction *m_editMarker; private slots: void seekCursor(int pos); @@ -195,16 +198,18 @@ private slots: void slotGoToMarker(QAction *action); void slotSetVolume(int volume); void slotShowVolume(); + void slotEditMarker(); public slots: void slotOpenFile(const QString &); - void slotSetXml(DocClipBase *clip, QPoint zone = QPoint(), const int position = -1); + void slotSetClipProducer(DocClipBase *clip, QPoint zone = QPoint(), bool forceUpdate = false, int position = -1); + void updateClipProducer(Mlt::Producer *prod); void refreshMonitor(bool visible); void refreshMonitor(); void slotSeek(int pos); void stop(); void start(); - void activateMonitor(); + bool activateMonitor(); void slotPlay(); void slotPlayZone(); void slotLoopZone(); @@ -240,10 +245,10 @@ public slots: signals: void renderPosition(int); void durationChanged(int); - void refreshClipThumbnail(const QString &); + void refreshClipThumbnail(const QString &, bool); void adjustMonitorSize(); void zoneUpdated(QPoint); - void saveZone(Render *, QPoint); + void saveZone(Render *, QPoint, DocClipBase *); /** @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);