X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=theme.h;h=bbef35ef350d1513afc92aa8216836b13b36b937;hb=4a0187ffb4075b4d217b8d9e9c96cac548b199d8;hp=b04050e51d05a6331b21d65409adda3311a61fa0;hpb=bcdbb7bdfcfc45b34ccdf36d3950e7e0af6444bd;p=nageru diff --git a/theme.h b/theme.h index b04050e..bbef35e 100644 --- a/theme.h +++ b/theme.h @@ -9,12 +9,14 @@ #include #include #include +#include #include #include "bmusb/bmusb.h" #include "ref_counted_frame.h" #include "tweaked_inputs.h" +class CEFCapture; class FFmpegCapture; class LiveInputWrapper; struct InputState; @@ -34,7 +36,8 @@ public: movit::EffectChain *chain; std::function setup_chain; - // May have duplicates. + // FRAME_HISTORY frames for each input, in order. Will contain duplicates + // for non-interlaced inputs. std::vector input_frames; }; @@ -67,22 +70,55 @@ public: return video_inputs; } - void register_signal_connection(LiveInputWrapper *live_input, FFmpegCapture *capture) +#ifdef HAVE_CEF + // Should be called as part of HTMLInput.new() only. + void register_html_input(CEFCapture *capture) { - signal_connections.emplace_back(live_input, capture); + html_inputs.push_back(capture); } - std::vector> get_signal_connections() const + std::vector get_html_inputs() const { - return signal_connections; + return html_inputs; + } +#endif + + void register_video_signal_connection(movit::EffectChain *chain, LiveInputWrapper *live_input, FFmpegCapture *capture) + { + video_signal_connections[chain].emplace_back(VideoSignalConnection { live_input, capture }); + } + +#ifdef HAVE_CEF + void register_html_signal_connection(movit::EffectChain *chain, LiveInputWrapper *live_input, CEFCapture *capture) + { + html_signal_connections[chain].emplace_back(CEFSignalConnection { live_input, capture }); + } +#endif + + struct MenuEntry { + std::string text; + int lua_ref; + }; + std::vector get_theme_menu() { return theme_menu; } // Can be empty for no menu. + void theme_menu_entry_clicked(int lua_ref); + + // Will be invoked every time the theme sets a new menu. + // Is not invoked for a menu that exists at the time of the callback. + void set_theme_menu_callback(std::function callback) + { + theme_menu_callback = callback; } private: + void register_constants(); void register_class(const char *class_name, const luaL_Reg *funcs); + int set_theme_menu(lua_State *L); + + std::string theme_path; std::mutex m; lua_State *L; // Protected by . - const InputState *input_state; // Protected by . Only set temporarily, during chain setup. + const InputState *input_state = nullptr; // Protected by . Only set temporarily, during chain setup. movit::ResourcePool *resource_pool; int num_channels; unsigned num_cards; @@ -91,9 +127,27 @@ private: std::map signal_to_card_mapping; // Protected by . std::vector video_inputs; - std::vector> signal_connections; + struct VideoSignalConnection { + LiveInputWrapper *wrapper; + FFmpegCapture *source; + }; + std::unordered_map> + video_signal_connections; +#ifdef HAVE_CEF + std::vector html_inputs; + struct CEFSignalConnection { + LiveInputWrapper *wrapper; + CEFCapture *source; + }; + std::unordered_map> + html_signal_connections; +#endif + + std::vector theme_menu; + std::function theme_menu_callback; friend class LiveInputWrapper; + friend int ThemeMenu_set(lua_State *L); }; // LiveInputWrapper is a facade on top of an YCbCrInput, exposed to @@ -103,16 +157,16 @@ private: // the mixer, and communicates that state over to the actual YCbCrInput. class LiveInputWrapper { public: - // Note: is irrelevant for PixelFormat_8BitRGBA. + // Note: is irrelevant for PixelFormat_8BitBGRA. LiveInputWrapper(Theme *theme, movit::EffectChain *chain, bmusb::PixelFormat pixel_format, bool override_bounce, bool deinterlace); - void connect_signal(int signal_num); - void connect_signal_raw(int signal_num); + void connect_signal(int signal_num); // Must be called with the theme's lock held, since it accesses theme->input_state. + void connect_signal_raw(int signal_num, const InputState &input_state); movit::Effect *get_effect() const { if (deinterlace) { return deinterlace_effect; - } else if (pixel_format == bmusb::PixelFormat_8BitRGBA) { + } else if (pixel_format == bmusb::PixelFormat_8BitBGRA) { return rgba_inputs[0]; } else { return ycbcr_inputs[0]; @@ -122,6 +176,7 @@ public: private: Theme *theme; // Not owned by us. bmusb::PixelFormat pixel_format; + movit::YCbCrFormat input_ycbcr_format; std::vector ycbcr_inputs; // Multiple ones if deinterlacing. Owned by the chain. std::vector rgba_inputs; // Multiple ones if deinterlacing. Owned by the chain. movit::Effect *deinterlace_effect = nullptr; // Owned by the chain.