X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=mixer.h;h=a177854b46cde0229ebfcb669998afea709813b7;hb=b4f16ea9f8969a3ba14be8cd9c88cfe00d19533b;hp=f2f9f7aecef7570fe1ccb47ae8adff56ef2a76be;hpb=2c84fdec878d1144b2d615dbfb901d23e838f457;p=nageru diff --git a/mixer.h b/mixer.h index f2f9f7a..a177854 100644 --- a/mixer.h +++ b/mixer.h @@ -9,11 +9,15 @@ #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" #define NUM_CARDS 2 @@ -31,16 +35,16 @@ public: void start(); void quit(); - enum Source { - SOURCE_INPUT1, - SOURCE_INPUT2, - SOURCE_SBS, - }; - void cut(Source source); + void transition_clicked(int transition_num); + void channel_clicked(int preview_num); enum Output { OUTPUT_LIVE = 0, OUTPUT_PREVIEW, + OUTPUT_INPUT0, + OUTPUT_INPUT1, + OUTPUT_INPUT2, + OUTPUT_INPUT3, NUM_OUTPUTS }; @@ -76,10 +80,9 @@ public: output_channel[output].set_frame_ready_callback(callback); } - // Ignored for OUTPUT_LIVE. - void set_preview_size(Output output, int width, int height) + std::vector get_transition_names() { - output_channel[output].set_size(width, height); + return theme->get_transition_names(pts()); } private: @@ -90,43 +93,42 @@ 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; - std::unique_ptr chain; + std::unique_ptr theme; std::unique_ptr display_chain; - std::unique_ptr preview_chain; GLuint cbcr_program_num; // Owned by . std::unique_ptr h264_encoder; - // Effects part of . Owned by . - movit::YCbCrInput *input[NUM_CARDS]; - movit::Effect *resample_effect, *resample2_effect; - movit::Effect *padding_effect, *padding2_effect; - // Effects part of . Owned by . movit::FlatInput *display_input; - // Effects part of . Owned by . - movit::YCbCrInput *preview_input; - - Source current_source = SOURCE_INPUT1; - int frame = 0; + int64_t pts_int = 0; // In TIMEBASE units. std::mutex bmusb_mutex; struct CaptureCard { BMUSBCapture *usb; std::unique_ptr frame_allocator; - // Threading stuff - bool thread_initialized = false; + // Stuff for the OpenGL context (for texture uploading). QSurface *surface; QOpenGLContext *context; - bool new_data_ready = false; // Whether new_frame contains anything. + 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. + 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 @@ -134,10 +136,10 @@ private: class OutputChannel { public: + ~OutputChannel(); void output_frame(DisplayFrame frame); bool get_display_frame(DisplayFrame *frame); void set_frame_ready_callback(new_frame_ready_callback_t callback); - void set_size(int width, int height); // Ignored for OUTPUT_LIVE. private: friend class Mixer; @@ -148,8 +150,6 @@ private: bool has_current_frame = false, has_ready_frame = false; // protected by new_frame_ready_callback_t new_frame_ready_callback; bool has_new_frame_ready_callback = false; - - int width = 1280, height = 720; }; OutputChannel output_channel[NUM_OUTPUTS];