X-Git-Url: https://git.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fffmpeg_file_encoder.h;h=fd716d47c4a3f980b7cc7d057b41e29c65bdafd8;hp=63826e2d5169bbe26298d910132f17955b8d440c;hb=59209af1e2d73334ff7dfe6c7da465293dc24c0b;hpb=f41310384889e4cfb6e709d098b316e212d8bf22 diff --git a/src/lib/ffmpeg_file_encoder.h b/src/lib/ffmpeg_file_encoder.h index 63826e2d5..fd716d47c 100644 --- a/src/lib/ffmpeg_file_encoder.h +++ b/src/lib/ffmpeg_file_encoder.h @@ -18,17 +18,36 @@ */ + #ifndef DCPOMATIC_FFMPEG_FILE_ENCODER_H #define DCPOMATIC_FFMPEG_FILE_ENCODER_H + +#include "audio_mapping.h" +#include "dcpomatic_time.h" #include "encoder.h" #include "event_history.h" -#include "audio_mapping.h" #include "log.h" +#include +#include +LIBDCP_DISABLE_WARNINGS extern "C" { #include #include } +LIBDCP_ENABLE_WARNINGS + + +class ExportAudioStream; + + +enum class ExportFormat +{ + PRORES_HQ, + H264_AAC, + SUBTITLES_DCP +}; + class FFmpegFileEncoder { @@ -38,15 +57,17 @@ public: int video_frame_rate, int audio_frame_rate, int channels, - boost::shared_ptr log, ExportFormat, + bool audio_stream_per_channel, int x264_crf, boost::filesystem::path output ); - void video (boost::shared_ptr, DCPTime); - void audio (boost::shared_ptr); - void subtitle (PlayerText, DCPTimePeriod); + ~FFmpegFileEncoder (); + + void video (std::shared_ptr, dcpomatic::DCPTime); + void audio (std::shared_ptr); + void subtitle (PlayerText, dcpomatic::DCPTimePeriod); void flush (); @@ -61,16 +82,15 @@ private: static void buffer_free(void* opaque, uint8_t* data); void buffer_free2(uint8_t* data); - AVCodec* _video_codec; - AVCodecContext* _video_codec_context; - AVCodec* _audio_codec; - AVCodecContext* _audio_codec_context; - AVFormatContext* _format_context; - AVStream* _video_stream; - AVStream* _audio_stream; + AVCodec const * _video_codec = nullptr; + AVCodecContext* _video_codec_context = nullptr; + std::vector> _audio_streams; + bool _audio_stream_per_channel; + AVFormatContext* _format_context = nullptr; + AVStream* _video_stream = nullptr; AVPixelFormat _pixel_format; AVSampleFormat _sample_format; - AVDictionary* _video_options; + AVDictionary* _video_options = nullptr; std::string _video_codec_name; std::string _audio_codec_name; int _audio_channels; @@ -79,17 +99,19 @@ private: dcp::Size _video_frame_size; int _video_frame_rate; int _audio_frame_rate; - boost::shared_ptr _log; - boost::shared_ptr _pending_audio; + int64_t _audio_frames = 0; + + std::shared_ptr _pending_audio; /** Store of shared_ptr to keep them alive whilst raw pointers into their data have been passed to FFmpeg. */ - std::map > _pending_images; + std::map> _pending_images; + boost::mutex _pending_images_mutex; static int _video_stream_index; - static int _audio_stream_index; + static int _audio_stream_index_base; }; #endif