/*
Copyright (C) 2013-2016 Carl Hetherington <cth@carlh.net>
- This program is free software; you can redistribute it and/or modify
+ This file is part of DCP-o-matic.
+
+ DCP-o-matic 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,
+ DCP-o-matic 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 DCP-o-matic. If not, see <http://www.gnu.org/licenses/>.
*/
class SubtitleContentProperty
{
public:
- static int const SUBTITLE_X_OFFSET;
- static int const SUBTITLE_Y_OFFSET;
- static int const SUBTITLE_X_SCALE;
- static int const SUBTITLE_Y_SCALE;
- static int const USE_SUBTITLES;
- static int const BURN_SUBTITLES;
- static int const SUBTITLE_LANGUAGE;
+ static int const X_OFFSET;
+ static int const Y_OFFSET;
+ static int const X_SCALE;
+ static int const Y_SCALE;
+ static int const USE;
+ static int const BURN;
+ static int const LANGUAGE;
static int const FONTS;
- static int const SUBTITLE_VIDEO_FRAME_RATE;
- static int const SUBTITLE_COLOUR;
- static int const SUBTITLE_OUTLINE;
- static int const SUBTITLE_OUTLINE_COLOUR;
+ static int const COLOUR;
+ static int const OUTLINE;
+ static int const SHADOW;
+ static int const EFFECT_COLOUR;
+ static int const LINE_SPACING;
};
+/** @class SubtitleContent
+ * @brief Description of how some subtitle content should be presented.
+ *
+ * There are `image' subtitles (bitmaps) and `text' subtitles (plain text),
+ * and not all of the settings in this class correspond to both types.
+ */
class SubtitleContent : public ContentPart
{
public:
- SubtitleContent (Content* parent, boost::shared_ptr<const Film>);
- SubtitleContent (Content* parent, boost::shared_ptr<const Film>, cxml::ConstNodePtr, int version);
- SubtitleContent (Content* parent, boost::shared_ptr<const Film>, std::vector<boost::shared_ptr<Content> >);
+ SubtitleContent (Content* parent);
+ SubtitleContent (Content* parent, std::vector<boost::shared_ptr<Content> >);
void as_xml (xmlpp::Node *) const;
std::string identifier () const;
- bool has_image_subtitles () const {
- /* XXX */
- return true;
- }
-
void add_font (boost::shared_ptr<Font> font);
- void set_use_subtitles (bool);
- void set_burn_subtitles (bool);
- void set_subtitle_x_offset (double);
- void set_subtitle_y_offset (double);
- void set_subtitle_x_scale (double);
- void set_subtitle_y_scale (double);
- void set_subtitle_language (std::string language);
+ void set_use (bool);
+ void set_burn (bool);
+ void set_x_offset (double);
+ void set_y_offset (double);
+ void set_x_scale (double);
+ void set_y_scale (double);
+ void set_language (std::string language);
- bool use_subtitles () const {
+ bool use () const {
boost::mutex::scoped_lock lm (_mutex);
- return _use_subtitles;
+ return _use;
}
- bool burn_subtitles () const {
+ bool burn () const {
boost::mutex::scoped_lock lm (_mutex);
- return _burn_subtitles;
+ return _burn;
}
- double subtitle_x_offset () const {
+ double x_offset () const {
boost::mutex::scoped_lock lm (_mutex);
- return _subtitle_x_offset;
+ return _x_offset;
}
- double subtitle_y_offset () const {
+ double y_offset () const {
boost::mutex::scoped_lock lm (_mutex);
- return _subtitle_y_offset;
+ return _y_offset;
}
- double subtitle_x_scale () const {
+ double x_scale () const {
boost::mutex::scoped_lock lm (_mutex);
- return _subtitle_x_scale;
+ return _x_scale;
}
- double subtitle_y_scale () const {
+ double y_scale () const {
boost::mutex::scoped_lock lm (_mutex);
- return _subtitle_y_scale;
+ return _y_scale;
}
std::list<boost::shared_ptr<Font> > fonts () const {
return _fonts;
}
- std::string subtitle_language () const {
+ std::string language () const {
boost::mutex::scoped_lock lm (_mutex);
- return _subtitle_language;
+ return _language;
}
void set_colour (dcp::Colour);
return _outline;
}
- void set_outline_colour (dcp::Colour);
+ void set_shadow (bool);
+
+ bool shadow () const {
+ boost::mutex::scoped_lock lm (_mutex);
+ return _shadow;
+ }
+
+ void set_effect_colour (dcp::Colour);
- dcp::Colour outline_colour () const {
+ dcp::Colour effect_colour () const {
boost::mutex::scoped_lock lm (_mutex);
- return _outline_colour;
+ return _effect_colour;
}
+ void set_line_spacing (double s);
+
+ double line_spacing () const {
+ boost::mutex::scoped_lock lm (_mutex);
+ return _line_spacing;
+ }
+
+ static boost::shared_ptr<SubtitleContent> from_xml (Content* parent, cxml::ConstNodePtr, int version);
+
protected:
/** subtitle language (e.g. "German") or empty if it is not known */
- std::string _subtitle_language;
+ std::string _language;
private:
friend struct ffmpeg_pts_offset_test;
+
+ SubtitleContent (Content* parent, cxml::ConstNodePtr, int version);
void font_changed ();
void connect_to_fonts ();
- bool _use_subtitles;
- bool _burn_subtitles;
+ bool _use;
+ bool _burn;
/** x offset for placing subtitles, as a proportion of the container width;
* +ve is further right, -ve is further left.
*/
- double _subtitle_x_offset;
+ double _x_offset;
/** y offset for placing subtitles, as a proportion of the container height;
* +ve is further down the frame, -ve is further up.
*/
- double _subtitle_y_offset;
+ double _y_offset;
/** x scale factor to apply to subtitles */
- double _subtitle_x_scale;
+ double _x_scale;
/** y scale factor to apply to subtitles */
- double _subtitle_y_scale;
+ double _y_scale;
std::list<boost::shared_ptr<Font> > _fonts;
dcp::Colour _colour;
bool _outline;
- dcp::Colour _outline_colour;
+ bool _shadow;
+ dcp::Colour _effect_colour;
std::list<boost::signals2::connection> _font_connections;
+ /** scaling factor for line spacing; 1 is "standard", < 1 is closer together, > 1 is further apart */
+ double _line_spacing;
};
#endif