X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=glwidget.h;h=ed67ae8621169fd7852c9bc9bccd5de2aa0797b7;hb=fa54f2630c56a1df0046923d6a77b1bd58abf240;hp=25a8ad7b7a7b99483dd59e5799a17c7b80ea4102;hpb=d7bba4abb3d56893399578f0540b9ded0a28380f;p=nageru diff --git a/glwidget.h b/glwidget.h index 25a8ad7..ed67ae8 100644 --- a/glwidget.h +++ b/glwidget.h @@ -2,20 +2,23 @@ #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). @@ -34,6 +37,8 @@ public: this->output = output; } + void shutdown(); + protected: void initializeGL() override; void resizeGL(int width, int height) override; @@ -43,12 +48,21 @@ protected: signals: void clicked(); void transition_names_updated(std::vector 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: + void show_live_context_menu(const QPoint &pos); + void show_preview_context_menu(unsigned signal_num, const QPoint &pos); + Mixer::Output output; - movit::ResourcePool *resource_pool; GLuint vao, program_num; GLuint position_vbo, texcoord_vbo; + movit::ResourcePool *resource_pool = nullptr; + int current_width = 1, current_height = 1; }; #endif