X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=src%2Frenderer.h;h=43be7b8bffcb280978738ee5a017160a84281df3;hb=56aee6aedeeed3efd10ada8fe3c229eddc01ef05;hp=9d059fe00206c3faa749fd199266cad552c85eca;hpb=910f914b9ed57d1edaacbc382e68f18d6237d188;p=kdenlive diff --git a/src/renderer.h b/src/renderer.h index 9d059fe0..43be7b8b 100644 --- a/src/renderer.h +++ b/src/renderer.h @@ -31,15 +31,15 @@ #include "gentime.h" #include "definitions.h" -#include "abstractmonitor.h" +#include "widgets/abstractmonitor.h" #include #include #include -#include -#include +#include +#include #include #include #include @@ -47,6 +47,7 @@ #include #include +class QGLWidget; class QPixmap; class KComboBox; @@ -109,7 +110,7 @@ class Render: public AbstractRender * @param rendererName A unique identifier for this renderer * @param winid The parent widget identifier (required for SDL display). Set to 0 for OpenGL rendering * @param profile The MLT profile used for the renderer (default one will be used if empty). */ - Render(Kdenlive::MONITORID rendererName, int winid, QString profile = QString(), QWidget *parent = 0); + Render(Kdenlive::MonitorId rendererName, int winid, QString profile = QString(), QWidget *parent = 0, QGLWidget *mainGLContext = 0); /** @brief Destroy the MLT Renderer. */ virtual ~Render(); @@ -356,6 +357,8 @@ class Render: public AbstractRender protected: static void consumer_frame_show(mlt_consumer, Render * self, mlt_frame frame_ptr); static void consumer_gl_frame_show(mlt_consumer, Render * self, mlt_frame frame_ptr); + static void consumer_thread_started(mlt_consumer, Render * self, mlt_frame frame_ptr); + static void consumer_thread_stopped(mlt_consumer, Render * self, mlt_frame frame_ptr); private: @@ -363,11 +366,13 @@ private: * * Useful to identify the renderers by what they do - e.g. background * rendering, workspace monitor, etc. */ - Kdenlive::MONITORID m_name; + Kdenlive::MonitorId m_name; Mlt::Consumer * m_mltConsumer; Mlt::Producer * m_mltProducer; Mlt::Profile *m_mltProfile; Mlt::Event *m_showFrameEvent; + Mlt::Event *m_consumerThreadStartedEvent; + Mlt::Event *m_consumerThreadStoppedEvent; Mlt::Event *m_pauseEvent; double m_fps; @@ -399,6 +404,10 @@ private: bool m_paused; /** @brief True if this monitor is active. */ bool m_isActive; + QGLWidget *m_mainGLContext; + QGLWidget *m_GLContext; + QMap m_renderThreadGLContexts; + Mlt::Filter* m_glslManager; void closeMlt(); void mltCheckLength(Mlt::Tractor *tractor); @@ -477,11 +486,12 @@ signals: * * Used in Mac OS X. */ void showImageSignal(QImage); + void showImageSignal(GLuint); void showAudioSignal(const QVector &); void addClip(const KUrl &, stringMap); void checkSeeking(); /** @brief Activate current monitor. */ - void activateMonitor(Kdenlive::MONITORID); + void activateMonitor(Kdenlive::MonitorId); void mltFrameReceived(Mlt::Frame *); public slots: