X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=mixer.h;h=45311aa42ec98af08cf7fb55719c16e3e01c0041;hb=02083dca89292d6ba95642cf8957f1cee8826313;hp=6098222c390d9b059561900f8c826aeb5f2ffcb4;hpb=4c974bd99c5730bf891f21cf905f585b2e4591f0;p=nageru diff --git a/mixer.h b/mixer.h index 6098222..45311aa 100644 --- a/mixer.h +++ b/mixer.h @@ -16,6 +16,7 @@ #include "ref_counted_gl_sync.h" #include "theme.h" #include "resampler.h" +#include "timebase.h" #define NUM_CARDS 2 @@ -80,7 +81,7 @@ public: std::vector get_transition_names() { - return theme->get_transition_names(frame / 60.0); + return theme->get_transition_names(pts()); } private: @@ -91,6 +92,7 @@ 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; } QSurface *mixer_surface, *h264_encoder_surface; std::unique_ptr resource_pool; @@ -102,7 +104,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 { @@ -119,7 +121,11 @@ private: 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