X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Frecmonitor.h;h=b5d767a5dabe7a937a3621f7bc3ff2536e16a5e5;hb=4ae3260592acc87712db77b7d3fe0cc2be7d76bc;hp=c61b8041f6eb2dc8c3f88ac3a1e42d116a6d6773;hpb=ac5f5c9f6d4bdffeb76f3f2098b80f27bc532606;p=kdenlive diff --git a/src/recmonitor.h b/src/recmonitor.h index c61b8041..b5d767a5 100644 --- a/src/recmonitor.h +++ b/src/recmonitor.h @@ -27,7 +27,7 @@ #define RECMONITOR_H #include "abstractmonitor.h" -#include "blackmagic/capture.h" +#include "definitions.h" #include "ui_recmonitor_ui.h" #include @@ -41,9 +41,10 @@ #include #include #include - -#if KDE_IS_VERSION(4,2,0) #include + +#if KDE_IS_VERSION(4,7,0) +#include #endif class MonitorManager; @@ -55,19 +56,18 @@ class RecMonitor : public AbstractMonitor, public Ui::RecMonitor_UI Q_OBJECT public: - explicit RecMonitor(QString name, MonitorManager *manager, QWidget *parent = 0); - virtual ~RecMonitor(); + explicit RecMonitor(Kdenlive::MONITORID name, MonitorManager *manager, QWidget *parent = 0); + ~RecMonitor(); - const QString name() const; AbstractRender *abstractRender(); void analyseFrames(bool analyse); enum CAPTUREDEVICE {FIREWIRE = 0, VIDEO4LINUX = 1, SCREENGRAB = 2, BLACKMAGIC = 3}; protected: - virtual void mousePressEvent(QMouseEvent * event); + void mousePressEvent(QMouseEvent * event); + void mouseDoubleClickEvent(QMouseEvent * event); private: - QString m_name; KDateTime m_captureTime; /** @brief Provide feedback about dvgrab operations */ QLabel m_dvinfo; @@ -77,10 +77,8 @@ private: KComboBox m_logger; QString m_capturePath; -#if KDE_IS_VERSION(4,2,0) KCapacityBar *m_freeSpace; QTimer m_spaceTimer; -#endif KUrl m_captureFile; KIcon m_playIcon; @@ -101,21 +99,30 @@ private: QAction *m_stopAction; QAction *m_discAction; - - CaptureHandler *m_bmCapture; - /** @brief Indicates whether we are currently capturing from BLACKMAGIC. */ - bool m_blackmagicCapturing; MonitorManager *m_manager; MltDeviceCapture *m_captureDevice; - VideoPreviewContainer *m_videoBox; + VideoContainer *m_videoBox; + QAction *m_addCapturedClip; + QAction *m_previewSettings; + QString m_error; + +#if KDE_IS_VERSION(4,7,0) + KMessageWidget *m_infoMessage; +#endif + bool m_analyse; void checkDeviceAvailability(); - QPixmap mergeSideBySide(const QPixmap& pix, const QString txt); + QPixmap mergeSideBySide(const QPixmap& pix, const QString &txt); void manageCapturedFiles(); - void createBlackmagicDevice(); + /** @brief Build MLT producer for device, using path as profile. */ + void buildMltDevice(const QString &path); + /** @brief Create string containing an XML playlist for v4l capture. */ + const QString getV4lXmlPlaylist(const MltVideoProfile &profile, bool *isXml); + /** @brief Display an error message to user. */ + void showWarningMessage(const QString &text, bool logAction = false); private slots: - void slotStartCapture(bool play = true); + void slotStartPreview(bool play = true); void slotRecord(); void slotProcessStatus(QProcess::ProcessState status); void slotVideoDeviceChanged(int ix); @@ -124,10 +131,14 @@ private slots: void slotDisconnect(); //void slotStartGrab(const QRect &rect); void slotConfigure(); - void slotReadDvgrabInfo(); + void slotReadProcessInfo(); void slotUpdateFreeSpace(); - void slotGotBlackmagicFrameNumber(ulong ix); - void slotGotBlackmagicMessage(const QString &message); + void slotSetInfoMessage(const QString &message); + void slotDroppedFrames(int dropped); + /** @brief Change setting for preview while recording. */ + void slotChangeRecordingPreview(bool enable); + /** @brief Show last jog error log. */ + void slotShowLog(); public slots: void refreshRecMonitor(bool visible); @@ -135,12 +146,15 @@ public slots: void stop(); void start(); void slotStopCapture(); - void slotUpdateCaptureFolder(const QString currentProjectFolder); + void slotUpdateCaptureFolder(const QString ¤tProjectFolder); + void slotMouseSeek(int eventDelta, bool fast); + void slotSwitchFullScreen(); signals: void renderPosition(int); void durationChanged(int); void addProjectClip(KUrl); + void addProjectClipList(KUrl::List); void showConfigDialog(int, int); };