Add Piece::seek().
[dcpomatic.git] / src / lib / piece.h
index dfba0f1857f3896feb2e017cc30ad4123b7006bf..56b16fb282f646b98403b9db74b70cbd12045a81 100644 (file)
@@ -24,6 +24,7 @@
 
 
 #include "audio_stream.h"
+#include "content_video.h"
 #include "dcpomatic_time.h"
 #include "frame_rate_change.h"
 #include "types.h"
@@ -32,6 +33,8 @@
 
 class Content;
 class Decoder;
+class PlayerVideo;
+struct overlap_video_test1;
 
 
 class Piece
@@ -45,23 +48,41 @@ public:
        dcpomatic::DCPTime content_video_to_dcp (Frame f) const;
        dcpomatic::DCPTime resampled_audio_to_dcp (Frame f, std::shared_ptr<const Film> film) const;
        dcpomatic::ContentTime dcp_to_content_time (dcpomatic::DCPTime t, std::shared_ptr<const Film> film) const;
-       dcpomatic::DCPTime content_time_to_dcp (dcpomatic::ContentTime t) const;
+       boost::optional<dcpomatic::DCPTime> content_time_to_dcp (std::shared_ptr<const Content> content, dcpomatic::ContentTime t) const;
+
+       void pass ();
 
        bool use_video () const;
+       VideoFrameType video_frame_type () const;
 
        FrameRateChange frame_rate_change () const {
-               return frc;
+               return _frc;
        }
 
        dcpomatic::DCPTime position () const;
+       dcpomatic::DCPTime end (std::shared_ptr<const Film> film) const;
+
+       std::shared_ptr<PlayerVideo> player_video (ContentVideo video, std::shared_ptr<const Film> film, dcp::Size container_size) const;
+
+       int resampled_audio_frame_rate (std::shared_ptr<const Film> film) const;
+       double audio_gain () const;
+       bool reference_dcp_audio () const;
+
+       std::shared_ptr<Decoder> decoder_for (std::shared_ptr<Content> content) const;
+
+       dcpomatic::DCPTime decoder_position () const;
+       bool has_text () const;
+       void seek (std::shared_ptr<const Film> film, dcpomatic::DCPTime time, bool accurate);
 
-       std::shared_ptr<Content> content;
        std::shared_ptr<Decoder> decoder;
        boost::optional<dcpomatic::DCPTimePeriod> ignore_video;
-       FrameRateChange frc;
        bool done = false;
 
 private:
+       friend struct overlap_video_test1;
+
+       std::shared_ptr<Content> _content;
+       FrameRateChange _frc;
        std::map<AudioStreamPtr, dcpomatic::DCPTime> _stream_last_push_end;
 };