X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fsubtitle_view.cc;h=dc41db2fa51e82fd49ac5ba9c2165f7149174301;hb=b6c780d3107557d452c6612d715d01e2be52dbda;hp=e4604ccde18584b0a9951c671aaf394e727d359b;hpb=f1d30fb114b3b2c6ccd8fdf5823e7cd6b26c1eef;p=dcpomatic.git diff --git a/src/wx/subtitle_view.cc b/src/wx/subtitle_view.cc index e4604ccde..dc41db2fa 100644 --- a/src/wx/subtitle_view.cc +++ b/src/wx/subtitle_view.cc @@ -28,7 +28,7 @@ using std::list; using boost::shared_ptr; using boost::dynamic_pointer_cast; -SubtitleView::SubtitleView (wxWindow* parent, shared_ptr film, shared_ptr content) +SubtitleView::SubtitleView (wxWindow* parent, shared_ptr film, shared_ptr decoder, DCPTime position) : wxDialog (parent, wxID_ANY, _("Subtitles")) { _list = new wxListCtrl (this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_REPORT | wxLC_SINGLE_SEL); @@ -65,16 +65,15 @@ SubtitleView::SubtitleView (wxWindow* parent, shared_ptr film, shared_ptr< sizer->Add (buttons, wxSizerFlags().Expand().DoubleBorder()); } - shared_ptr decoder (new SubRipDecoder (content)); - list > subs = decoder->get_text_subtitles (ContentTimePeriod (ContentTime(), ContentTime::max ())); - FrameRateChange const frc = film->active_frame_rate_change (content->position ()); + list subs = decoder->get_text_subtitles (ContentTimePeriod (ContentTime(), ContentTime::max ()), true); + FrameRateChange const frc = film->active_frame_rate_change (position); int n = 0; - for (list >::const_iterator i = subs.begin(); i != subs.end(); ++i) { - for (list::const_iterator j = (*i)->subs.begin(); j != (*i)->subs.end(); ++j) { + for (list::const_iterator i = subs.begin(); i != subs.end(); ++i) { + for (list::const_iterator j = i->subs.begin(); j != i->subs.end(); ++j) { wxListItem list_item; list_item.SetId (n); _list->InsertItem (list_item); - ContentTimePeriod const p = (*i)->period (); + ContentTimePeriod const p = i->period (); _list->SetItem (n, 0, std_to_wx (p.from.timecode (frc.source))); _list->SetItem (n, 1, std_to_wx (p.to.timecode (frc.source))); _list->SetItem (n, 2, std_to_wx (j->text ()));