From ff72bf25f215f5cb58ee165898968380f9dff73f Mon Sep 17 00:00:00 2001 From: Carl Hetherington Date: Tue, 28 Jun 2016 00:34:24 +0100 Subject: Fix pango markup when rendering subtitles. --- src/lib/render_subtitles.cc | 98 ++++++++++++++++++++++----------------------- src/lib/render_subtitles.h | 3 +- 2 files changed, 51 insertions(+), 50 deletions(-) (limited to 'src/lib') diff --git a/src/lib/render_subtitles.cc b/src/lib/render_subtitles.cc index 0e985371c..fea788a5c 100644 --- a/src/lib/render_subtitles.cc +++ b/src/lib/render_subtitles.cc @@ -44,6 +44,54 @@ using boost::optional; static FcConfig* fc_config = 0; static list > fc_config_fonts; +string +marked_up (list subtitles) +{ + string out; + bool italic = false; + bool bold = false; + bool underline = false; + BOOST_FOREACH (dcp::SubtitleString const & i, subtitles) { + if (i.italic() && !italic) { + out += ""; + } + if (i.bold() && !bold) { + out += ""; + } + if (i.underline() && !underline) { + out += ""; + } + + out += i.text (); + + if (!i.underline() && underline) { + out += ""; + } + if (!i.bold() && bold) { + out += ""; + } + if (!i.italic() && italic) { + out += ""; + } + + italic = i.italic (); + bold = i.bold (); + underline = i.underline (); + } + + if (underline) { + out += ""; + } + if (bold) { + out += ""; + } + if (italic) { + out += ""; + } + + return out; +} + /** @param subtitles A list of subtitles that are all on the same line */ static PositionImage render_line (list subtitles, list > fonts, dcp::Size target) @@ -197,55 +245,7 @@ render_line (list subtitles, list > fonts, Pango::FontDescription font (font_name); font.set_absolute_size (subtitles.front().size_in_pixels (target.height) * PANGO_SCALE); layout->set_font_description (font); - - string marked_up; - bool italic = false; - bool bold = false; - bool underline = false; - BOOST_FOREACH (dcp::SubtitleString const & i, subtitles) { - if (i.italic() != italic) { - if (i.italic()) { - marked_up += ""; - } else { - marked_up += ""; - } - italic = i.italic (); - } - - if (i.bold() != bold) { - if (i.bold()) { - marked_up += ""; - } else { - marked_up += ""; - } - bold = i.bold (); - } - - if (i.underline() != underline) { - if (i.underline()) { - marked_up += ""; - } else { - marked_up += ""; - } - underline = i.underline (); - } - - marked_up += i.text (); - } - - if (italic) { - marked_up += ""; - } - - if (bold) { - marked_up += ""; - } - - if (underline) { - marked_up += ""; - } - - layout->set_markup (marked_up); + layout->set_markup (marked_up (subtitles)); /* Compute fade factor */ /* XXX */ diff --git a/src/lib/render_subtitles.h b/src/lib/render_subtitles.h index 4fd931781..281efe97a 100644 --- a/src/lib/render_subtitles.h +++ b/src/lib/render_subtitles.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2014 Carl Hetherington + Copyright (C) 2014-2016 Carl Hetherington This file is part of DCP-o-matic. @@ -24,4 +24,5 @@ class Font; +std::string marked_up (std::list subtitles); std::list render_subtitles (std::list, std::list > fonts, dcp::Size); -- cgit v1.2.3