X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fsubtitle_content.h;h=b64e4787b536b1d7fec96519027155ab9312e736;hb=00ae2c28501bb757a6a45ba47ad4ecbe32412933;hp=2fc6d0fd6f89d3b00ee03d4134df9055232c2de1;hpb=249ae25148213a2ab5d76980133182e7f2521524;p=dcpomatic.git diff --git a/src/lib/subtitle_content.h b/src/lib/subtitle_content.h index 2fc6d0fd6..b64e4787b 100644 --- a/src/lib/subtitle_content.h +++ b/src/lib/subtitle_content.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2016 Carl Hetherington + Copyright (C) 2013-2018 Carl Hetherington This file is part of DCP-o-matic. @@ -40,8 +40,7 @@ public: static int const LANGUAGE; static int const FONTS; static int const COLOUR; - static int const OUTLINE; - static int const SHADOW; + static int const EFFECT; static int const EFFECT_COLOUR; static int const LINE_SPACING; static int const FADE_IN; @@ -58,7 +57,7 @@ public: class SubtitleContent : public ContentPart { public: - SubtitleContent (Content* parent); + explicit SubtitleContent (Content* parent); SubtitleContent (Content* parent, std::vector >); void as_xml (xmlpp::Node *) const; @@ -75,13 +74,17 @@ public: 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 unset_colour (); + void set_effect (dcp::Effect); + void unset_effect (); void set_effect_colour (dcp::Colour); + void unset_effect_colour (); void set_line_spacing (double s); void set_fade_in (ContentTime); + void unset_fade_in (); void set_fade_out (ContentTime); void set_outline_width (int); + void unset_fade_out (); bool use () const { boost::mutex::scoped_lock lm (_mutex); @@ -123,22 +126,17 @@ public: return _language; } - dcp::Colour colour () const { + boost::optional colour () const { boost::mutex::scoped_lock lm (_mutex); return _colour; } - bool outline () const { + boost::optional effect () const { boost::mutex::scoped_lock lm (_mutex); - return _outline; + return _effect; } - bool shadow () const { - boost::mutex::scoped_lock lm (_mutex); - return _shadow; - } - - dcp::Colour effect_colour () const { + boost::optional effect_colour () const { boost::mutex::scoped_lock lm (_mutex); return _effect_colour; } @@ -148,12 +146,12 @@ public: return _line_spacing; } - ContentTime fade_in () const { + boost::optional fade_in () const { boost::mutex::scoped_lock lm (_mutex); return _fade_in; } - ContentTime fade_out () const { + boost::optional fade_out () const { boost::mutex::scoped_lock lm (_mutex); return _fade_out; } @@ -193,14 +191,13 @@ private: /** y scale factor to apply to subtitles */ double _y_scale; std::list > _fonts; - dcp::Colour _colour; - bool _outline; - bool _shadow; - dcp::Colour _effect_colour; + boost::optional _colour; + boost::optional _effect; + boost::optional _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; + boost::optional _fade_in; + boost::optional _fade_out; int _outline_width; };