X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=mixer.h;h=f50eb58db5560f620b2fcdb1cc9097f4b6c5d1cb;hb=65d716be70e6295628dfa5bb0a72f3429b9696ba;hp=76aec682c5d71773c7d3909de60ed2d9a58a76a8;hpb=5c8dc09f89df0f25434bcefc9102438d2b491df2;p=nageru diff --git a/mixer.h b/mixer.h index 76aec68..f50eb58 100644 --- a/mixer.h +++ b/mixer.h @@ -34,6 +34,7 @@ #include "timebase.h" #include "stereocompressor.h" #include "filter.h" +#include "input_state.h" class H264Encoder; class QSurface; @@ -102,7 +103,7 @@ public: typedef std::function audio_level_callback_t; + float gain_staging_db)> audio_level_callback_t; void set_audio_level_callback(audio_level_callback_t callback) { audio_level_callback = callback; @@ -168,6 +169,24 @@ public: compressor_enabled = enabled; } + void set_gain_staging_db(float gain_db) + { + std::unique_lock lock(level_compressor_mutex); + level_compressor_enabled = false; + gain_staging_db = gain_db; + } + + void set_gain_staging_auto(bool enabled) + { + std::unique_lock lock(level_compressor_mutex); + level_compressor_enabled = enabled; + } + + void schedule_cut() + { + should_cut = true; + } + void reset_meters(); private: @@ -210,7 +229,8 @@ private: bool should_quit = false; RefCountedFrame new_frame; int64_t new_frame_length; // In TIMEBASE units. - unsigned new_frame_field; // Which field (0 or 1) of the frame to use. + bool new_frame_interlaced; + unsigned new_frame_field; // Which field (0 or 1) of the frame to use. Always 0 for progressive. GLsync new_data_ready_fence; // Whether new_frame is ready for rendering. std::condition_variable new_data_ready_changed; // Set whenever new_data_ready is changed. unsigned dropped_frames = 0; // Before new_frame. @@ -226,7 +246,7 @@ private: }; CaptureCard cards[MAX_CARDS]; // protected by - RefCountedFrame bmusb_current_rendering_frame[MAX_CARDS]; + InputState input_state; class OutputChannel { public: @@ -250,9 +270,11 @@ private: std::thread mixer_thread; std::thread audio_thread; std::atomic should_quit{false}; + std::atomic should_cut{false}; audio_level_callback_t audio_level_callback = nullptr; - Ebu_r128_proc r128; + std::mutex compressor_mutex; + Ebu_r128_proc r128; // Under compressor_mutex. Resampler peak_resampler; std::atomic peak{0.0f}; @@ -261,8 +283,10 @@ private: std::atomic locut_cutoff_hz; // First compressor; takes us up to about -12 dBFS. - StereoCompressor level_compressor; - float last_gain_staging_db = 0.0f; + std::mutex level_compressor_mutex; + StereoCompressor level_compressor; // Under compressor_mutex. Used to set/override gain_staging_db if . + float gain_staging_db = 0.0f; // Under compressor_mutex. + bool level_compressor_enabled = true; // Under compressor_mutex. static constexpr float ref_level_dbfs = -14.0f;