X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fffmpeg_file_encoder.h;h=78840d6a82ef9091de6f5b2baca8c1754dd7feea;hb=24b83514fed0683008bff23c6fd9c1d990a30b02;hp=08fc4778b4d6bb7fe2f45f3e99a5104b91b1fef3;hpb=a332bd6be323f03dad5b180fb237afe54f1bf81e;p=dcpomatic.git diff --git a/src/lib/ffmpeg_file_encoder.h b/src/lib/ffmpeg_file_encoder.h index 08fc4778b..78840d6a8 100644 --- a/src/lib/ffmpeg_file_encoder.h +++ b/src/lib/ffmpeg_file_encoder.h @@ -18,23 +18,39 @@ */ + #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 "image_store.h" #include "log.h" #include +#include +LIBDCP_DISABLE_WARNINGS extern "C" { #include #include } +LIBDCP_ENABLE_WARNINGS class ExportAudioStream; +enum class ExportFormat +{ + PRORES_4444, + PRORES_HQ, + H264_AAC, + SUBTITLES_DCP +}; + + class FFmpegFileEncoder { public: @@ -51,8 +67,8 @@ public: ~FFmpegFileEncoder (); - void video (boost::shared_ptr, dcpomatic::DCPTime); - void audio (boost::shared_ptr); + void video (std::shared_ptr, dcpomatic::DCPTime); + void audio (std::shared_ptr); void subtitle (PlayerText, dcpomatic::DCPTimePeriod); void flush (); @@ -65,18 +81,15 @@ private: void audio_frame (int size); - static void buffer_free(void* opaque, uint8_t* data); - void buffer_free2(uint8_t* data); - - AVCodec* _video_codec; - AVCodecContext* _video_codec_context; - std::vector > _audio_streams; + AVCodec const * _video_codec = nullptr; + AVCodecContext* _video_codec_context = nullptr; + std::vector> _audio_streams; bool _audio_stream_per_channel; - AVFormatContext* _format_context; - AVStream* _video_stream; + 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; @@ -86,15 +99,11 @@ private: int _video_frame_rate; int _audio_frame_rate; - int64_t _audio_frames; + int64_t _audio_frames = 0; - boost::shared_ptr _pending_audio; + 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; - boost::mutex _pending_images_mutex; + ImageStore _pending_images; static int _video_stream_index; static int _audio_stream_index_base;