]> git.sesse.net Git - nageru/blobdiff - glwidget.h
Fix an issue where the mixer lagging too much behind CEF would cause us to display...
[nageru] / glwidget.h
index 0d74480802ef37224707f53a1b2906591ee43209..ed67ae8621169fd7852c9bc9bccd5de2aa0797b7 100644 (file)
@@ -1,13 +1,30 @@
 #ifndef GLWIDGET_H
 #define GLWIDGET_H
 
-#include <QOpenGLWidget>
+#include <epoxy/gl.h>
+#include <QGL>
+#include <QString>
+#include <string>
+#include <vector>
+
+#include "mixer.h"
+
+class QMouseEvent;
+class QObject;
+class QPoint;
+class QWidget;
 
 namespace movit {
+
 class ResourcePool;
-}
 
-class GLWidget : public QOpenGLWidget
+}  // namespace movit
+
+// Note: We use the older QGLWidget instead of QOpenGLWidget as it is
+// much faster (does not go through a separate offscreen rendering step).
+//
+// TODO: Consider if QOpenGLWindow could do what we want.
+class GLWidget : public QGLWidget
 {
        Q_OBJECT
 
@@ -15,14 +32,37 @@ public:
        GLWidget(QWidget *parent = 0);
        ~GLWidget();
 
+       void set_output(Mixer::Output output)
+       {
+               this->output = output;
+       }
+
+       void shutdown();
+
 protected:
        void initializeGL() override;
+       void resizeGL(int width, int height) override;
        void paintGL() override;
+       void mousePressEvent(QMouseEvent *event) override;
+
+signals:
+       void clicked();
+       void transition_names_updated(std::vector<std::string> transition_names);
+       void name_updated(Mixer::Output output, const std::string &name);
+       void color_updated(Mixer::Output output, const std::string &color);
+
+private slots:
+       void show_context_menu(const QPoint &pos);
 
 private:
-       movit::ResourcePool *resource_pool;
-       GLuint vao, program_num;
+       void show_live_context_menu(const QPoint &pos);
+       void show_preview_context_menu(unsigned signal_num, const QPoint &pos);
 
+       Mixer::Output output;
+       GLuint vao, program_num;
+       GLuint position_vbo, texcoord_vbo;
+       movit::ResourcePool *resource_pool = nullptr;
+       int current_width = 1, current_height = 1;
 };
 
 #endif