X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Ftext_decoder.h;h=96b335de14397ac1c9644ad4feb7dd3e150ee615;hb=fcba100f0dfd1d4214291abb76f22ebd696c24d4;hp=d9d351d92dd0286ac879aad61574344f13ea25c0;hpb=d7ac100c0eb1b5efdcfbec59be870fd869252840;p=dcpomatic.git diff --git a/src/lib/text_decoder.h b/src/lib/text_decoder.h index d9d351d92..96b335de1 100644 --- a/src/lib/text_decoder.h +++ b/src/lib/text_decoder.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2017 Carl Hetherington + Copyright (C) 2013-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,57 +18,62 @@ */ -#ifndef DCPOMATIC_SUBTITLE_DECODER_H -#define DCPOMATIC_SUBTITLE_DECODER_H + +#ifndef DCPOMATIC_CAPTION_DECODER_H +#define DCPOMATIC_CAPTION_DECODER_H + #include "decoder.h" #include "rect.h" #include "types.h" -#include "content_subtitle.h" +#include "content_text.h" #include "decoder_part.h" #include #include + namespace sub { class Subtitle; } class Image; + class TextDecoder : public DecoderPart { public: TextDecoder ( Decoder* parent, - boost::shared_ptr, - boost::shared_ptr log, - ContentTime first + std::shared_ptr, + dcpomatic::ContentTime first ); - ContentTime position () const { + boost::optional position (std::shared_ptr) const override { return _position; } - void emit_image_start (ContentTime from, boost::shared_ptr image, dcpomatic::Rect rect); - void emit_text_start (ContentTime from, std::list s); - void emit_text_start (ContentTime from, sub::Subtitle const & subtitle); - void emit_text (ContentTimePeriod period, std::list s); - void emit_text (ContentTimePeriod period, sub::Subtitle const & subtitle); - void emit_stop (ContentTime to); + void emit_bitmap_start (ContentBitmapText const& bitmap); + void emit_bitmap (dcpomatic::ContentTimePeriod period, std::shared_ptr image, dcpomatic::Rect rect); + void emit_plain_start (dcpomatic::ContentTime from, std::list s); + void emit_plain_start (dcpomatic::ContentTime from, sub::Subtitle const & subtitle); + void emit_plain (dcpomatic::ContentTimePeriod period, std::list s); + void emit_plain (dcpomatic::ContentTimePeriod period, sub::Subtitle const & subtitle); + void emit_stop (dcpomatic::ContentTime to); - void seek (); + void seek () override; - boost::shared_ptr content () const { + std::shared_ptr content () const { return _content; } - boost::signals2::signal ImageStart; - boost::signals2::signal TextStart; - boost::signals2::signal Stop; + boost::signals2::signal BitmapStart; + boost::signals2::signal PlainStart; + boost::signals2::signal Stop; private: - boost::shared_ptr _content; - ContentTime _position; + std::shared_ptr _content; + boost::optional _position; }; + #endif