X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.h;h=13f107a216b7e15bab671a811273f02948462cee;hb=fc7b1b8dcdedceac156f8f3068fe04909bc9d007;hp=7f7a7ba6f1f32a543b28735a971617ca691e6e7b;hpb=7893afa29547c481ca7e58363a7e82bdb824ebf8;p=kdenlive diff --git a/src/monitor.h b/src/monitor.h index 7f7a7ba6..13f107a2 100644 --- a/src/monitor.h +++ b/src/monitor.h @@ -20,65 +20,102 @@ #ifndef MONITOR_H #define MONITOR_H -#include - -#include -#include -#include -#include #include "gentime.h" -#include "ui_monitor_ui.h" +#include "renderer.h" #include "timecodedisplay.h" +#include "abstractmonitor.h" #if defined(Q_WS_MAC) || defined(USE_OPEN_GL) #include "videoglwidget.h" #endif -class MonitorManager; -class Render; +#include +#include +#include +#include + +#include +#include +#include + class SmallRuler; class DocClipBase; -class MonitorScene; class AbstractClipItem; class Transition; class ClipItem; -class QGraphicsView; -class QGraphicsPixmapItem; -class AudioSignal; +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); - virtual void paintEvent(QPaintEvent *event); 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(); @@ -89,7 +126,9 @@ public: void checkOverlay(); void updateTimecodeFormat(); void updateMarkers(DocClipBase *source); - MonitorScene *getEffectScene(); + MonitorEditWidget *getEffectEdit(); + QWidget *container(); + QFrame *m_volumePopup; protected: virtual void mousePressEvent(QMouseEvent * event); @@ -110,14 +149,11 @@ protected: //virtual void paintEvent(QPaintEvent * event); private: - Ui::Monitor_UI m_ui; - AudioSignal *m_audiosignal; QString m_name; MonitorManager *m_monitorManager; DocClipBase *m_currentClip; SmallRuler *m_ruler; Overlay *m_overlay; - bool m_isActive; double m_scale; int m_length; bool m_dragStarted; @@ -133,8 +169,8 @@ private: QMenu *m_playMenu; QMenu *m_markerMenu; QPoint m_DragStartPosition; - MonitorScene *m_effectScene; - QGraphicsView *m_effectView; + MonitorEditWidget *m_effectWidget; + VideoContainer *m_videoBox; /** Selected clip/transition in timeline. Used for looping it. */ AbstractClipItem *m_selectedClip; /** true if selected clip is transition, false = selected clip is clip. @@ -142,10 +178,15 @@ private: bool m_loopClipTransition; #if defined(Q_WS_MAC) || defined(USE_OPEN_GL) VideoGLWidget *m_glWidget; - bool createOpenGlWidget(QVBoxLayout *rendererBox, const QString profile); + bool createOpenGlWidget(QWidget *parent, const QString profile); #endif GenTime getSnapForPos(bool previous); + Qt::WindowFlags m_baseFlags; + QToolBar *m_toolbar; + QWidget *m_volumeWidget; + QSlider *m_audioSlider; + QAction *m_editMarker; private slots: void seekCursor(int pos); @@ -160,11 +201,15 @@ private slots: void slotSwitchMonitorInfo(bool show); void slotSwitchDropFrames(bool show); 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 refreshMonitor(bool visible = true); + void refreshMonitor(bool visible); + void refreshMonitor(); void slotSeek(int pos); void stop(); void start(); @@ -198,14 +243,16 @@ public slots: void slotSetSelectedClip(AbstractClipItem *item); void slotSetSelectedClip(ClipItem *item); void slotSetSelectedClip(Transition *item); + void slotMouseSeek(int eventDelta, bool fast); + void slotSwitchFullScreen(); 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);