X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fsubtitle_view.cc;h=6ec71fce5e91634a2495b4a8ddf33fb7f78312e7;hb=de2af791bdfdcd653752cba970e59efc7bf810c7;hp=f6fbd9a9abfbf1f49e1e99e327fa16462bd6ffe6;hpb=a4c19a34244aeaf183c25878933b570fc5c0ee34;p=dcpomatic.git diff --git a/src/wx/subtitle_view.cc b/src/wx/subtitle_view.cc index f6fbd9a9a..6ec71fce5 100644 --- a/src/wx/subtitle_view.cc +++ b/src/wx/subtitle_view.cc @@ -1,32 +1,36 @@ /* Copyright (C) 2014 Carl Hetherington - 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 . */ -#include "lib/subrip_decoder.h" -#include "lib/decoded.h" +#include "lib/text_subtitle_decoder.h" +#include "lib/content_subtitle.h" +#include "lib/film.h" +#include "lib/text_subtitle_content.h" #include "subtitle_view.h" +#include "wx_util.h" using std::list; using boost::shared_ptr; using boost::dynamic_pointer_cast; -SubtitleView::SubtitleView (wxWindow* parent, shared_ptr content) - : wxDialog (parent, wxID_ANY, _("Subtitles")) +SubtitleView::SubtitleView (wxWindow* parent, shared_ptr film, shared_ptr decoder, DCPTime position) + : wxDialog (parent, wxID_ANY, _("Subtitles"), wxDefaultPosition, wxDefaultSize, wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER) { _list = new wxListCtrl (this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_REPORT | wxLC_SINGLE_SEL); @@ -44,7 +48,7 @@ SubtitleView::SubtitleView (wxWindow* parent, shared_ptr content) ip.SetText (_("End")); ip.SetWidth (100); _list->InsertColumn (1, ip); - } + } { wxListItem ip; @@ -55,35 +59,32 @@ SubtitleView::SubtitleView (wxWindow* parent, shared_ptr content) } wxBoxSizer* sizer = new wxBoxSizer (wxVERTICAL); - sizer->Add (_list, 1, wxEXPAND); + sizer->Add (_list, 1, wxEXPAND | wxALL, DCPOMATIC_SIZER_X_GAP); - wxSizer* buttons = CreateSeparatedButtonSizer (wxOK | wxCANCEL); + wxSizer* buttons = CreateSeparatedButtonSizer (wxOK); if (buttons) { sizer->Add (buttons, wxSizerFlags().Expand().DoubleBorder()); } - shared_ptr decoder (new SubRipDecoder (content)); - int n = 0; - while (1) { - shared_ptr dec = decoder->peek (); - if (!dec) { - break; - } - - shared_ptr sub = dynamic_pointer_cast (dec); - assert (sub); +#if 0 + XXX - for (list::const_iterator i = sub->subs.begin(); i != sub->subs.end(); ++i) { + list subs = decoder->subtitle->get_text (ContentTimePeriod (ContentTime(), ContentTime::max ()), true, 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) { wxListItem list_item; list_item.SetId (n); _list->InsertItem (list_item); - _list->SetItem (n, 2, i->text ()); + 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 ())); ++n; } - - decoder->consume (); } +#endif SetSizerAndFit (sizer); } -