projects
/
dcpomatic.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
No-op; fix GPL address and use the explicit-program-name version.
[dcpomatic.git]
/
src
/
wx
/
subtitle_view.cc
diff --git
a/src/wx/subtitle_view.cc
b/src/wx/subtitle_view.cc
index d14f260c9c8ba4098e39527ab960514a38ac3df0..e3aaffdfcf811a71e29f08a8d9d463b18277858d 100644
(file)
--- a/
src/wx/subtitle_view.cc
+++ b/
src/wx/subtitle_view.cc
@@
-1,32
+1,36
@@
/*
Copyright (C) 2014 Carl Hetherington <cth@carlh.net>
/*
Copyright (C) 2014 Carl Hetherington <cth@carlh.net>
- 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.
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
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 <http://www.gnu.org/licenses/>.
*/
*/
-#include "lib/
subrip
_decoder.h"
+#include "lib/
text_subtitle
_decoder.h"
#include "lib/content_subtitle.h"
#include "lib/content_subtitle.h"
+#include "lib/film.h"
+#include "lib/text_subtitle_content.h"
#include "subtitle_view.h"
#include "subtitle_view.h"
+#include "wx_util.h"
using std::list;
using boost::shared_ptr;
using boost::dynamic_pointer_cast;
using std::list;
using boost::shared_ptr;
using boost::dynamic_pointer_cast;
-SubtitleView::SubtitleView (wxWindow* parent, shared_ptr<
SubRipContent> content
)
- : wxDialog (parent, wxID_ANY, _("Subtitles"))
+SubtitleView::SubtitleView (wxWindow* parent, shared_ptr<
Film> film, shared_ptr<Decoder> 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);
{
_list = new wxListCtrl (this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxLC_REPORT | wxLC_SINGLE_SEL);
@@
-44,7
+48,7
@@
SubtitleView::SubtitleView (wxWindow* parent, shared_ptr<SubRipContent> content)
ip.SetText (_("End"));
ip.SetWidth (100);
_list->InsertColumn (1, ip);
ip.SetText (_("End"));
ip.SetWidth (100);
_list->InsertColumn (1, ip);
- }
+ }
{
wxListItem ip;
{
wxListItem ip;
@@
-55,26
+59,28
@@
SubtitleView::SubtitleView (wxWindow* parent, shared_ptr<SubRipContent> content)
}
wxBoxSizer* sizer = new wxBoxSizer (wxVERTICAL);
}
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());
}
if (buttons) {
sizer->Add (buttons, wxSizerFlags().Expand().DoubleBorder());
}
-
shared_ptr<SubRipDecoder> decoder (new SubRipDecoder (content)
);
-
list<shared_ptr<ContentTextSubtitle> > subs = decoder->get_text_subtitles (ContentTimePeriod (ContentTime(), ContentTime::max ())
);
+
list<ContentTextSubtitle> subs = decoder->subtitle->get_text (ContentTimePeriod (ContentTime(), ContentTime::max ()), true, true
);
+
FrameRateChange const frc = film->active_frame_rate_change (position
);
int n = 0;
int n = 0;
- for (list<
shared_ptr<ContentTextSubtitle>
>::const_iterator i = subs.begin(); i != subs.end(); ++i) {
- for (list<dcp::SubtitleString>::const_iterator j =
(*i)->subs.begin(); j != (*i)
->subs.end(); ++j) {
+ for (list<
ContentTextSubtitle
>::const_iterator i = subs.begin(); i != subs.end(); ++i) {
+ for (list<dcp::SubtitleString>::const_iterator j =
i->subs.begin(); j != i
->subs.end(); ++j) {
wxListItem list_item;
list_item.SetId (n);
_list->InsertItem (list_item);
wxListItem list_item;
list_item.SetId (n);
_list->InsertItem (list_item);
- _list->SetItem (n, 2, j->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;
}
}
SetSizerAndFit (sizer);
}
++n;
}
}
SetSizerAndFit (sizer);
}
-