*/
-#include "decoder.h"
+#include "video_decoder.h"
namespace Magick {
class Image;
}
-class ImageMagickDecoder : public Decoder
+class ImageMagickContent;
+
+class ImageMagickDecoder : public VideoDecoder
{
public:
- ImageMagickDecoder (boost::shared_ptr<Film>, boost::shared_ptr<const Options>, Job *);
-
- float frames_per_second () const {
- return static_frames_per_second ();
- }
-
- Size native_size () const;
-
- int audio_channels () const {
- return 0;
- }
-
- int audio_sample_rate () const {
- return 0;
- }
+ ImageMagickDecoder (boost::shared_ptr<const Film>, boost::shared_ptr<const ImageMagickContent>);
- int64_t audio_channel_layout () const {
- return 0;
- }
-
- bool has_subtitles () const {
- return false;
- }
-
- static float static_frames_per_second () {
- return 24;
- }
+ /* Decoder */
-protected:
- bool pass ();
- PixelFormat pixel_format () const;
+ void pass ();
+ void seek (Time);
+ void seek_back ();
+ void seek_forward ();
+ Time next () const;
+ bool done () const;
- int time_base_numerator () const {
- return 0;
- }
+ /* VideoDecoder */
- int time_base_denominator () const {
- return 0;
- }
+ float video_frame_rate () const;
+ libdcp::Size video_size () const;
+ ContentVideoFrame video_length () const;
- int sample_aspect_ratio_numerator () const {
- /* XXX */
- return 1;
- }
+ /* ImageMagickDecoder */
- int sample_aspect_ratio_denominator () const {
- /* XXX */
- return 1;
+ boost::shared_ptr<const ImageMagickContent> content () const {
+ return _imagemagick_content;
}
private:
- Magick::Image* _magick_image;
- bool _done;
+ boost::shared_ptr<const ImageMagickContent> _imagemagick_content;
+ boost::shared_ptr<Image> _image;
+ mutable boost::optional<libdcp::Size> _video_size;
};