X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=glwidget.h;h=ae4902c12b1f51464981a6a2bd8c55fb78071e5d;hb=6b5c8411a2776e77d1bb7d66ee7ec255428f2a13;hp=d2ff50cb5017ea48ba3698d5febafa8de604252e;hpb=60f6e9adafb491012b053d07b37371aef04aa8a4;p=nageru diff --git a/glwidget.h b/glwidget.h index d2ff50c..ae4902c 100644 --- a/glwidget.h +++ b/glwidget.h @@ -1,13 +1,23 @@ #ifndef GLWIDGET_H #define GLWIDGET_H -#include +#include +#include +#include +#include -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 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; };