diff options
| author | Carl Hetherington <cth@carlh.net> | 2017-04-07 11:51:39 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2017-04-07 11:51:39 +0100 |
| commit | fdb1cacf58115881bd4d3e8cca8ba389f26400df (patch) | |
| tree | 3a91ce7a4ab088d634036f91135c7ad974b27e51 /src/wx | |
| parent | ab32017c7cc918ddd2cd35661cf64985e0abc79a (diff) | |
Make jump-to-content-start on selection in the content list optional.
This behaviour is annoying in some cases, e.g. trying to move separate
subtitle files around when looking at a particular time in the preview.
Diffstat (limited to 'src/wx')
| -rw-r--r-- | src/wx/content_panel.cc | 3 | ||||
| -rw-r--r-- | src/wx/film_viewer.cc | 40 | ||||
| -rw-r--r-- | src/wx/film_viewer.h | 2 |
3 files changed, 30 insertions, 15 deletions
diff --git a/src/wx/content_panel.cc b/src/wx/content_panel.cc index 1aeba6372..1d748be5f 100644 --- a/src/wx/content_panel.cc +++ b/src/wx/content_panel.cc @@ -36,6 +36,7 @@ #include "lib/dcp_content.h" #include "lib/case_insensitive_sorter.h" #include "lib/playlist.h" +#include "lib/config.h" #include <wx/wx.h> #include <wx/notebook.h> #include <wx/listctrl.h> @@ -254,7 +255,7 @@ ContentPanel::selection_changed () } } - if (go_to) { + if (go_to && Config::instance()->jump_to_selected ()) { _film_viewer->set_position (go_to.get ()); } diff --git a/src/wx/film_viewer.cc b/src/wx/film_viewer.cc index 40155b18c..3c6138d46 100644 --- a/src/wx/film_viewer.cc +++ b/src/wx/film_viewer.cc @@ -40,6 +40,7 @@ #include "lib/video_decoder.h" #include "lib/timer.h" #include "lib/log.h" +#include "lib/config.h" extern "C" { #include <libavutil/pixfmt.h> } @@ -69,6 +70,7 @@ FilmViewer::FilmViewer (wxWindow* p) , _outline_content (new wxCheckBox (this, wxID_ANY, _("Outline content"))) , _left_eye (new wxRadioButton (this, wxID_ANY, _("Left eye"), wxDefaultPosition, wxDefaultSize, wxRB_GROUP)) , _right_eye (new wxRadioButton (this, wxID_ANY, _("Right eye"))) + , _jump_to_selected (new wxCheckBox (this, wxID_ANY, _("Jump to selected content"))) , _slider (new wxSlider (this, wxID_ANY, 0, 0, 4096)) , _back_button (new wxButton (this, wxID_ANY, wxT("<"))) , _forward_button (new wxButton (this, wxID_ANY, wxT(">"))) @@ -94,6 +96,7 @@ FilmViewer::FilmViewer (wxWindow* p) view_options->Add (_outline_content, 0, wxRIGHT, DCPOMATIC_SIZER_GAP); view_options->Add (_left_eye, 0, wxLEFT | wxRIGHT, DCPOMATIC_SIZER_GAP); view_options->Add (_right_eye, 0, wxLEFT | wxRIGHT, DCPOMATIC_SIZER_GAP); + view_options->Add (_jump_to_selected, 0, wxLEFT | wxRIGHT, DCPOMATIC_SIZER_GAP); _v_sizer->Add (view_options, 0, wxALL, DCPOMATIC_SIZER_GAP); wxBoxSizer* h_sizer = new wxBoxSizer (wxHORIZONTAL); @@ -114,20 +117,23 @@ FilmViewer::FilmViewer (wxWindow* p) _back_button->SetMinSize (wxSize (32, -1)); _forward_button->SetMinSize (wxSize (32, -1)); - _panel->Bind (wxEVT_PAINT, boost::bind (&FilmViewer::paint_panel, this)); - _panel->Bind (wxEVT_SIZE, boost::bind (&FilmViewer::panel_sized, this, _1)); - _outline_content->Bind(wxEVT_CHECKBOX, boost::bind (&FilmViewer::refresh_panel, this)); - _left_eye->Bind (wxEVT_RADIOBUTTON, boost::bind (&FilmViewer::refresh, this)); - _right_eye->Bind (wxEVT_RADIOBUTTON, boost::bind (&FilmViewer::refresh, this)); - _slider->Bind (wxEVT_SCROLL_THUMBTRACK, boost::bind (&FilmViewer::slider_moved, this)); - _slider->Bind (wxEVT_SCROLL_PAGEUP, boost::bind (&FilmViewer::slider_moved, this)); - _slider->Bind (wxEVT_SCROLL_PAGEDOWN, boost::bind (&FilmViewer::slider_moved, this)); - _play_button->Bind (wxEVT_TOGGLEBUTTON, boost::bind (&FilmViewer::play_clicked, this)); - _timer.Bind (wxEVT_TIMER, boost::bind (&FilmViewer::timer, this)); - _back_button->Bind (wxEVT_LEFT_DOWN, boost::bind (&FilmViewer::back_clicked, this, _1)); - _forward_button->Bind (wxEVT_LEFT_DOWN, boost::bind (&FilmViewer::forward_clicked, this, _1)); - _frame_number->Bind (wxEVT_LEFT_DOWN, boost::bind (&FilmViewer::frame_number_clicked, this)); - _timecode->Bind (wxEVT_LEFT_DOWN, boost::bind (&FilmViewer::timecode_clicked, this)); + _panel->Bind (wxEVT_PAINT, boost::bind (&FilmViewer::paint_panel, this)); + _panel->Bind (wxEVT_SIZE, boost::bind (&FilmViewer::panel_sized, this, _1)); + _outline_content->Bind (wxEVT_CHECKBOX, boost::bind (&FilmViewer::refresh_panel, this)); + _left_eye->Bind (wxEVT_RADIOBUTTON, boost::bind (&FilmViewer::refresh, this)); + _right_eye->Bind (wxEVT_RADIOBUTTON, boost::bind (&FilmViewer::refresh, this)); + _slider->Bind (wxEVT_SCROLL_THUMBTRACK, boost::bind (&FilmViewer::slider_moved, this)); + _slider->Bind (wxEVT_SCROLL_PAGEUP, boost::bind (&FilmViewer::slider_moved, this)); + _slider->Bind (wxEVT_SCROLL_PAGEDOWN, boost::bind (&FilmViewer::slider_moved, this)); + _play_button->Bind (wxEVT_TOGGLEBUTTON, boost::bind (&FilmViewer::play_clicked, this)); + _timer.Bind (wxEVT_TIMER, boost::bind (&FilmViewer::timer, this)); + _back_button->Bind (wxEVT_LEFT_DOWN, boost::bind (&FilmViewer::back_clicked, this, _1)); + _forward_button->Bind (wxEVT_LEFT_DOWN, boost::bind (&FilmViewer::forward_clicked, this, _1)); + _frame_number->Bind (wxEVT_LEFT_DOWN, boost::bind (&FilmViewer::frame_number_clicked, this)); + _timecode->Bind (wxEVT_LEFT_DOWN, boost::bind (&FilmViewer::timecode_clicked, this)); + _jump_to_selected->Bind (wxEVT_CHECKBOX, boost::bind (&FilmViewer::jump_to_selected_clicked, this)); + + _jump_to_selected->SetValue (Config::instance()->jump_to_selected ()); set_film (shared_ptr<Film> ()); @@ -590,3 +596,9 @@ FilmViewer::frame_number_clicked () } dialog->Destroy (); } + +void +FilmViewer::jump_to_selected_clicked () +{ + Config::instance()->set_jump_to_selected (_jump_to_selected->GetValue ()); +} diff --git a/src/wx/film_viewer.h b/src/wx/film_viewer.h index aa588b926..0db4bccc5 100644 --- a/src/wx/film_viewer.h +++ b/src/wx/film_viewer.h @@ -75,6 +75,7 @@ private: void timecode_clicked (); void frame_number_clicked (); void go_to (DCPTime t); + void jump_to_selected_clicked (); boost::shared_ptr<Film> _film; boost::shared_ptr<Player> _player; @@ -84,6 +85,7 @@ private: wxCheckBox* _outline_content; wxRadioButton* _left_eye; wxRadioButton* _right_eye; + wxCheckBox* _jump_to_selected; wxSlider* _slider; wxButton* _back_button; wxButton* _forward_button; |
