X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=mixer.h;h=289ce45c9b5542da424942b4205ec825605d5848;hb=e284d1c7a2e18ee7e4aea082c4a57a3504a0f5e8;hp=940dc1308c04445c166b3956aeda6b36cbaa3287;hpb=b68d8a25951faf5b967b7a35fa0a363b4b68fbc0;p=nageru diff --git a/mixer.h b/mixer.h index 940dc13..289ce45 100644 --- a/mixer.h +++ b/mixer.h @@ -403,6 +403,15 @@ public: return httpd.get_num_connected_clients(); } + std::vector get_theme_menu() { return theme->get_theme_menu(); } + + void theme_menu_entry_clicked(int lua_ref) { return theme->theme_menu_entry_clicked(lua_ref); } + + void set_theme_menu_callback(std::function callback) + { + theme->set_theme_menu_callback(callback); + } + private: struct CaptureCard; @@ -478,6 +487,15 @@ private: CardType type; std::unique_ptr output; + // CEF only delivers frames when it actually has a change. + // If we trim the queue for latency reasons, we could thus + // end up in a situation trimming a frame that was meant to + // be displayed for a long time, which is really suboptimal. + // Thus, if we drop the last frame we have, may_have_dropped_last_frame + // is set to true, and the next starvation event will trigger + // us requestin a CEF repaint. + bool is_cef_capture, may_have_dropped_last_frame = false; + // If this card is used for output (ie., output_card_index points to it), // it cannot simultaneously be uesd for capture, so gets replaced // by a FakeCapture. However, since reconstructing the real capture object