diff options
| author | Carl Hetherington <cth@carlh.net> | 2014-12-11 15:20:33 +0000 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2014-12-11 16:05:58 +0000 |
| commit | 6bd8be029c72180a41d70e590bf2cb85a77317bf (patch) | |
| tree | f31286d8a6f4aa990fce2af549e5eb3cb7909b34 /src/lib | |
| parent | 5c93e50af883f02eadcf9a7bfe9cbfabbb3be844 (diff) | |
Add language property to SubtitleContent and use it in output DCP subtitle files.
Diffstat (limited to 'src/lib')
| -rw-r--r-- | src/lib/dcp_subtitle_content.cc | 1 | ||||
| -rw-r--r-- | src/lib/player.cc | 8 | ||||
| -rw-r--r-- | src/lib/player_subtitles.h | 4 | ||||
| -rw-r--r-- | src/lib/subtitle_content.cc | 19 | ||||
| -rw-r--r-- | src/lib/subtitle_content.h | 12 | ||||
| -rw-r--r-- | src/lib/writer.cc | 4 | ||||
| -rw-r--r-- | src/lib/writer.h | 2 |
7 files changed, 44 insertions, 6 deletions
diff --git a/src/lib/dcp_subtitle_content.cc b/src/lib/dcp_subtitle_content.cc index 7be96ceeb..798afbfc3 100644 --- a/src/lib/dcp_subtitle_content.cc +++ b/src/lib/dcp_subtitle_content.cc @@ -48,6 +48,7 @@ DCPSubtitleContent::examine (shared_ptr<Job> job, bool calculate_digest) { Content::examine (job, calculate_digest); dcp::SubtitleContent sc (path (0), false); + _subtitle_language = sc.language (); _length = DCPTime::from_seconds (sc.latest_subtitle_out().to_seconds ()); } diff --git a/src/lib/player.cc b/src/lib/player.cc index fabb5b211..396dc9906 100644 --- a/src/lib/player.cc +++ b/src/lib/player.cc @@ -50,6 +50,8 @@ #include <stdint.h> #include <algorithm> +#include "i18n.h" + #define LOG_GENERAL(...) _film->log()->log (String::compose (__VA_ARGS__), Log::TYPE_GENERAL); using std::list; @@ -549,6 +551,12 @@ Player::get_subtitles (DCPTime time, DCPTime length, bool starting) continue; } + /* XXX: this will break down if we have multiple subtitle content */ + ps.language = subtitle_content->subtitle_language(); + if (ps.language.empty ()) { + ps.language = _("Unknown"); + } + shared_ptr<SubtitleDecoder> subtitle_decoder = dynamic_pointer_cast<SubtitleDecoder> ((*j)->decoder); ContentTime const from = dcp_to_content_subtitle (*j, time); /* XXX: this video_frame_rate() should be the rate that the subtitle content has been prepared for */ diff --git a/src/lib/player_subtitles.h b/src/lib/player_subtitles.h index d0a3b4f65..804c87cb9 100644 --- a/src/lib/player_subtitles.h +++ b/src/lib/player_subtitles.h @@ -36,7 +36,9 @@ public: /** ImageSubtitles, with their rectangles transformed as specified by their content */ std::list<ImageSubtitle> image; - std::list<dcp::SubtitleString> text; + std::list<dcp::SubtitleString> text; + + std::string language; }; #endif diff --git a/src/lib/subtitle_content.cc b/src/lib/subtitle_content.cc index 5b370847b..df90a4a1a 100644 --- a/src/lib/subtitle_content.cc +++ b/src/lib/subtitle_content.cc @@ -38,6 +38,7 @@ int const SubtitleContentProperty::SUBTITLE_Y_OFFSET = 501; int const SubtitleContentProperty::SUBTITLE_X_SCALE = 502; int const SubtitleContentProperty::SUBTITLE_Y_SCALE = 503; int const SubtitleContentProperty::USE_SUBTITLES = 504; +int const SubtitleContentProperty::SUBTITLE_LANGUAGE = 505; SubtitleContent::SubtitleContent (shared_ptr<const Film> f) : Content (f) @@ -88,6 +89,8 @@ SubtitleContent::SubtitleContent (shared_ptr<const Film> f, cxml::ConstNodePtr n } else { _subtitle_x_scale = _subtitle_y_scale = node->number_child<float> ("SubtitleScale"); } + + _subtitle_language = node->optional_string_child ("SubtitleLanguage").get_value_or (""); } SubtitleContent::SubtitleContent (shared_ptr<const Film> f, vector<shared_ptr<Content> > c) @@ -125,6 +128,7 @@ SubtitleContent::SubtitleContent (shared_ptr<const Film> f, vector<shared_ptr<Co _subtitle_y_offset = ref->subtitle_y_offset (); _subtitle_x_scale = ref->subtitle_x_scale (); _subtitle_y_scale = ref->subtitle_y_scale (); + _subtitle_language = ref->subtitle_language (); } void @@ -135,6 +139,7 @@ SubtitleContent::as_xml (xmlpp::Node* root) const root->add_child("SubtitleYOffset")->add_child_text (raw_convert<string> (_subtitle_y_offset)); root->add_child("SubtitleXScale")->add_child_text (raw_convert<string> (_subtitle_x_scale)); root->add_child("SubtitleYScale")->add_child_text (raw_convert<string> (_subtitle_y_scale)); + root->add_child("SubtitleLanguage")->add_child_text (_subtitle_language); } void @@ -187,6 +192,16 @@ SubtitleContent::set_subtitle_y_scale (double s) signal_changed (SubtitleContentProperty::SUBTITLE_Y_SCALE); } +void +SubtitleContent::set_subtitle_language (string language) +{ + { + boost::mutex::scoped_lock lm (_mutex); + _subtitle_language = language; + } + signal_changed (SubtitleContentProperty::SUBTITLE_LANGUAGE); +} + string SubtitleContent::identifier () const { @@ -197,5 +212,9 @@ SubtitleContent::identifier () const << "_" << raw_convert<string> (subtitle_x_offset()) << "_" << raw_convert<string> (subtitle_y_offset()); + /* The language is for metadata only, and doesn't affect + how this content looks. + */ + return s.str (); } diff --git a/src/lib/subtitle_content.h b/src/lib/subtitle_content.h index c3c25232f..4cbef657a 100644 --- a/src/lib/subtitle_content.h +++ b/src/lib/subtitle_content.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013 Carl Hetherington <cth@carlh.net> + Copyright (C) 2013-2014 Carl Hetherington <cth@carlh.net> This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -30,6 +30,7 @@ public: static int const SUBTITLE_X_SCALE; static int const SUBTITLE_Y_SCALE; static int const USE_SUBTITLES; + static int const SUBTITLE_LANGUAGE; }; /** @class SubtitleContent @@ -56,6 +57,7 @@ public: 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); bool use_subtitles () const { boost::mutex::scoped_lock lm (_mutex); @@ -82,6 +84,14 @@ public: return _subtitle_y_scale; } + std::string subtitle_language () const { + return _subtitle_language; + } + +protected: + /** subtitle language (e.g. "German") or empty if it is not known */ + std::string _subtitle_language; + private: friend struct ffmpeg_pts_offset_test; diff --git a/src/lib/writer.cc b/src/lib/writer.cc index 11a4f9d03..eca0b134a 100644 --- a/src/lib/writer.cc +++ b/src/lib/writer.cc @@ -615,9 +615,7 @@ Writer::write (PlayerSubtitles subs) } if (!_subtitle_content) { - _subtitle_content.reset ( - new dcp::SubtitleContent (_film->name(), _film->isdcf_metadata().subtitle_language) - ); + _subtitle_content.reset (new dcp::SubtitleContent (_film->name(), subs.language)); } for (list<dcp::SubtitleString>::const_iterator i = subs.text.begin(); i != subs.text.end(); ++i) { diff --git a/src/lib/writer.h b/src/lib/writer.h index f8aeb8c83..5efb14e50 100644 --- a/src/lib/writer.h +++ b/src/lib/writer.h @@ -94,7 +94,7 @@ public: void write (boost::shared_ptr<const EncodedData>, int, Eyes); void fake_write (int, Eyes); void write (boost::shared_ptr<const AudioBuffers>); - void write (PlayerSubtitles); + void write (PlayerSubtitles subs); void repeat (int f, Eyes); void finish (); |
