X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=theme.h;h=91c5c2e1a11deb2f25229104d4ae581e78f7d91d;hb=b987f5b45720dcaf6582d1b9f9f7c18537df47ab;hp=a5ecebc5d8ba3746733a162383c3bfd82daac216;hpb=a98732df9454028ddaa54a9d07b5d7513767bfe9;p=nageru diff --git a/theme.h b/theme.h index a5ecebc..91c5c2e 100644 --- a/theme.h +++ b/theme.h @@ -2,9 +2,9 @@ #define _THEME_H 1 #include -#include -#include +#include #include +#include #include #include #include @@ -16,6 +16,8 @@ #include #include "defs.h" +#include "input_state.h" +#include "ref_counted_frame.h" namespace movit { class ResourcePool; @@ -23,8 +25,6 @@ struct ImageFormat; struct YCbCrFormat; } // namespace movit -#define MAX_CARDS 16 - class NonBouncingYCbCrInput : public movit::YCbCrInput { public: NonBouncingYCbCrInput(const movit::ImageFormat &image_format, @@ -38,22 +38,27 @@ public: class Theme { public: - Theme(const char *filename, movit::ResourcePool *resource_pool, unsigned num_cards); + Theme(const std::string &filename, const std::vector &search_dirs, movit::ResourcePool *resource_pool, unsigned num_cards); + ~Theme(); - std::pair> - get_chain(unsigned num, float t, unsigned width, unsigned height); + struct Chain { + movit::EffectChain *chain; + std::function setup_chain; - 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; } + // May have duplicates. + std::vector input_frames; + }; + + Chain get_chain(unsigned num, float t, unsigned width, unsigned height, InputState input_state); + + int get_num_channels() const { return num_channels; } + int map_signal(int signal_num); + void set_signal_mapping(int signal_num, int card_num); std::string get_channel_name(unsigned channel); + int get_channel_signal(unsigned channel); bool get_supports_set_wb(unsigned channel); void set_wb(unsigned channel, double r, double g, double b); + std::string get_channel_color(unsigned channel); std::vector get_transition_names(float t); @@ -61,35 +66,43 @@ public: void transition_clicked(int transition_num, float t); void channel_clicked(int preview_num); + movit::ResourcePool *get_resource_pool() const { return resource_pool; } + private: void register_class(const char *class_name, const luaL_Reg *funcs); std::mutex m; - lua_State *L; + lua_State *L; // Protected by . + const InputState *input_state; // Protected by . Only set temporarily, during chain setup. movit::ResourcePool *resource_pool; - struct { - GLuint tex_y = 0, tex_cbcr = 0; - GLuint width = WIDTH, height = HEIGHT; - } input_textures[MAX_CARDS]; int num_channels; unsigned num_cards; - std::set signals_warned_about; + + std::mutex map_m; + std::map signal_to_card_mapping; // Protected by . + + friend class LiveInputWrapper; }; class LiveInputWrapper { public: - LiveInputWrapper(Theme *theme, movit::EffectChain *chain, bool override_bounce); + LiveInputWrapper(Theme *theme, movit::EffectChain *chain, bool override_bounce, bool deinterlace); void connect_signal(int signal_num); - movit::YCbCrInput *get_input() const + movit::Effect *get_effect() const { - return input; + if (deinterlace) { + return deinterlace_effect; + } else { + return inputs[0]; + } } private: Theme *theme; // Not owned by us. - movit::YCbCrInput *input; // Owned by the chain. - int connected_signal_num = 0; + std::vector inputs; // Multiple ones if deinterlacing. Owned by the chain. + movit::Effect *deinterlace_effect = nullptr; // Owned by the chain. + bool deinterlace; }; #endif // !defined(_THEME_H)