diff options
| author | Carl Hetherington <cth@carlh.net> | 2012-10-17 17:42:58 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2012-10-17 17:42:58 +0100 |
| commit | 988fa33f7d25f2f3319442ce3c9ed661172e4d56 (patch) | |
| tree | aad7e83489c231cfaede43c1d89329fb0e0743ae /src/wx | |
| parent | 65400c0562fcf23c78c7b7276a79d0aef6b21a8a (diff) | |
Update stream choices correctly when changed.
Diffstat (limited to 'src/wx')
| -rw-r--r-- | src/wx/film_editor.cc | 36 | ||||
| -rw-r--r-- | src/wx/film_editor.h | 2 |
2 files changed, 38 insertions, 0 deletions
diff --git a/src/wx/film_editor.cc b/src/wx/film_editor.cc index 8a4112630..c687975ba 100644 --- a/src/wx/film_editor.cc +++ b/src/wx/film_editor.cc @@ -258,6 +258,8 @@ FilmEditor::FilmEditor (Film* f, wxWindow* parent) _with_subtitles->Connect (wxID_ANY, wxEVT_COMMAND_CHECKBOX_CLICKED, wxCommandEventHandler (FilmEditor::with_subtitles_toggled), 0, this); _subtitle_offset->Connect (wxID_ANY, wxEVT_COMMAND_SPINCTRL_UPDATED, wxCommandEventHandler (FilmEditor::subtitle_offset_changed), 0, this); _subtitle_scale->Connect (wxID_ANY, wxEVT_COMMAND_SPINCTRL_UPDATED, wxCommandEventHandler (FilmEditor::subtitle_scale_changed), 0, this); + _audio_stream->Connect (wxID_ANY, wxEVT_COMMAND_COMBOBOX_SELECTED, wxCommandEventHandler (FilmEditor::audio_stream_changed), 0, this); + _subtitle_stream->Connect (wxID_ANY, wxEVT_COMMAND_COMBOBOX_SELECTED, wxCommandEventHandler (FilmEditor::subtitle_stream_changed), 0, this); setup_visibility (); setup_formats (); @@ -903,3 +905,37 @@ FilmEditor::set_selected_stream (vector<Stream> const & streams, int id, wxCombo assert (n < streams.size()); combo->SetSelection (n); } + +void +FilmEditor::audio_stream_changed (wxCommandEvent &) +{ + if (!_film) { + return; + } + + _ignore_changes = Film::AUDIO_STREAM; + int const n = _audio_stream->GetSelection (); + if (n >= 0) { + vector<Stream> s = _film->audio_streams (); + assert (n < int (s.size ())); + _film->set_audio_stream (s[n].id); + } + _ignore_changes = Film::NONE; +} + +void +FilmEditor::subtitle_stream_changed (wxCommandEvent &) +{ + if (!_film) { + return; + } + + _ignore_changes = Film::SUBTITLE_STREAM; + int const n = _subtitle_stream->GetSelection (); + if (n >= 0) { + vector<Stream> s = _film->subtitle_streams (); + assert (n < int (s.size ())); + _film->set_subtitle_stream (s[n].id); + } + _ignore_changes = Film::NONE; +} diff --git a/src/wx/film_editor.h b/src/wx/film_editor.h index 9d159d307..b204385bc 100644 --- a/src/wx/film_editor.h +++ b/src/wx/film_editor.h @@ -65,6 +65,8 @@ private: void subtitle_offset_changed (wxCommandEvent &); void subtitle_scale_changed (wxCommandEvent &); void still_duration_changed (wxCommandEvent &); + void audio_stream_changed (wxCommandEvent &); + void subtitle_stream_changed (wxCommandEvent &); /* Handle changes to the model */ void film_changed (Film::Property); |
