X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=mixer.h;h=a94cf922fce2b0600521caef8ff87b01ff1939cb;hb=9c824f7164eeecaa1aa904d69c5bb64fb3a6a27b;hp=9b631e4766071d35e6f0d215cd3f4442f46cdf2e;hpb=3ed9b0fbb73071284aa7fa221ce0373d2dadbc85;p=nageru diff --git a/mixer.h b/mixer.h index 9b631e4..a94cf92 100644 --- a/mixer.h +++ b/mixer.h @@ -9,13 +9,16 @@ #include #include -#include "bmusb.h" +#include "bmusb/bmusb.h" #include "h264encode.h" #include "pbo_frame_allocator.h" #include "ref_counted_frame.h" #include "ref_counted_gl_sync.h" #include "theme.h" #include "resampler.h" +#include "timebase.h" +#include "httpd.h" +#include "ebu_r128_proc.h" #define NUM_CARDS 2 @@ -78,9 +81,15 @@ public: output_channel[output].set_frame_ready_callback(callback); } + typedef std::function audio_level_callback_t; + void set_audio_level_callback(audio_level_callback_t callback) + { + audio_level_callback = callback; + } + std::vector get_transition_names() { - return theme->get_transition_names(frame / 60.0); + return theme->get_transition_names(pts()); } private: @@ -91,6 +100,9 @@ private: void thread_func(); void subsample_chroma(GLuint src_tex, GLuint dst_dst); void release_display_frame(DisplayFrame *frame); + double pts() { return double(pts_int) / TIMEBASE; } + + HTTPD httpd; QSurface *mixer_surface, *h264_encoder_surface; std::unique_ptr resource_pool; @@ -102,7 +114,7 @@ private: // Effects part of . Owned by . movit::FlatInput *display_input; - int frame = 0; + int64_t pts_int = 0; // In TIMEBASE units. std::mutex bmusb_mutex; struct CaptureCard { @@ -114,11 +126,16 @@ private: QOpenGLContext *context; bool new_data_ready = false; // Whether new_frame and new_frame_audio contains anything. + bool should_quit = false; RefCountedFrame new_frame; GLsync new_data_ready_fence; // Whether new_frame is ready for rendering. std::vector new_frame_audio; std::condition_variable new_data_ready_changed; // Set whenever new_data_ready is changed. - Resampler *resampler = nullptr; + unsigned dropped_frames = 0; // Before new_frame. + + std::mutex audio_mutex; + std::unique_ptr resampler; // Under audio_mutex. + int last_timecode = -1; // Unwrapped. }; CaptureCard cards[NUM_CARDS]; // protected by @@ -145,6 +162,12 @@ private: std::thread mixer_thread; bool should_quit = false; + + audio_level_callback_t audio_level_callback = nullptr; + Ebu_r128_proc r128; + + // TODO: Implement oversampled peak detection. + float peak = 0.0f; }; extern Mixer *global_mixer;