X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitor.h;h=d3f1ba93d740bc1c91e5052bb2af75debfdf1eac;hb=a3eee7be24126f5a3458d488f44cd61c66135e17;hp=7f7a7ba6f1f32a543b28735a971617ca691e6e7b;hpb=7893afa29547c481ca7e58363a7e82bdb824ebf8;p=kdenlive diff --git a/src/monitor.h b/src/monitor.h index 7f7a7ba6..d3f1ba93 100644 --- a/src/monitor.h +++ b/src/monitor.h @@ -20,68 +20,62 @@ #ifndef MONITOR_H #define MONITOR_H -#include - -#include -#include -#include -#include #include "gentime.h" -#include "ui_monitor_ui.h" +#include "renderer.h" +#include "definitions.h" #include "timecodedisplay.h" -#if defined(Q_WS_MAC) || defined(USE_OPEN_GL) -#include "videoglwidget.h" -#endif +#include "widgets/abstractmonitor.h" +#include "widgets/videoglwidget.h" + +#include +#include +#include + +#include -class MonitorManager; -class Render; class SmallRuler; class DocClipBase; -class MonitorScene; class AbstractClipItem; class Transition; class ClipItem; -class QGraphicsView; -class QGraphicsPixmapItem; -class AudioSignal; - -class MonitorRefresh : public QWidget -{ - Q_OBJECT -public: - MonitorRefresh(QWidget *parent = 0); - virtual void paintEvent(QPaintEvent *event); - void setRenderer(Render* render); - -private: - Render *m_renderer; -}; +class MonitorEditWidget; +class Monitor; +class MonitorManager; +class QSlider; +class VideoGLWidget; +class QGLWidget; 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: + void mouseDoubleClickEvent ( QMouseEvent * event ); + void mousePressEvent ( QMouseEvent * event ); + 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(Kdenlive::MonitorId id, MonitorManager *manager, QGLWidget *glContext, QString profile = QString(), QWidget *parent = 0); + ~Monitor(); Render *render; - void resetProfile(const QString profile); - QString name() const; + AbstractRender *abstractRender(); + void resetProfile(const QString &profile); + void setCustomProfile(const QString &profile, const Timecode &tc); 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(); @@ -89,20 +83,34 @@ public: void checkOverlay(); void updateTimecodeFormat(); void updateMarkers(DocClipBase *source); - MonitorScene *getEffectScene(); + void setMarkers(const QList &markers); + MonitorEditWidget *getEffectEdit(); + QWidget *container(); + void reloadProducer(const QString &id); + QFrame *m_volumePopup; + /** @brief Reimplemented from QWidget, updates the palette colors. */ + void setPalette ( const QPalette & p); + /** @brief Returns a hh:mm:ss timecode from a frame number. */ + QString getTimecodeFromFrames(int pos); + /** @brief Returns current project's fps. */ + double fps() const; + /** @brief Get url for the clip's thumbnail */ + QString getMarkerThumb(GenTime pos); protected: - virtual void mousePressEvent(QMouseEvent * event); - virtual void mouseReleaseEvent(QMouseEvent * 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); virtual Qt::DropActions supportedDropActions() const;*/ @@ -110,18 +118,12 @@ 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; - MonitorRefresh *m_monitorRefresh; KIcon m_playIcon; KIcon m_pauseIcon; TimecodeDisplay *m_timePos; @@ -133,19 +135,23 @@ private: QMenu *m_playMenu; QMenu *m_markerMenu; QPoint m_DragStartPosition; - MonitorScene *m_effectScene; - QGraphicsView *m_effectView; + MonitorEditWidget *m_effectWidget; /** Selected clip/transition in timeline. Used for looping it. */ AbstractClipItem *m_selectedClip; /** 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) + + QGLWidget *m_parentGLContext; VideoGLWidget *m_glWidget; - bool createOpenGlWidget(QVBoxLayout *rendererBox, const QString profile); -#endif + void createOpenGlWidget(QWidget *parent, const QString &profile); 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); @@ -156,19 +162,24 @@ 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 slotGoToMarker(QAction *action); + void slotSetVolume(int volume); + void slotShowVolume(); + void slotEditMarker(); + void slotExtractCurrentZone(); public slots: void slotOpenFile(const QString &); - void slotSetXml(DocClipBase *clip, QPoint zone = QPoint(), const int position = -1); - void refreshMonitor(bool visible = true); + 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(); void slotPlay(); void slotPlayZone(); void slotLoopZone(); @@ -178,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(); @@ -191,24 +202,29 @@ 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. */ 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 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, const QPoint &zone); }; #endif