X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fkdm_advanced_dialog.cc;h=f5ed88b41c80afef5d4030cd65b0ded5f61b57b9;hb=30c9ecad729397574754163d13253c54a2285a6a;hp=2027c06392efa247bd0c665b490a8f3e798870bb;hpb=9c1bb2e5ca7c80c4e26b1b2e41159aa171360a94;p=dcpomatic.git diff --git a/src/wx/kdm_advanced_dialog.cc b/src/wx/kdm_advanced_dialog.cc index 2027c0639..f5ed88b41 100644 --- a/src/wx/kdm_advanced_dialog.cc +++ b/src/wx/kdm_advanced_dialog.cc @@ -1,5 +1,5 @@ /* - Copyright (C) 2018 Carl Hetherington + Copyright (C) 2018-2019 Carl Hetherington This file is part of DCP-o-matic. @@ -20,8 +20,12 @@ #include "kdm_advanced_dialog.h" #include "check_box.h" +#include "wx_util.h" +#include -KDMAdvancedDialog::KDMAdvancedDialog (wxWindow* parent, bool forensic_mark_video, bool forensic_mark_audio) +using boost::optional; + +KDMAdvancedDialog::KDMAdvancedDialog (wxWindow* parent, bool forensic_mark_video, bool forensic_mark_audio, optional forensic_mark_audio_up_to) : TableDialog (parent, _("Advanced KDM options"), 2, 1, false) { _forensic_mark_video = new CheckBox (this, _("Forensically mark video")); @@ -33,7 +37,29 @@ KDMAdvancedDialog::KDMAdvancedDialog (wxWindow* parent, bool forensic_mark_video add (_forensic_mark_audio); add_spacer (); + _forensic_mark_all_audio = new wxRadioButton (this, wxID_ANY, _("Mark all audio channels")); + _table->Add (_forensic_mark_all_audio, 1, wxEXPAND | wxLEFT, DCPOMATIC_SIZER_GAP); + add_spacer (); + wxBoxSizer* hbox = new wxBoxSizer (wxHORIZONTAL); + _forensic_mark_some_audio = new wxRadioButton (this, wxID_ANY, _("Mark audio channels up to (and including)")); + hbox->Add (_forensic_mark_some_audio, 1, wxEXPAND | wxRIGHT, DCPOMATIC_SIZER_X_GAP); + _forensic_mark_audio_up_to = new wxSpinCtrl (this, wxID_ANY); + hbox->Add (_forensic_mark_audio_up_to, 0, wxRIGHT, DCPOMATIC_SIZER_X_GAP); + _table->Add (hbox, 0, wxLEFT, DCPOMATIC_SIZER_GAP); + add_spacer (); + + if (forensic_mark_audio_up_to) { + _forensic_mark_audio_up_to->SetValue (*forensic_mark_audio_up_to); + _forensic_mark_some_audio->SetValue (true); + } + layout (); + setup_sensitivity (); + + _forensic_mark_audio_up_to->SetRange (1, 15); + _forensic_mark_audio->Bind (wxEVT_CHECKBOX, boost::bind(&KDMAdvancedDialog::setup_sensitivity, this)); + _forensic_mark_all_audio->Bind (wxEVT_RADIOBUTTON, boost::bind(&KDMAdvancedDialog::setup_sensitivity, this)); + _forensic_mark_some_audio->Bind (wxEVT_RADIOBUTTON, boost::bind(&KDMAdvancedDialog::setup_sensitivity, this)); } bool @@ -47,3 +73,21 @@ KDMAdvancedDialog::forensic_mark_audio () const { return _forensic_mark_audio->GetValue (); } + +optional +KDMAdvancedDialog::forensic_mark_audio_up_to () const +{ + if (!_forensic_mark_some_audio->GetValue()) { + return optional(); + } + + return _forensic_mark_audio_up_to->GetValue(); +} + +void +KDMAdvancedDialog::setup_sensitivity () +{ + _forensic_mark_all_audio->Enable (_forensic_mark_audio->GetValue()); + _forensic_mark_some_audio->Enable (_forensic_mark_audio->GetValue()); + _forensic_mark_audio_up_to->Enable (_forensic_mark_audio->GetValue() && _forensic_mark_some_audio->GetValue()); +}