]> git.sesse.net Git - nageru/blobdiff - glwidget.h
Show the current resolution next to the inputs.
[nageru] / glwidget.h
index d2ff50cb5017ea48ba3698d5febafa8de604252e..ae4902c12b1f51464981a6a2bd8c55fb78071e5d 100644 (file)
@@ -1,13 +1,23 @@
 #ifndef GLWIDGET_H
 #define GLWIDGET_H
 
-#include <QOpenGLWidget>
+#include <epoxy/gl.h>
+#include <QGLWidget>
+#include <string>
+#include <vector>
 
-namespace movit {
-class ResourcePool;
-}
+#include "mixer.h"
+#include "qgl.h"
+#include "qobjectdefs.h"
 
-class GLWidget : public QOpenGLWidget
+class QMouseEvent;
+class QWidget;
+
+// 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,12 +25,24 @@ public:
        GLWidget(QWidget *parent = 0);
        ~GLWidget();
 
+       void set_output(Mixer::Output output)
+       {
+               this->output = output;
+       }
+
 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 resolution_updated(Mixer::Output output);
 
 private:
-       movit::ResourcePool *resource_pool;
+       Mixer::Output output;
        GLuint vao, program_num;
        GLuint position_vbo, texcoord_vbo;
 };