X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fsubtitle_string.h;h=8e798d8ec6fdcb19ebe638efcf7dbba41d2e2ea8;hb=6af628a0404e7135cb77cfa6d49a8419c883f2bf;hp=b16f764bb0ea6c285f07562a37338a3ee902d7af;hpb=d927e9b913606f4fc982885c7582ecaf0e3c5a1a;p=libdcp.git diff --git a/src/subtitle_string.h b/src/subtitle_string.h index b16f764b..8e798d8e 100644 --- a/src/subtitle_string.h +++ b/src/subtitle_string.h @@ -39,6 +39,7 @@ #define LIBDCP_SUBTITLE_STRING_H #include "types.h" +#include "subtitle.h" #include "dcp_time.h" #include #include @@ -48,13 +49,14 @@ namespace dcp { /** @class SubtitleString * @brief A single line of subtitle text with all the associated attributes. */ -class SubtitleString +class SubtitleString : public Subtitle { public: SubtitleString ( boost::optional font, bool italic, bool bold, + bool underline, Colour colour, int size, float aspect_adjust, @@ -85,42 +87,18 @@ public: return _bold; } - Colour colour () const { - return _colour; + bool underline () const { + return _underline; } - Time in () const { - return _in; - } - - Time out () const { - return _out; + Colour colour () const { + return _colour; } std::string text () const { return _text; } - float h_position () const { - return _h_position; - } - - HAlign h_align () const { - return _h_align; - } - - /** @return vertical position as a proportion of the screen height from the - * vertical alignment point. - * (between 0 and 1) - */ - float v_position () const { - return _v_position; - } - - VAlign v_align () const { - return _v_align; - } - Direction direction () const { return _direction; } @@ -133,14 +111,6 @@ public: return _effect_colour; } - Time fade_up_time () const { - return _fade_up_time; - } - - Time fade_down_time () const { - return _fade_down_time; - } - int size () const { return _size; } @@ -155,23 +125,12 @@ public: return _aspect_adjust; } - void set_in (Time i) { - _in = i; + void set_font (std::string id) { + _font = id; } - void set_out (Time o) { - _out = o; - } - - void set_h_position (float p) { - _h_position = p; - } - - /** @param p New vertical position as a proportion of the screen height - * from the top (between 0 and 1) - */ - void set_v_position (float p) { - _v_position = p; + void unset_font () { + _font = boost::optional(); } void set_size (int s) { @@ -182,6 +141,22 @@ public: _aspect_adjust = a; } + void set_text (std::string t) { + _text = t; + } + + void set_colour (Colour c) { + _colour = c; + } + + void set_effect (Effect e) { + _effect = e; + } + + void set_effect_colour (Colour c) { + _effect_colour = c; + } + private: /** font ID */ boost::optional _font; @@ -189,6 +164,8 @@ private: bool _italic; /** true if the weight is bold, false for normal */ bool _bold; + /** true to enable underlining, false otherwise */ + bool _underline; /** text colour */ Colour _colour; /** Size in points as if the screen height is 11 inches, so a 72pt font @@ -196,27 +173,14 @@ private: */ int _size; float _aspect_adjust; - Time _in; - Time _out; - /** Horizontal position as a proportion of the screen width from the _h_align - * (between 0 and 1) - */ - float _h_position; - HAlign _h_align; - /** Vertical position as a proportion of the screen height from the _v_align - * (between 0 and 1) - */ - float _v_position; - VAlign _v_align; Direction _direction; std::string _text; Effect _effect; Colour _effect_colour; - Time _fade_up_time; - Time _fade_down_time; }; bool operator== (SubtitleString const & a, SubtitleString const & b); +bool operator!= (SubtitleString const & a, SubtitleString const & b); std::ostream& operator<< (std::ostream& s, SubtitleString const & sub); }