diff options
| author | Carl Hetherington <cth@carlh.net> | 2018-02-08 20:41:57 +0000 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2018-02-08 20:41:57 +0000 |
| commit | e3f2d81e7e7d3b36d47020b5704fcc36d6959952 (patch) | |
| tree | b40b74eb97fc6e8a1fd375a96241a987b92241dd | |
| parent | 18dbb50a911612e3148ccb1479928fda74b83194 (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.cc | 7 | ||||
| m--------- | test/data | 0 | ||||
| -rw-r--r-- | test/player_test.cc | 29 |
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)); + } +} |
