X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fsubtitle_decoder.h;h=317755107abaca3b6445c972ea56ae68c84aa6b2;hb=504c63b3d62038bc486ca8a09e77fbb403907edd;hp=142cfa42b766b0813fb1570d530268d886beee2c;hpb=3e12c68dc0451e73b5bc1a84d1d70f4999f7b4b5;p=dcpomatic.git diff --git a/src/lib/subtitle_decoder.h b/src/lib/subtitle_decoder.h index 142cfa42b..317755107 100644 --- a/src/lib/subtitle_decoder.h +++ b/src/lib/subtitle_decoder.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2016 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 @@ -20,40 +20,51 @@ #ifndef DCPOMATIC_SUBTITLE_DECODER_H #define DCPOMATIC_SUBTITLE_DECODER_H -#include #include "decoder.h" #include "rect.h" #include "types.h" #include "content_subtitle.h" +#include -class Film; -class DCPTimedSubtitle; class Image; -class SubtitleDecoder : public virtual Decoder +class SubtitleDecoder { public: - SubtitleDecoder (boost::shared_ptr); + /** Second parameter to the _during functions is true if we + * want only subtitles that start during the period, + * otherwise we want subtitles that overlap the period. + */ + SubtitleDecoder ( + Decoder* parent, + boost::shared_ptr, + boost::function (ContentTimePeriod, bool)> image_subtitles_during, + boost::function (ContentTimePeriod, bool)> text_subtitles_during + ); - std::list get_image_subtitles (ContentTimePeriod period, bool starting); - std::list get_text_subtitles (ContentTimePeriod period, bool starting); + std::list get_image_subtitles (ContentTimePeriod period, bool starting, bool accurate); + std::list get_text_subtitles (ContentTimePeriod period, bool starting, bool accurate); -protected: void seek (ContentTime, bool); - + void image_subtitle (ContentTimePeriod period, boost::shared_ptr, dcpomatic::Rect); - void text_subtitle (std::list); + void text_subtitle (ContentTimePeriod period, std::list); + + boost::shared_ptr content () const { + return _subtitle_content; + } +private: + Decoder* _parent; std::list _decoded_image_subtitles; std::list _decoded_text_subtitles; + boost::shared_ptr _subtitle_content; -private: template - std::list get (std::list const & subs, ContentTimePeriod period, bool starting); + std::list get (std::list const & subs, std::list const & sp, ContentTimePeriod period, bool starting, bool accurate); - virtual std::list subtitles_during (ContentTimePeriod, bool starting) const = 0; - - boost::shared_ptr _subtitle_content; + boost::function (ContentTimePeriod, bool)> _image_subtitles_during; + boost::function (ContentTimePeriod, bool)> _text_subtitles_during; }; #endif