X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=theme.h;h=a5ecebc5d8ba3746733a162383c3bfd82daac216;hb=5c8dc09f89df0f25434bcefc9102438d2b491df2;hp=80b01badf3f1a1c0b0a38f37e15f9270f4ee84d8;hpb=9c824f7164eeecaa1aa904d69c5bb64fb3a6a27b;p=nageru diff --git a/theme.h b/theme.h index 80b01ba..a5ecebc 100644 --- a/theme.h +++ b/theme.h @@ -1,16 +1,29 @@ #ifndef _THEME_H #define _THEME_H 1 -#include -#include +#include #include - +#include +#include +#include +#include +#include #include #include +#include +#include #include +#include -#include -#include +#include "defs.h" + +namespace movit { +class ResourcePool; +struct ImageFormat; +struct YCbCrFormat; +} // namespace movit + +#define MAX_CARDS 16 class NonBouncingYCbCrInput : public movit::YCbCrInput { public: @@ -25,17 +38,22 @@ public: class Theme { public: - Theme(const char *filename, movit::ResourcePool *resource_pool); - void register_class(const char *class_name, const luaL_Reg *funcs); + Theme(const char *filename, movit::ResourcePool *resource_pool, unsigned num_cards); std::pair> get_chain(unsigned num, float t, unsigned width, unsigned height); - void set_input_textures(int signal_num, GLuint tex_y, GLuint tex_cbcr) { - input_textures[signal_num].tex_y = tex_y; - input_textures[signal_num].tex_cbcr = tex_cbcr; + void set_input_textures(int signal_num, GLuint tex_y, GLuint tex_cbcr, GLuint width, GLuint height) { + auto &tex = input_textures[signal_num]; + tex.tex_y = tex_y; + tex.tex_cbcr = tex_cbcr; + tex.width = width; + tex.height = height; } int get_num_channels() { return num_channels; } + std::string get_channel_name(unsigned channel); + bool get_supports_set_wb(unsigned channel); + void set_wb(unsigned channel, double r, double g, double b); std::vector get_transition_names(float t); @@ -44,13 +62,18 @@ public: void channel_clicked(int preview_num); private: + void register_class(const char *class_name, const luaL_Reg *funcs); + std::mutex m; lua_State *L; movit::ResourcePool *resource_pool; struct { GLuint tex_y = 0, tex_cbcr = 0; - } input_textures[16]; // FIXME + GLuint width = WIDTH, height = HEIGHT; + } input_textures[MAX_CARDS]; int num_channels; + unsigned num_cards; + std::set signals_warned_about; }; class LiveInputWrapper {