X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fplaylist.h;h=444eb9ae5ebb5ae1aac34932440025c92c3f8b43;hb=e6f28e7cda23c1ba3c49cc1bf2dc1491c2f87160;hp=e39e9f51f96aa13148a4c4b48c8066ca9c135904;hpb=56506a1993f402fe889a650faa3de2e265632498;p=dcpomatic.git diff --git a/src/lib/playlist.h b/src/lib/playlist.h index e39e9f51f..444eb9ae5 100644 --- a/src/lib/playlist.h +++ b/src/lib/playlist.h @@ -25,12 +25,13 @@ #include #include "ffmpeg_content.h" #include "audio_mapping.h" +#include "util.h" class Content; class FFmpegContent; class FFmpegDecoder; -class ImageMagickContent; -class ImageMagickDecoder; +class StillImageMagickContent; +class StillImageMagickDecoder; class SndfileContent; class SndfileDecoder; class Job; @@ -56,11 +57,13 @@ public: ~Playlist (); void as_xml (xmlpp::Node *); - void set_from_xml (boost::shared_ptr, boost::shared_ptr); + void set_from_xml (boost::shared_ptr, boost::shared_ptr, int, std::list &); void add (boost::shared_ptr); void remove (boost::shared_ptr); void remove (ContentList); + void move_earlier (boost::shared_ptr); + void move_later (boost::shared_ptr); bool has_subtitles () const; @@ -68,10 +71,11 @@ public: std::string video_identifier () const; - Time length () const; + DCPTime length () const; int best_dcp_frame_rate () const; - Time video_end () const; + DCPTime video_end () const; + FrameRateChange active_frame_rate_change (DCPTime, int dcp_frame_rate) const; void set_sequence_video (bool); void maybe_sequence_video (); @@ -86,6 +90,7 @@ private: void content_changed (boost::weak_ptr, int, bool); void reconnect (); + /** List of content. Kept sorted in position order. */ ContentList _content; bool _sequence_video; bool _sequencing_video;