X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=glwidget.h;h=ed67ae8621169fd7852c9bc9bccd5de2aa0797b7;hb=fa54f2630c56a1df0046923d6a77b1bd58abf240;hp=b0dc79ed09e5e4ef49101e9f8f97761989548560;hpb=adaeecd2ab8f1da45169861b7af22a0c7af066be;p=nageru diff --git a/glwidget.h b/glwidget.h index b0dc79e..ed67ae8 100644 --- a/glwidget.h +++ b/glwidget.h @@ -2,15 +2,16 @@ #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 { @@ -29,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(); + void shutdown(); protected: void initializeGL() override; @@ -46,16 +48,21 @@ 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); + 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; GLuint vao, program_num; GLuint position_vbo, texcoord_vbo; movit::ResourcePool *resource_pool = nullptr; + int current_width = 1, current_height = 1; }; #endif