]> git.sesse.net Git - kdenlive/blobdiff - src/monitormanager.h
Complete rewrite of the video4linux capture to use MLT, in progress.
[kdenlive] / src / monitormanager.h
index 5f3050d4c77e8d5169146f4f9dc61cb6d8cde386..9352f4d70356c74bbba4968bf17650502b25554b 100644 (file)
@@ -22,9 +22,9 @@
 #define MONITORMANAGER_H
 
 #include "monitor.h"
+#include "recmonitor.h"
 #include "timecode.h"
 
-class Monitor;
 
 class MonitorManager : public QObject
 {
@@ -32,17 +32,23 @@ class MonitorManager : public QObject
 
 public:
     MonitorManager(QWidget *parent = 0);
-    void initMonitors(Monitor *clipMonitor, Monitor *projectMonitor);
+    void initMonitors(Monitor *clipMonitor, Monitor *projectMonitor, RecMonitor *recMonitor);
+    void appendMonitor(AbstractMonitor *monitor);
+    void removeMonitor(AbstractMonitor *monitor);
     Timecode timecode();
     void resetProfiles(Timecode tc);
     void stopActiveMonitor();
+    AbstractRender *activeRenderer();
+    void updateScopeSource();
 
 public slots:
 
     /** @brief Activates a monitor.
      * @param name name of the monitor to activate */
     void activateMonitor(QString name = QString());
+    bool isActive(const QString name) const;
     void slotPlay();
+    void slotPause();
     void slotPlayZone();
     void slotLoopZone();
     void slotRewind(double speed = 0);
@@ -59,21 +65,22 @@ public slots:
      * @ref activateMonitor
      * @param activateClip whether to activate the clip monitor */
     void slotSwitchMonitors(bool activateClip);
+    void slotUpdateAudioMonitoring();
 
 private slots:
     void slotRefreshCurrentMonitor();
-    void slotUpdateAudioMonitoring();
 
 private:
     Monitor *m_clipMonitor;
     Monitor *m_projectMonitor;
-    QString m_activeMonitor;
     Timecode m_timecode;
+    AbstractMonitor *m_activeMonitor;
     bool m_blocked;
+    QList <AbstractMonitor *>m_monitorsList;
 
 signals:
     /** @brief Emitted when the active monitor changes */
-    void raiseClipMonitor(bool);
+    void raiseMonitor(AbstractMonitor *);
     /** @brief When the monitor changed, update the visible color scopes */
     void checkColorScopes();