X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Ftimeline_dialog.cc;h=bc3e8db9931d45ae7de3b39787df38aa409633c6;hb=0dcbc398124f740e4fd7b552926f601a3e5c755e;hp=35d5eec2105b5190ccaedd91973706c29895aa1f;hpb=a0856e3fbef17f24073b01cb96be6bbcb229ecbc;p=dcpomatic.git diff --git a/src/wx/timeline_dialog.cc b/src/wx/timeline_dialog.cc index 35d5eec21..bc3e8db99 100644 --- a/src/wx/timeline_dialog.cc +++ b/src/wx/timeline_dialog.cc @@ -19,10 +19,10 @@ #include #include +#include "lib/playlist.h" #include "film_editor.h" #include "timeline_dialog.h" #include "wx_util.h" -#include "playlist.h" using std::list; using std::cout; @@ -30,13 +30,58 @@ using boost::shared_ptr; TimelineDialog::TimelineDialog (FilmEditor* ed, shared_ptr film) : wxDialog (ed, wxID_ANY, _("Timeline"), wxDefaultPosition, wxSize (640, 512), wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER | wxFULL_REPAINT_ON_RESIZE) + , _film (film) , _timeline (this, ed, film) { wxBoxSizer* sizer = new wxBoxSizer (wxVERTICAL); - + + wxBoxSizer* controls = new wxBoxSizer (wxHORIZONTAL); + _snap = new wxCheckBox (this, wxID_ANY, _("Snap")); + controls->Add (_snap); + _sequence_video = new wxCheckBox (this, wxID_ANY, _("Keep video in sequence")); + controls->Add (_sequence_video, 1, wxLEFT, 12); + + sizer->Add (controls, 0, wxALL, 12); sizer->Add (&_timeline, 1, wxEXPAND | wxALL, 12); SetSizer (sizer); 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_VIDEO); + _snap->Bind (wxEVT_COMMAND_CHECKBOX_CLICKED, boost::bind (&TimelineDialog::sequence_video_toggled, this)); + + film->Changed.connect (bind (&TimelineDialog::film_changed, this, _1)); +} + +void +TimelineDialog::snap_toggled () +{ + _timeline.set_snap (_snap->GetValue ()); +} + +void +TimelineDialog::sequence_video_toggled () +{ + shared_ptr film = _film.lock (); + if (!film) { + return; + } + + film->set_sequence_video (_sequence_video->GetValue ()); +} + +void +TimelineDialog::film_changed (Film::Property p) +{ + shared_ptr film = _film.lock (); + if (!film) { + return; + } + + if (p == Film::SEQUENCE_VIDEO) { + _sequence_video->SetValue (film->sequence_video ()); + } }