X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.h;h=d3f1ba93d740bc1c91e5052bb2af75debfdf1eac;hb=a3eee7be24126f5a3458d488f44cd61c66135e17;hp=1de74ffa0cb2d7bcce33f1d6a58c9ed025bd0b27;hpb=f8b94e4037e9eea645fabfddc2e373ace81dafed;p=kdenlive diff --git a/src/monitor.h b/src/monitor.h index 1de74ffa..d3f1ba93 100644 --- a/src/monitor.h +++ b/src/monitor.h @@ -25,19 +25,14 @@ #include "renderer.h" #include "definitions.h" #include "timecodedisplay.h" -#include "abstractmonitor.h" -#ifdef USE_OPENGL -#include "videoglwidget.h" -#endif +#include "widgets/abstractmonitor.h" +#include "widgets/videoglwidget.h" #include #include #include -#include #include -#include -#include class SmallRuler; class DocClipBase; @@ -47,7 +42,9 @@ class ClipItem; class MonitorEditWidget; class Monitor; class MonitorManager; - +class QSlider; +class VideoGLWidget; +class QGLWidget; class Overlay : public QLabel { @@ -57,9 +54,9 @@ public: void setOverlayText(const QString &, bool isZone = true); protected: - virtual void mouseDoubleClickEvent ( QMouseEvent * event ); - virtual void mousePressEvent ( QMouseEvent * event ); - virtual void mouseReleaseEvent ( QMouseEvent * event ); + void mouseDoubleClickEvent ( QMouseEvent * event ); + void mousePressEvent ( QMouseEvent * event ); + void mouseReleaseEvent ( QMouseEvent * event ); signals: void editMarker(); @@ -70,12 +67,12 @@ class Monitor : public AbstractMonitor Q_OBJECT public: - Monitor(Kdenlive::MONITORID id, MonitorManager *manager, QString profile = QString(), QWidget *parent = 0); + Monitor(Kdenlive::MonitorId id, MonitorManager *manager, QGLWidget *glContext, QString profile = QString(), QWidget *parent = 0); ~Monitor(); Render *render; AbstractRender *abstractRender(); void resetProfile(const QString &profile); - void setCustomProfile(const QString &profile, Timecode tc); + void setCustomProfile(const QString &profile, const Timecode &tc); void resetSize(); void pause(); void unpause(); @@ -86,7 +83,7 @@ public: void checkOverlay(); void updateTimecodeFormat(); void updateMarkers(DocClipBase *source); - void setMarkers(QList markers); + void setMarkers(const QList &markers); MonitorEditWidget *getEffectEdit(); QWidget *container(); void reloadProducer(const QString &id); @@ -101,18 +98,17 @@ public: QString getMarkerThumb(GenTime pos); protected: - virtual void mousePressEvent(QMouseEvent * event); - virtual void mouseReleaseEvent(QMouseEvent * event); - virtual void mouseDoubleClickEvent(QMouseEvent * event); - virtual void resizeEvent(QResizeEvent *event); + void mousePressEvent(QMouseEvent * event); + void mouseReleaseEvent(QMouseEvent * event); + void resizeEvent(QResizeEvent *event); /** @brief Move to another position on mouse wheel event. * * Moves towards the end of the clip/timeline on mouse wheel down/back, the * opposite on mouse wheel up/forward. * Ctrl + wheel moves by a second, without Ctrl it moves by a single frame. */ - virtual void wheelEvent(QWheelEvent * event); - virtual void mouseMoveEvent(QMouseEvent *event); + void wheelEvent(QWheelEvent * event); + void mouseMoveEvent(QMouseEvent *event); virtual QStringList mimeTypes() const; /*virtual void dragMoveEvent(QDragMoveEvent * event); @@ -146,10 +142,9 @@ private: * Necessary because sometimes we get two signals, e.g. we get a clip and we get selected transition = NULL. */ bool m_loopClipTransition; -#ifdef USE_OPENGL + QGLWidget *m_parentGLContext; VideoGLWidget *m_glWidget; - bool createOpenGlWidget(QWidget *parent, const QString profile); -#endif + void createOpenGlWidget(QWidget *parent, const QString &profile); GenTime getSnapForPos(bool previous); Qt::WindowFlags m_baseFlags; @@ -167,11 +162,9 @@ private slots: void slotSetSizeOneToTwo(); void slotSaveZone(); void slotSeek(); - void setClipZone(QPoint pos); + void setClipZone(const QPoint &pos); void slotSwitchMonitorInfo(bool show); void slotSwitchDropFrames(bool show); - void slotSetDeinterlacer(int ix); - void slotSetInterpolation(int ix); void slotGoToMarker(QAction *action); void slotSetVolume(int volume); void slotShowVolume(); @@ -196,7 +189,7 @@ public slots: void slotRewind(double speed = 0); void slotRewindOneFrame(int diff = 1); void slotForwardOneFrame(int diff = 1); - void saveSceneList(QString path, QDomElement info = QDomElement()); + void saveSceneList(const QString &path, const QDomElement &info = QDomElement()); void slotStart(); void slotEnd(); void slotSetZoneStart(); @@ -225,13 +218,13 @@ signals: void durationChanged(int); void refreshClipThumbnail(const QString &, bool); void adjustMonitorSize(); - void zoneUpdated(QPoint); - void saveZone(Render *, QPoint, DocClipBase *); + void zoneUpdated(const QPoint&); + void saveZone(Render *, const 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); /** @brief Request a zone extraction (ffmpeg transcoding). */ - void extractZone(const QString &id, QPoint zone); + void extractZone(const QString &id, const QPoint &zone); }; #endif