Fix various problems with the closed caption viewer not being updated properly.
authorCarl Hetherington <cth@carlh.net>
Tue, 28 Jul 2020 20:20:19 +0000 (22:20 +0200)
committerCarl Hetherington <cth@carlh.net>
Sun, 2 Aug 2020 21:48:08 +0000 (21:48 +0000)
Cherry-picked from d902160e3c89a9f65f58a2463fac0b1de1d940b1 in v2.15.x.

src/wx/closed_captions_dialog.cc
src/wx/closed_captions_dialog.h
src/wx/film_viewer.cc
src/wx/film_viewer.h

index 44e6b8da1d9162423bdafdfaab261935cfe9e3ff..5403e7f2e745f3aaeed41e1af87124470fb91ce0 100644 (file)
@@ -191,6 +191,12 @@ ClosedCaptionsDialog::update (DCPTime time)
                Refresh ();
                _current_in_lines = true;
        }
+
+       if (!_current && _tracks.empty()) {
+               for (int i = 0; i < CLOSED_CAPTION_LINES; ++i) {
+                       _lines[i] = wxString();
+               }
+       }
 }
 
 void
@@ -201,8 +207,15 @@ ClosedCaptionsDialog::clear ()
        Refresh ();
 }
 
+
+void
+ClosedCaptionsDialog::set_butler (weak_ptr<Butler> butler)
+{
+       _butler = butler;
+}
+
 void
-ClosedCaptionsDialog::set_film_and_butler (shared_ptr<Film> film, weak_ptr<Butler> butler)
+ClosedCaptionsDialog::update_tracks (shared_ptr<const Film> film)
 {
        _tracks.clear ();
 
@@ -225,5 +238,5 @@ ClosedCaptionsDialog::set_film_and_butler (shared_ptr<Film> film, weak_ptr<Butle
                _track->SetSelection (0);
        }
 
-       _butler = butler;
+       track_selected ();
 }
index 4b407fa5a7a7c49ae2631ace6979cba235b88bc9..26d042639a9d210567b2b9bc603c23eeb8eac52f 100644 (file)
@@ -33,7 +33,8 @@ public:
 
        void update (DCPTime);
        void clear ();
-       void set_film_and_butler (boost::shared_ptr<Film>, boost::weak_ptr<Butler>);
+       void update_tracks (boost::shared_ptr<const Film> film);
+       void set_butler (boost::weak_ptr<Butler>);
 
 private:
        void paint ();
index 098fc2598994e4b13add02900300db71f49f47af..026e9d66f4920de0abf57468d8c24348b07b903d 100644 (file)
@@ -45,6 +45,7 @@
 #include "lib/config.h"
 #include "lib/compose.hpp"
 #include "lib/dcpomatic_log.h"
+#include "lib/text_content.h"
 extern "C" {
 #include <libavutil/pixfmt.h>
 }
@@ -154,6 +155,7 @@ FilmViewer::set_film (shared_ptr<Film> film)
        _player->set_play_referenced ();
 
        _film->Change.connect (boost::bind (&FilmViewer::film_change, this, _1, _2));
+       _film->ContentChange.connect (boost::bind(&FilmViewer::content_change, this, _1, _3));
        _player->Change.connect (boost::bind (&FilmViewer::player_change, this, _1, _2, _3));
 
        /* Keep about 1 second's worth of history samples */
@@ -213,7 +215,7 @@ FilmViewer::recreate_butler ()
                _butler->disable_audio ();
        }
 
-       _closed_captions_dialog->set_film_and_butler (_film, _butler);
+       _closed_captions_dialog->set_butler (_butler);
 
        if (was_running) {
                start ();
@@ -554,6 +556,8 @@ FilmViewer::film_change (ChangeType type, Film::Property p)
 {
        if (type == CHANGE_TYPE_DONE && p == Film::AUDIO_CHANNELS) {
                recreate_butler ();
+       } else if (p == Film::CONTENT) {
+               _closed_captions_dialog->update_tracks (_film);
        }
 }
 
@@ -792,3 +796,15 @@ FilmViewer::set_pad_black (bool p)
 {
        _pad_black = p;
 }
+
+void
+FilmViewer::content_change (ChangeType type, int property)
+{
+       if (type != CHANGE_TYPE_DONE) {
+               return;
+       }
+
+       if (property == TextContentProperty::USE || property == TextContentProperty::TYPE || property == TextContentProperty::DCP_TRACK) {
+               _closed_captions_dialog->update_tracks (_film);
+       }
+}
index 972a88a5af2aee7c8ed1ef8a27378a37df5e475b..cfb8374ee0d8146bc2e67434ca4a7ef31df04519 100644 (file)
@@ -113,6 +113,7 @@ private:
        void get ();
        void display_player_video ();
        void film_change (ChangeType, Film::Property);
+       void content_change (ChangeType, int property);
        void recreate_butler ();
        void config_changed (Config::Property);
        bool maybe_draw_background_image (wxPaintDC& dc);