- list<shared_ptr<dcp::InteropLoadFont> > fonts = sc.load_font_nodes ();
- for (list<shared_ptr<dcp::InteropLoadFont> >::const_iterator i = fonts.begin(); i != fonts.end(); ++i) {
- _fonts.push_back (shared_ptr<Font> (new Font ((*i)->id)));
+ /* Default to turning these subtitles on */
+ only_text()->set_use (true);
+
+ _length = ContentTime::from_seconds(subtitle_asset->latest_subtitle_out().as_seconds());
+
+ subtitle_asset->fix_empty_font_ids();
+
+ auto font_data = subtitle_asset->font_data();
+ for (auto node: subtitle_asset->load_font_nodes()) {
+ auto data = font_data.find(node->id);
+ if (data != font_data.end()) {
+ only_text()->add_font(make_shared<Font>(node->id, data->second));
+ } else {
+ only_text()->add_font(make_shared<Font>(node->id));
+ }