Some compilers don't like x = {} where x is a boost::optional<string>
[libdcp.git] / src / subtitle_string.h
index 03d3d4f82bd59c34322ec48e7cd03301ab476371..bf9c87d9036cf32f1919872d773c2dc22afc07a8 100644 (file)
 /*
-    Copyright (C) 2012-2014 Carl Hetherington <cth@carlh.net>
+    Copyright (C) 2012-2021 Carl Hetherington <cth@carlh.net>
 
-    This program is free software; you can redistribute it and/or modify
+    This file is part of libdcp.
+
+    libdcp is free software; you can redistribute it and/or modify
     it under the terms of the GNU General Public License as published by
     the Free Software Foundation; either version 2 of the License, or
     (at your option) any later version.
 
-    This program is distributed in the hope that it will be useful,
+    libdcp is distributed in the hope that it will be useful,
     but WITHOUT ANY WARRANTY; without even the implied warranty of
     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     GNU General Public License for more details.
 
     You should have received a copy of the GNU General Public License
-    along with this program; if not, write to the Free Software
-    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-
+    along with libdcp.  If not, see <http://www.gnu.org/licenses/>.
+
+    In addition, as a special exception, the copyright holders give
+    permission to link the code of portions of this program with the
+    OpenSSL library under certain conditions as described in each
+    individual source file, and distribute linked combinations
+    including the two.
+
+    You must obey the GNU General Public License in all respects
+    for all of the code used other than OpenSSL.  If you modify
+    file(s) with this exception, you may extend this exception to your
+    version of the file(s), but you are not obligated to do so.  If you
+    do not wish to do so, delete this exception statement from your
+    version.  If you delete this exception statement from all source
+    files in the program, then also delete it here.
 */
 
+
 /** @file  src/subtitle_string.h
- *  @brief SubtitleString class.
+ *  @brief SubtitleString class
  */
 
+
 #ifndef LIBDCP_SUBTITLE_STRING_H
 #define LIBDCP_SUBTITLE_STRING_H
 
+
 #include "types.h"
+#include "subtitle.h"
 #include "dcp_time.h"
+#include <boost/optional.hpp>
 #include <string>
 
+
 namespace dcp {
 
+
 /** @class SubtitleString
  *  @brief A single line of subtitle text with all the associated attributes.
  */
-class SubtitleString
+class SubtitleString : public Subtitle
 {
 public:
+       /** @param font Font ID, or empty to use the default
+        *  @param italic true for italic text
+        *  @param bold true for bold text
+        *  @param underline true for underlined text
+        *  @param colour Colour of the text
+        *  @param size Size in points as if the screen height is 11 inches, so a 72pt font would be 1/11th of the screen height
+        *  @param aspect_adjust greater than 1 to stretch text to be wider, less than 1 to shrink text to be narrower (must be between 0.25 and 4)
+        *  @param in start time
+        *  @param out finish time
+        *  @param h_position Horizontal position as a fraction of the screen width (between 0 and 1) from h_align
+        *  @param h_align Horizontal alignment point
+        *  @param v_position Vertical position as a fraction of the screen height (between 0 and 1) from v_align
+        *  @param v_align Vertical alignment point
+        *  @param direction Direction of text
+        *  @param text The text to display
+        *  @param effect Effect to use
+        *  @param effect_colour Colour of the effect
+        *  @param fade_up_time Time to fade the text in
+        *  @param fade_down_time Time to fade the text out
+        */
        SubtitleString (
-               std::string font,
+               boost::optional<std::string> font,
                bool italic,
-               Color color,
+               bool bold,
+               bool underline,
+               Colour colour,
                int size,
+               float aspect_adjust,
                Time in,
                Time out,
+               float h_position,
+               HAlign h_align,
                float v_position,
                VAlign v_align,
+               Direction direction,
                std::string text,
                Effect effect,
-               Color effect_color,
+               Colour effect_colour,
                Time fade_up_time,
                Time fade_down_time
                );
 
-       std::string font () const {
+       /** @return font ID */
+       boost::optional<std::string> font () const {
                return _font;
        }
 
@@ -60,80 +108,108 @@ public:
                return _italic;
        }
 
-       Color color () const {
-               return _color;
+       bool bold () const {
+               return _bold;
        }
 
-       Time in () const {
-               return _in;
+       bool underline () const {
+               return _underline;
        }
 
-       Time out () const {
-               return _out;
+       Colour colour () const {
+               return _colour;
        }
 
        std::string text () const {
                return _text;
        }
 
-       float v_position () const {
-               return _v_position;
-       }
-
-       VAlign v_align () const {
-               return _v_align;
+       Direction direction () const {
+               return _direction;
        }
 
        Effect effect () const {
                return _effect;
        }
 
-       Color effect_color () const {
-               return _effect_color;
+       Colour effect_colour () const {
+               return _effect_colour;
        }
 
-       Time fade_up_time () const {
-               return _fade_up_time;
+       int size () const {
+               return _size;
        }
 
-       Time fade_down_time () const {
-               return _fade_down_time;
+       int size_in_pixels (int screen_height) const;
+
+       /** @return Aspect ratio `adjustment' of the font size.
+        *  Values greater than 1 widen each character, values less than 1 narrow each character,
+        *  and the value must be between 0.25 and 4.
+        */
+       float aspect_adjust () const {
+               return _aspect_adjust;
        }
 
-       int size () const {
-               return _size;
+       void set_font (std::string id) {
+               _font = id;
+       }
+
+       void unset_font () {
+               _font = boost::optional<std::string>();
+       }
+
+       void set_size (int s) {
+               _size = s;
+       }
+
+       void set_aspect_adjust (float a) {
+               _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;
        }
-       
-       int size_in_pixels (int screen_height) const;
 
 private:
-       /** font name */
-       std::string _font;
+       /** font ID */
+       boost::optional<std::string> _font;
        /** true if the text is italic */
        bool _italic;
+       /** true if the weight is bold, false for normal */
+       bool _bold;
+       /** true to enable underlining, false otherwise */
+       bool _underline;
        /** text colour */
-       Color _color;
+       Colour _colour;
        /** Size in points as if the screen height is 11 inches, so a 72pt font
         *  would be 1/11th of the screen height.
-        */ 
-       int _size;
-       Time _in;
-       Time _out;
-       /** Vertical position as a proportion of the screen height from the top
-        *  (between 0 and 1)
         */
-       float _v_position;
-       VAlign _v_align;
+       int _size;
+       float _aspect_adjust;
+       Direction _direction;
        std::string _text;
        Effect _effect;
-       Color _effect_color;
-       Time _fade_up_time;
-       Time _fade_down_time;
+       Colour _effect_colour;
 };
 
 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);
 
+
 }
 
+
 #endif