X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Fmonitormanager.h;h=7fbe52002aba3514328fda2575ee242c93f5a489;hb=ede6f74de910cea0264b51e7a5b16b681b0b669b;hp=9029407cc55ca185cfaf11a3da6dd1e168dab184;hpb=7caecc149e65907e4a57c8115c7cac12042e9308;p=kdenlive diff --git a/src/monitormanager.h b/src/monitormanager.h index 9029407c..7fbe5200 100644 --- a/src/monitormanager.h +++ b/src/monitormanager.h @@ -22,24 +22,34 @@ #define MONITORMANAGER_H #include "monitor.h" +#include "recmonitor.h" #include "timecode.h" -class Monitor; -class MonitorManager : public QObject { +class MonitorManager : public QObject +{ Q_OBJECT 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 switchMonitors(); void resetProfiles(Timecode tc); void stopActiveMonitor(); + AbstractRender *activeRenderer(); + void updateScopeSource(); + void clearScopeSource(); public slots: - void activateMonitor(QString name = QString::null); + + /** @brief Activates a monitor. + * @param name name of the monitor to activate */ + bool activateMonitor(const QString &name = QString()); + bool isActive(const QString &name) const; void slotPlay(); + void slotPause(); void slotPlayZone(); void slotLoopZone(); void slotRewind(double speed = 0); @@ -52,14 +62,27 @@ public slots: void slotEnd(); void slotResetProfiles(); + /** @brief Switches between project and clip monitor. + * @ref activateMonitor + * @param activateClip whether to activate the clip monitor */ + void slotSwitchMonitors(bool activateClip); + void slotUpdateAudioMonitoring(); + +private slots: + void slotRefreshCurrentMonitor(const QString &id); + private: Monitor *m_clipMonitor; Monitor *m_projectMonitor; - QString m_activeMonitor; Timecode m_timecode; + AbstractMonitor *m_activeMonitor; + QList m_monitorsList; signals: - void raiseClipMonitor(bool); + /** @brief When the monitor changed, update the visible color scopes */ + void checkColorScopes(); + /** @brief When the active monitor renderer was deleted, reset color scopes */ + void clearScopes(); };