2 Copyright (C) 2013-2016 Carl Hetherington <cth@carlh.net>
4 This file is part of DCP-o-matic.
6 DCP-o-matic is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 DCP-o-matic is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with DCP-o-matic. If not, see <http://www.gnu.org/licenses/>.
21 #ifndef DCPOMATIC_SUBTITLE_CONTENT_H
22 #define DCPOMATIC_SUBTITLE_CONTENT_H
24 #include "content_part.h"
25 #include <libcxml/cxml.h>
26 #include <dcp/types.h>
27 #include <boost/signals2.hpp>
31 class SubtitleContentProperty
34 static int const X_OFFSET;
35 static int const Y_OFFSET;
36 static int const X_SCALE;
37 static int const Y_SCALE;
39 static int const BURN;
40 static int const LANGUAGE;
41 static int const FONTS;
42 static int const COLOUR;
43 static int const OUTLINE;
44 static int const SHADOW;
45 static int const EFFECT_COLOUR;
46 static int const LINE_SPACING;
49 /** @class SubtitleContent
50 * @brief Description of how some subtitle content should be presented.
52 * There are `image' subtitles (bitmaps) and `text' subtitles (plain text),
53 * and not all of the settings in this class correspond to both types.
55 class SubtitleContent : public ContentPart
58 SubtitleContent (Content* parent);
59 SubtitleContent (Content* parent, std::vector<boost::shared_ptr<Content> >);
61 void as_xml (xmlpp::Node *) const;
62 std::string identifier () const;
64 void add_font (boost::shared_ptr<Font> font);
68 void set_x_offset (double);
69 void set_y_offset (double);
70 void set_x_scale (double);
71 void set_y_scale (double);
72 void set_language (std::string language);
75 boost::mutex::scoped_lock lm (_mutex);
80 boost::mutex::scoped_lock lm (_mutex);
84 double x_offset () const {
85 boost::mutex::scoped_lock lm (_mutex);
89 double y_offset () const {
90 boost::mutex::scoped_lock lm (_mutex);
94 double x_scale () const {
95 boost::mutex::scoped_lock lm (_mutex);
99 double y_scale () const {
100 boost::mutex::scoped_lock lm (_mutex);
104 std::list<boost::shared_ptr<Font> > fonts () const {
105 boost::mutex::scoped_lock lm (_mutex);
109 std::string language () const {
110 boost::mutex::scoped_lock lm (_mutex);
114 void set_colour (dcp::Colour);
116 dcp::Colour colour () const {
117 boost::mutex::scoped_lock lm (_mutex);
121 void set_outline (bool);
123 bool outline () const {
124 boost::mutex::scoped_lock lm (_mutex);
128 void set_shadow (bool);
130 bool shadow () const {
131 boost::mutex::scoped_lock lm (_mutex);
135 void set_effect_colour (dcp::Colour);
137 dcp::Colour effect_colour () const {
138 boost::mutex::scoped_lock lm (_mutex);
139 return _effect_colour;
142 void set_line_spacing (double s);
144 double line_spacing () const {
145 boost::mutex::scoped_lock lm (_mutex);
146 return _line_spacing;
149 static boost::shared_ptr<SubtitleContent> from_xml (Content* parent, cxml::ConstNodePtr, int version);
152 /** subtitle language (e.g. "German") or empty if it is not known */
153 std::string _language;
156 friend struct ffmpeg_pts_offset_test;
158 SubtitleContent (Content* parent, cxml::ConstNodePtr, int version);
159 void font_changed ();
160 void connect_to_fonts ();
164 /** x offset for placing subtitles, as a proportion of the container width;
165 * +ve is further right, -ve is further left.
168 /** y offset for placing subtitles, as a proportion of the container height;
169 * +ve is further down the frame, -ve is further up.
172 /** x scale factor to apply to subtitles */
174 /** y scale factor to apply to subtitles */
176 std::list<boost::shared_ptr<Font> > _fonts;
180 dcp::Colour _effect_colour;
181 std::list<boost::signals2::connection> _font_connections;
182 /** scaling factor for line spacing; 1 is "standard", < 1 is closer together, > 1 is further apart */
183 double _line_spacing;