More automated renaming.
[dcpomatic.git] / src / lib / ffmpeg_encoder.h
index b5715e514f23e5fd03c20f778e398148bf64cd04..b1d07eb7f65bdeff0ebaf414be6a29afbffcf6ac 100644 (file)
 
 #include "encoder.h"
 #include "event_history.h"
+#include "audio_mapping.h"
 extern "C" {
 #include <libavcodec/avcodec.h>
 #include <libavformat/avformat.h>
 }
+#include <boost/thread/condition.hpp>
+
+class Butler;
 
 class FFmpegEncoder : public Encoder
 {
@@ -37,7 +41,7 @@ public:
                FORMAT_H264
        };
 
-       FFmpegEncoder (boost::shared_ptr<const Film> film, boost::weak_ptr<Job> job, boost::filesystem::path output, Format format);
+       FFmpegEncoder (boost::shared_ptr<const Film> film, boost::weak_ptr<Job> job, boost::filesystem::path output, Format format, bool mixdown_to_stereo);
 
        void go ();
 
@@ -49,15 +53,30 @@ public:
 
 private:
        void video (boost::shared_ptr<PlayerVideo>, DCPTime);
-       void audio (boost::shared_ptr<AudioBuffers>, DCPTime);
-       void subtitle (PlayerSubtitles, DCPTimePeriod);
+       void audio (boost::shared_ptr<AudioBuffers>);
+       void subtitle (PlayerText, DCPTimePeriod);
+
+       void setup_video ();
+       void setup_audio ();
+
+       void audio_frame (int size);
 
-       AVCodecContext* _codec_context;
+       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;
        AVPixelFormat _pixel_format;
-       AVDictionary* _options;
-       std::string _codec_name;
+       AVSampleFormat _sample_format;
+       AVDictionary* _video_options;
+       std::string _video_codec_name;
+       std::string _audio_codec_name;
+       int _output_audio_channels;
 
        mutable boost::mutex _mutex;
        DCPTime _last_time;
@@ -65,6 +84,22 @@ private:
        EventHistory _history;
 
        boost::filesystem::path _output;
+
+       boost::shared_ptr<AudioBuffers> _pending_audio;
+
+       mutable boost::mutex _queue_mutex;
+       boost::condition _queue_full;
+       std::list<std::pair<boost::shared_ptr<PlayerVideo>, DCPTime> > _queue;
+
+       boost::shared_ptr<Butler> _butler;
+
+       /** Store of shared_ptr<Image> to keep them alive whilst raw pointers into
+           their data have been passed to FFmpeg.
+       */
+       std::map<uint8_t*, boost::shared_ptr<const Image> > _pending_images;
+
+       static int _video_stream_index;
+       static int _audio_stream_index;
 };
 
 #endif