X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fsubtitle_content.h;h=7278b540892681fecff8a9d038c04970b3a79700;hb=58dce923b9d438a27ce1cd7e3125370f74d46e3a;hp=6665f563af4a0496ce9826f17dda7fad80b2b9c5;hpb=4593ab6ba39ff188bcf57ef5e69d0c69f454e0b6;p=dcpomatic.git diff --git a/src/lib/subtitle_content.h b/src/lib/subtitle_content.h index 6665f563a..7278b5408 100644 --- a/src/lib/subtitle_content.h +++ b/src/lib/subtitle_content.h @@ -41,8 +41,12 @@ public: static int const FONTS; static int const COLOUR; static int const OUTLINE; - static int const OUTLINE_COLOUR; + static int const SHADOW; + static int const EFFECT_COLOUR; static int const LINE_SPACING; + static int const FADE_IN; + static int const FADE_OUT; + static int const OUTLINE_WIDTH; }; /** @class SubtitleContent @@ -59,6 +63,7 @@ public: void as_xml (xmlpp::Node *) const; std::string identifier () const; + void use_template (boost::shared_ptr c); void add_font (boost::shared_ptr font); @@ -69,6 +74,14 @@ public: void set_x_scale (double); void set_y_scale (double); void set_language (std::string language); + void set_colour (dcp::Colour); + void set_outline (bool); + void set_shadow (bool); + void set_effect_colour (dcp::Colour); + void set_line_spacing (double s); + void set_fade_in (ContentTime); + void set_fade_out (ContentTime); + void set_outline_width (int); bool use () const { boost::mutex::scoped_lock lm (_mutex); @@ -110,34 +123,46 @@ public: return _language; } - void set_colour (dcp::Colour); - dcp::Colour colour () const { boost::mutex::scoped_lock lm (_mutex); return _colour; } - void set_outline (bool); - bool outline () const { boost::mutex::scoped_lock lm (_mutex); return _outline; } - void set_outline_colour (dcp::Colour); - - dcp::Colour outline_colour () const { + bool shadow () const { boost::mutex::scoped_lock lm (_mutex); - return _outline_colour; + return _shadow; } - void set_line_spacing (double s); + dcp::Colour effect_colour () const { + boost::mutex::scoped_lock lm (_mutex); + return _effect_colour; + } double line_spacing () const { boost::mutex::scoped_lock lm (_mutex); return _line_spacing; } + ContentTime fade_in () const { + boost::mutex::scoped_lock lm (_mutex); + return _fade_in; + } + + ContentTime fade_out () const { + boost::mutex::scoped_lock lm (_mutex); + return _fade_out; + } + + int outline_width () const { + boost::mutex::scoped_lock lm (_mutex); + return _outline_width; + } + static boost::shared_ptr from_xml (Content* parent, cxml::ConstNodePtr, int version); protected: @@ -151,6 +176,8 @@ private: void font_changed (); void connect_to_fonts (); + std::list _font_connections; + bool _use; bool _burn; /** x offset for placing subtitles, as a proportion of the container width; @@ -168,10 +195,13 @@ private: std::list > _fonts; dcp::Colour _colour; bool _outline; - dcp::Colour _outline_colour; - std::list _font_connections; + bool _shadow; + dcp::Colour _effect_colour; /** scaling factor for line spacing; 1 is "standard", < 1 is closer together, > 1 is further apart */ double _line_spacing; + ContentTime _fade_in; + ContentTime _fade_out; + int _outline_width; }; #endif