projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
New DCPTime/ContentTime types.
[dcpomatic.git]
/
src
/
lib
/
playlist.h
diff --git
a/src/lib/playlist.h
b/src/lib/playlist.h
index 1d69c34baee71bde82ee950cf9f5854e88f0fbf9..35709f109d2bf4bb4cbcbd725f61bbce7f7bf3ae 100644
(file)
--- a/
src/lib/playlist.h
+++ b/
src/lib/playlist.h
@@
-25,12
+25,13
@@
#include <boost/enable_shared_from_this.hpp>
#include "ffmpeg_content.h"
#include "audio_mapping.h"
#include <boost/enable_shared_from_this.hpp>
#include "ffmpeg_content.h"
#include "audio_mapping.h"
+#include "util.h"
class Content;
class FFmpegContent;
class FFmpegDecoder;
class Content;
class FFmpegContent;
class FFmpegDecoder;
-class ImageMagickContent;
-class ImageMagickDecoder;
+class
Still
ImageMagickContent;
+class
Still
ImageMagickDecoder;
class SndfileContent;
class SndfileDecoder;
class Job;
class SndfileContent;
class SndfileDecoder;
class Job;
@@
-56,28
+57,30
@@
public:
~Playlist ();
void as_xml (xmlpp::Node *);
~Playlist ();
void as_xml (xmlpp::Node *);
- void set_from_xml (boost::shared_ptr<const Film>, boost::shared_ptr<const cxml::Node>);
+ void set_from_xml (boost::shared_ptr<const Film>, boost::shared_ptr<const cxml::Node>
, int
);
void add (boost::shared_ptr<Content>);
void remove (boost::shared_ptr<Content>);
void add (boost::shared_ptr<Content>);
void remove (boost::shared_ptr<Content>);
+ void remove (ContentList);
+ void move_earlier (boost::shared_ptr<Content>);
+ void move_later (boost::shared_ptr<Content>);
bool has_subtitles () const;
bool has_subtitles () const;
- typedef std::vector<boost::shared_ptr<Content> > ContentList;
-
ContentList content () const;
std::string video_identifier () const;
ContentList content () const;
std::string video_identifier () const;
- Time length () const;
+
DCP
Time length () const;
int best_dcp_frame_rate () 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 ();
void set_sequence_video (bool);
void maybe_sequence_video ();
- void repeat (
std::list<boost::shared_ptr<Content> >
, int);
+ void repeat (
ContentList
, int);
mutable boost::signals2::signal<void ()> Changed;
/** Third parameter is true if signals are currently being emitted frequently */
mutable boost::signals2::signal<void ()> Changed;
/** Third parameter is true if signals are currently being emitted frequently */
@@
-87,6
+90,7
@@
private:
void content_changed (boost::weak_ptr<Content>, int, bool);
void reconnect ();
void content_changed (boost::weak_ptr<Content>, int, bool);
void reconnect ();
+ /** List of content. Kept sorted in position order. */
ContentList _content;
bool _sequence_video;
bool _sequencing_video;
ContentList _content;
bool _sequence_video;
bool _sequencing_video;