diff options
| author | Carl Hetherington <cth@carlh.net> | 2018-07-04 02:23:29 +0100 |
|---|---|---|
| committer | Carl Hetherington <cth@carlh.net> | 2018-07-04 02:23:29 +0100 |
| commit | c554c20be02b4a518be1be4266f90b88df9d5bd6 (patch) | |
| tree | 014aec0045a14dd44d811cefbd14e4dd6628fcf6 /src | |
| parent | 7bcf60f8ad3acd4dcae77a120216839b665c4335 (diff) | |
Replace checkboxes with tools.
Diffstat (limited to 'src')
| -rw-r--r-- | src/wx/timeline.cc | 11 | ||||
| -rw-r--r-- | src/wx/timeline.h | 4 | ||||
| -rw-r--r-- | src/wx/timeline_dialog.cc | 66 | ||||
| -rw-r--r-- | src/wx/timeline_dialog.h | 8 |
4 files changed, 49 insertions, 40 deletions
diff --git a/src/wx/timeline.cc b/src/wx/timeline.cc index c60568e3a..8524db603 100644 --- a/src/wx/timeline.cc +++ b/src/wx/timeline.cc @@ -428,6 +428,8 @@ Timeline::left_down (wxMouseEvent& ev) break; case ZOOM: case ZOOM_ALL: + case SNAP: + case SEQUENCE: /* Nothing to do */ break; } @@ -499,6 +501,8 @@ Timeline::left_up (wxMouseEvent& ev) left_up_zoom (ev); break; case ZOOM_ALL: + case SNAP: + case SEQUENCE: break; } } @@ -571,6 +575,8 @@ Timeline::mouse_moved (wxMouseEvent& ev) mouse_moved_zoom (ev); break; case ZOOM_ALL: + case SNAP: + case SEQUENCE: break; } } @@ -611,6 +617,8 @@ Timeline::right_down (wxMouseEvent& ev) Refresh (); break; case ZOOM_ALL: + case SNAP: + case SEQUENCE: break; } } @@ -810,6 +818,9 @@ Timeline::tool_clicked (Tool t) case ZOOM_ALL: zoom_all (); break; + case SNAP: + case SEQUENCE: + break; } } diff --git a/src/wx/timeline.h b/src/wx/timeline.h index 2133a537d..2214ee13f 100644 --- a/src/wx/timeline.h +++ b/src/wx/timeline.h @@ -69,7 +69,9 @@ public: enum Tool { SELECT, ZOOM, - ZOOM_ALL + ZOOM_ALL, + SNAP, + SEQUENCE }; void tool_clicked (Tool t); diff --git a/src/wx/timeline_dialog.cc b/src/wx/timeline_dialog.cc index d20f89db9..9194ed2bc 100644 --- a/src/wx/timeline_dialog.cc +++ b/src/wx/timeline_dialog.cc @@ -24,12 +24,14 @@ #include "content_panel.h" #include "lib/playlist.h" #include "lib/cross.h" +#include "lib/compose.hpp" #include <wx/graphics.h> #include <iostream> #include <list> using std::list; using std::cout; +using std::string; using boost::shared_ptr; TimelineDialog::TimelineDialog (ContentPanel* cp, shared_ptr<Film> film) @@ -53,25 +55,22 @@ TimelineDialog::TimelineDialog (ContentPanel* cp, shared_ptr<Film> film) { wxBoxSizer* sizer = new wxBoxSizer (wxVERTICAL); - wxBoxSizer* controls = new wxBoxSizer (wxHORIZONTAL); + wxBitmap select (bitmap_path("select"), wxBITMAP_TYPE_PNG); + wxBitmap zoom (bitmap_path ("zoom"), wxBITMAP_TYPE_PNG); + wxBitmap zoom_all (bitmap_path ("zoom_all"), wxBITMAP_TYPE_PNG); + wxBitmap snap (bitmap_path ("snap"), wxBITMAP_TYPE_PNG); + wxBitmap sequence (bitmap_path ("sequence"), wxBITMAP_TYPE_PNG); - wxBitmap select (wxString::Format (wxT ("%s/select.png"), std_to_wx (shared_path().string())), wxBITMAP_TYPE_PNG); - wxBitmap zoom (wxString::Format (wxT ("%s/zoom.png"), std_to_wx (shared_path().string())), wxBITMAP_TYPE_PNG); - wxBitmap zoom_all (wxString::Format (wxT ("%s/zoom_all.png"), std_to_wx (shared_path().string())), wxBITMAP_TYPE_PNG); + _toolbar = new wxToolBar (this, wxID_ANY); + _toolbar->AddRadioTool ((int) Timeline::SELECT, _("Select"), select, wxNullBitmap, _("Select and move content")); + _toolbar->AddRadioTool ((int) Timeline::ZOOM, _("Zoom"), zoom, wxNullBitmap, _("Zoom in / out")); + _toolbar->AddTool ((int) Timeline::ZOOM_ALL, _("Zoom all"), zoom_all, _("Zoom out to whole film")); + _toolbar->AddCheckTool ((int) Timeline::SNAP, _("Snap"), snap, wxNullBitmap, _("Snap")); + _toolbar->AddCheckTool ((int) Timeline::SEQUENCE, _("Sequence"), sequence, wxNullBitmap, _("Keep video and subtitles in sequence")); - wxToolBar* toolbar = new wxToolBar (this, wxID_ANY); - toolbar->AddRadioTool ((int) Timeline::SELECT, _("Select"), select, wxNullBitmap, _("Select and move content")); - toolbar->AddRadioTool ((int) Timeline::ZOOM, _("Zoom"), zoom, wxNullBitmap, _("Zoom in / out")); - toolbar->AddTool ((int) Timeline::ZOOM_ALL, _("Zoom all"), zoom_all, _("Zoom out to whole film")); - controls->Add (toolbar); - toolbar->Bind (wxEVT_TOOL, bind (&TimelineDialog::tool_clicked, this, _1)); + _toolbar->Bind (wxEVT_TOOL, bind (&TimelineDialog::tool_clicked, this, _1)); - _snap = new wxCheckBox (this, wxID_ANY, _("Snap")); - controls->Add (_snap); - _sequence = new wxCheckBox (this, wxID_ANY, _("Keep video and subtitles in sequence")); - controls->Add (_sequence, 1, wxLEFT, 12); - - sizer->Add (controls, 0, wxALL, 12); + sizer->Add (_toolbar, 0, wxALL, 12); sizer->Add (&_timeline, 1, wxEXPAND | wxALL, 12); #ifdef DCPOMATIC_LINUX @@ -85,29 +84,17 @@ TimelineDialog::TimelineDialog (ContentPanel* cp, shared_ptr<Film> film) sizer->Layout (); sizer->SetSizeHints (this); - _snap->SetValue (_timeline.snap ()); - _snap->Bind (wxEVT_CHECKBOX, boost::bind (&TimelineDialog::snap_toggled, this)); + _toolbar->ToggleTool ((int) Timeline::SNAP, _timeline.snap ()); film_changed (Film::SEQUENCE); - _sequence->Bind (wxEVT_CHECKBOX, boost::bind (&TimelineDialog::sequence_toggled, this)); _film_changed_connection = film->Changed.connect (bind (&TimelineDialog::film_changed, this, _1)); } -void -TimelineDialog::snap_toggled () -{ - _timeline.set_snap (_snap->GetValue ()); -} - -void -TimelineDialog::sequence_toggled () +wxString +TimelineDialog::bitmap_path (string name) { - shared_ptr<Film> film = _film.lock (); - if (!film) { - return; - } - - film->set_sequence (_sequence->GetValue ()); + boost::filesystem::path p = shared_path() / String::compose("%1.png", name); + return std_to_wx (p.string ()); } void @@ -119,7 +106,7 @@ TimelineDialog::film_changed (Film::Property p) } if (p == Film::SEQUENCE) { - _sequence->SetValue (film->sequence ()); + _toolbar->ToggleTool ((int) Timeline::SEQUENCE, film->sequence ()); } } @@ -132,5 +119,14 @@ TimelineDialog::set_selection (ContentList selection) void TimelineDialog::tool_clicked (wxCommandEvent& ev) { - _timeline.tool_clicked ((Timeline::Tool) ev.GetId()); + Timeline::Tool t = (Timeline::Tool) ev.GetId(); + _timeline.tool_clicked (t); + if (t == Timeline::SNAP) { + _timeline.set_snap (_snap->IsToggled()); + } else if (t == Timeline::SEQUENCE) { + shared_ptr<Film> film = _film.lock (); + if (film) { + film->set_sequence (_sequence->IsToggled()); + } + } } diff --git a/src/wx/timeline_dialog.h b/src/wx/timeline_dialog.h index 0d91baf22..e9156b89e 100644 --- a/src/wx/timeline_dialog.h +++ b/src/wx/timeline_dialog.h @@ -33,14 +33,14 @@ public: void set_selection (ContentList selection); private: - void snap_toggled (); - void sequence_toggled (); void film_changed (Film::Property); void tool_clicked (wxCommandEvent& id); + wxString bitmap_path (std::string name); boost::weak_ptr<Film> _film; Timeline _timeline; - wxCheckBox* _snap; - wxCheckBox* _sequence; + wxToolBar* _toolbar; + wxToolBarToolBase* _snap; + wxToolBarToolBase* _sequence; boost::signals2::scoped_connection _film_changed_connection; }; |
