X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=glwidget.h;h=f2eaea8bc00aa0cd95fa40eafa54cdc6edfa67ed;hb=402b3d36c13bb04e9a2f690c5c12d8f85d6dc415;hp=ae4902c12b1f51464981a6a2bd8c55fb78071e5d;hpb=6b5c8411a2776e77d1bb7d66ee7ec255428f2a13;p=nageru diff --git a/glwidget.h b/glwidget.h index ae4902c..f2eaea8 100644 --- a/glwidget.h +++ b/glwidget.h @@ -2,17 +2,24 @@ #define GLWIDGET_H #include -#include +#include +#include #include #include #include "mixer.h" -#include "qgl.h" -#include "qobjectdefs.h" class QMouseEvent; +class QObject; +class QPoint; class QWidget; +namespace movit { + +class ResourcePool; + +} // 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). // @@ -23,13 +30,14 @@ class GLWidget : public QGLWidget public: GLWidget(QWidget *parent = 0); - ~GLWidget(); void set_output(Mixer::Output output) { this->output = output; } + void clean_context(); + protected: void initializeGL() override; void resizeGL(int width, int height) override; @@ -39,12 +47,17 @@ protected: signals: void clicked(); void transition_names_updated(std::vector transition_names); - void resolution_updated(Mixer::Output output); + 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(unsigned signal_num, const QPoint &pos); private: Mixer::Output output; GLuint vao, program_num; GLuint position_vbo, texcoord_vbo; + movit::ResourcePool *resource_pool = nullptr; }; #endif