Pass DCP subtitles before video so that they are present when the video frame looks...
authorCarl Hetherington <cth@carlh.net>
Thu, 8 Feb 2018 20:41:57 +0000 (20:41 +0000)
committerCarl Hetherington <cth@carlh.net>
Thu, 8 Feb 2018 20:41:57 +0000 (20:41 +0000)
src/lib/dcp_decoder.cc
test/data
test/player_test.cc

index 14b791aa2a48a9ef60579c09d8ed02e4461c59ef..c1c7780bb8c782346bb87474d421b0eb42fc1b2d 100644 (file)
@@ -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 ()) {
index 8e92ab871972fd6b19114e5783b5dfccba9a61e1..4e9eb33fcd08820325f40446e089e10928fe3c59 160000 (submodule)
--- a/test/data
+++ b/test/data
@@ -1 +1 @@
-Subproject commit 8e92ab871972fd6b19114e5783b5dfccba9a61e1
+Subproject commit 4e9eb33fcd08820325f40446e089e10928fe3c59
index 1580d5902e3a4da40e3ad32c7b21593cc5fa16ee..e22570bc0b95b121ccb460cedc83c314c599b6d9 100644 (file)
@@ -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));
+       }
+}