/* Copyright (C) 2012 Carl Hetherington This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ /** @file src/decoder.h * @brief Parent class for decoders of content. */ #ifndef DVDOMATIC_DECODER_H #define DVDOMATIC_DECODER_H #include #include #include #include #include #include "util.h" #include "stream.h" class Job; class Options; class Image; class Log; class DelayLine; class TimedSubtitle; class Subtitle; class Film; class FilterGraph; /** @class Decoder. * @brief Parent class for decoders of content. * * These classes can be instructed run through their content * (by calling ::go), and they emit signals when video or audio data is ready for something else * to process. */ class Decoder { public: Decoder (boost::shared_ptr, boost::shared_ptr, Job *); virtual ~Decoder (); /* Methods to query our input video */ /** @return video frames per second, or 0 if unknown */ virtual float frames_per_second () const = 0; /** @return native size in pixels */ virtual Size native_size () const = 0; virtual int time_base_numerator () const = 0; virtual int time_base_denominator () const = 0; virtual int sample_aspect_ratio_numerator () const = 0; virtual int sample_aspect_ratio_denominator () const = 0; void process_begin (); virtual bool pass () = 0; void process_end (); void go (); SourceFrame video_frame () const { return _video_frame; } virtual void set_audio_stream (boost::optional); virtual void set_subtitle_stream (boost::optional); boost::optional audio_stream () const { return _audio_stream; } boost::optional subtitle_stream () const { return _subtitle_stream; } std::vector audio_streams () const { return _audio_streams; } std::vector subtitle_streams () const { return _subtitle_streams; } /** Emitted when a video frame is ready. * First parameter is the frame within the source. * Second parameter is its index within the content. * Third parameter is either 0 or a subtitle that should be on this frame. */ boost::signals2::signal, SourceFrame, boost::shared_ptr)> Video; /** Emitted when some audio data is ready */ boost::signals2::signal, int64_t)> Audio; protected: virtual PixelFormat pixel_format () const = 0; void process_video (AVFrame *); void process_audio (boost::shared_ptr); void process_subtitle (boost::shared_ptr); void repeat_last_video (); /** our Film */ boost::shared_ptr _film; /** our options */ boost::shared_ptr _opt; /** associated Job, or 0 */ Job* _job; boost::optional _audio_stream; boost::optional _subtitle_stream; std::vector _audio_streams; std::vector _subtitle_streams; private: void emit_video (boost::shared_ptr, boost::shared_ptr); void emit_audio (boost::shared_ptr); SourceFrame _video_frame; int64_t _audio_frame; std::list > _filter_graphs; DelayLine* _delay_line; int _delay_in_frames; boost::shared_ptr _timed_subtitle; boost::shared_ptr _last_image; boost::shared_ptr _last_subtitle; }; #endif