summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2018-02-08 20:41:57 +0000
committerCarl Hetherington <cth@carlh.net>2018-02-08 20:41:57 +0000
commite3f2d81e7e7d3b36d47020b5704fcc36d6959952 (patch)
treeb40b74eb97fc6e8a1fd375a96241a987b92241dd
parent18dbb50a911612e3148ccb1479928fda74b83194 (diff)
Pass DCP subtitles before video so that they are present when the video frame looks for them.
-rw-r--r--src/lib/dcp_decoder.cc7
m---------test/data0
-rw-r--r--test/player_test.cc29
3 files changed, 34 insertions, 2 deletions
diff --git a/src/lib/dcp_decoder.cc b/src/lib/dcp_decoder.cc
index 14b791aa2..c1c7780bb 100644
--- a/src/lib/dcp_decoder.cc
+++ b/src/lib/dcp_decoder.cc
@@ -99,6 +99,11 @@ DCPDecoder::pass ()
/* Frame within the (played part of the) reel that is coming up next */
int64_t const frame = _next.frames_round (vfr);
+ /* We must emit subtitles first as when we emit the video for this frame
+ it will expect already to have the subs.
+ */
+ pass_subtitles (_next);
+
if ((_mono_reader || _stereo_reader) && (_decode_referenced || !_dcp_content->reference_video())) {
shared_ptr<dcp::PictureAsset> asset = (*_reel)->main_picture()->asset ();
int64_t const entry_point = (*_reel)->main_picture()->entry_point ();
@@ -162,8 +167,6 @@ DCPDecoder::pass ()
audio->emit (_dcp_content->audio->stream(), data, ContentTime::from_frames (_offset, vfr) + _next);
}
- pass_subtitles (_next);
-
_next += ContentTime::from_frames (1, vfr);
if ((*_reel)->main_picture ()) {
diff --git a/test/data b/test/data
-Subproject 8e92ab871972fd6b19114e5783b5dfccba9a61e
+Subproject 4e9eb33fcd08820325f40446e089e10928fe3c5
diff --git a/test/player_test.cc b/test/player_test.cc
index 1580d5902..e22570bc0 100644
--- a/test/player_test.cc
+++ b/test/player_test.cc
@@ -230,3 +230,32 @@ BOOST_AUTO_TEST_CASE (player_seek_test)
check_image(String::compose("test/data/player_seek_test_%1.png", i), String::compose("build/test/player_seek_test_%1.png", i));
}
}
+
+/** Test some more seeks towards the start of a DCP with awkward subtitles */
+BOOST_AUTO_TEST_CASE (player_seek_test2)
+{
+ shared_ptr<Film> film (new Film (optional<boost::filesystem::path>()));
+ shared_ptr<DCPContent> dcp (new DCPContent (film, private_data / "awkward_subs2"));
+ film->examine_and_add_content (dcp, true);
+ BOOST_REQUIRE (!wait_for_jobs ());
+ dcp->subtitle->set_use (true);
+
+ shared_ptr<Player> player (new Player (film, film->playlist()));
+ player->set_fast ();
+ player->set_always_burn_subtitles (true);
+ player->set_play_referenced ();
+
+ shared_ptr<Butler> butler (new Butler (player, film->log(), AudioMapping(), 2));
+ butler->disable_audio();
+
+ butler->seek(DCPTime::from_seconds(5), true);
+
+ for (int i = 0; i < 10; ++i) {
+ DCPTime t = DCPTime::from_seconds(5) + DCPTime::from_frames (i, 24);
+ butler->seek (t, true);
+ pair<shared_ptr<PlayerVideo>, DCPTime> video = butler->get_video();
+ BOOST_CHECK_EQUAL(video.second.get(), t.get());
+ write_image(video.first->image(note_handler, PlayerVideo::always_rgb, false, true), String::compose("build/test/player_seek_test2_%1.png", i), "RGB");
+ check_image(String::compose("test/data/player_seek_test2_%1.png", i), String::compose("build/test/player_seek_test2_%1.png", i));
+ }
+}