summaryrefslogtreecommitdiff
path: root/src/wx
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2017-04-07 11:51:39 +0100
committerCarl Hetherington <cth@carlh.net>2017-04-07 11:51:39 +0100
commitfdb1cacf58115881bd4d3e8cca8ba389f26400df (patch)
tree3a91ce7a4ab088d634036f91135c7ad974b27e51 /src/wx
parentab32017c7cc918ddd2cd35661cf64985e0abc79a (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.cc3
-rw-r--r--src/wx/film_viewer.cc40
-rw-r--r--src/wx/film_viewer.h2
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;