X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Fwx%2Ftimeline_dialog.cc;h=3a720cfecff8ec958d336c139c920bb64bcc6144;hp=e050c27d97acb1b88915c647d6fd9595facee1a1;hb=9001a63be211fd8e97431f8fc07c66af01554f5a;hpb=c3433d59c0d320f0451df18c9cb06bfd5fff40b0 diff --git a/src/wx/timeline_dialog.cc b/src/wx/timeline_dialog.cc index e050c27d9..3a720cfec 100644 --- a/src/wx/timeline_dialog.cc +++ b/src/wx/timeline_dialog.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2016 Carl Hetherington + Copyright (C) 2013-2019 Carl Hetherington This file is part of DCP-o-matic. @@ -18,22 +18,26 @@ */ -#include -#include -#include "lib/playlist.h" #include "film_editor.h" #include "timeline_dialog.h" #include "wx_util.h" #include "content_panel.h" +#include "lib/playlist.h" +#include "lib/cross.h" +#include "lib/compose.hpp" +#include #include +#include using std::list; using std::cout; +using std::string; using boost::shared_ptr; +using boost::weak_ptr; -TimelineDialog::TimelineDialog (ContentPanel* cp, shared_ptr film) +TimelineDialog::TimelineDialog (ContentPanel* cp, shared_ptr film, weak_ptr viewer) : wxDialog ( - cp->panel(), + cp->window(), wxID_ANY, _("Timeline"), wxDefaultPosition, @@ -48,17 +52,28 @@ TimelineDialog::TimelineDialog (ContentPanel* cp, shared_ptr film) #endif ) , _film (film) - , _timeline (this, cp, film) + , _timeline (this, cp, film, viewer) { wxBoxSizer* sizer = new wxBoxSizer (wxVERTICAL); - wxBoxSizer* controls = new wxBoxSizer (wxHORIZONTAL); - _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); + 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); - sizer->Add (controls, 0, wxALL, 12); + _toolbar = new wxToolBar (this, wxID_ANY, wxDefaultPosition, wxDefaultSize, wxTB_HORIZONTAL); + _toolbar->SetMargins (4, 4); + _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")); + _toolbar->Realize (); + + _toolbar->Bind (wxEVT_TOOL, bind (&TimelineDialog::tool_clicked, this, _1)); + + sizer->Add (_toolbar, 0, wxALL, 12); sizer->Add (&_timeline, 1, wxEXPAND | wxALL, 12); #ifdef DCPOMATIC_LINUX @@ -72,41 +87,47 @@ TimelineDialog::TimelineDialog (ContentPanel* cp, shared_ptr film) sizer->Layout (); sizer->SetSizeHints (this); - _snap->SetValue (_timeline.snap ()); - _snap->Bind (wxEVT_COMMAND_CHECKBOX_CLICKED, boost::bind (&TimelineDialog::snap_toggled, this)); - film_changed (Film::SEQUENCE); - _sequence->Bind (wxEVT_COMMAND_CHECKBOX_CLICKED, boost::bind (&TimelineDialog::sequence_toggled, this)); + _toolbar->ToggleTool ((int) Timeline::SNAP, _timeline.snap ()); + film_change (CHANGE_TYPE_DONE, Film::SEQUENCE); - _film_changed_connection = film->Changed.connect (bind (&TimelineDialog::film_changed, this, _1)); + _film_changed_connection = film->Change.connect (bind (&TimelineDialog::film_change, this, _1, _2)); } -void -TimelineDialog::snap_toggled () +wxString +TimelineDialog::bitmap_path (string name) { - _timeline.set_snap (_snap->GetValue ()); + boost::filesystem::path base; + +#ifdef DCPOMATIC_DEBUG + /* Hack to allow OS X to find icons when running from the source tree */ + char* path = getenv ("DCPOMATIC_GRAPHICS"); + if (path) { + base = path; + } else { + base = shared_path(); + } +#else + base = shared_path(); +#endif + + boost::filesystem::path p = base / String::compose("%1.png", name); + return std_to_wx (p.string()); } void -TimelineDialog::sequence_toggled () +TimelineDialog::film_change (ChangeType type, Film::Property p) { - shared_ptr film = _film.lock (); - if (!film) { + if (type != CHANGE_TYPE_DONE) { return; } - film->set_sequence (_sequence->GetValue ()); -} - -void -TimelineDialog::film_changed (Film::Property p) -{ shared_ptr film = _film.lock (); if (!film) { return; } if (p == Film::SEQUENCE) { - _sequence->SetValue (film->sequence ()); + _toolbar->ToggleTool ((int) Timeline::SEQUENCE, film->sequence ()); } } @@ -115,3 +136,18 @@ TimelineDialog::set_selection (ContentList selection) { _timeline.set_selection (selection); } + +void +TimelineDialog::tool_clicked (wxCommandEvent& ev) +{ + Timeline::Tool t = (Timeline::Tool) ev.GetId(); + _timeline.tool_clicked (t); + if (t == Timeline::SNAP) { + _timeline.set_snap (_toolbar->GetToolState ((int) t)); + } else if (t == Timeline::SEQUENCE) { + shared_ptr film = _film.lock (); + if (film) { + film->set_sequence (_toolbar->GetToolState ((int) t)); + } + } +}