X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Faudio_panel.cc;h=9e2ba986939dea29fd6b9aebd00735eea15bf000;hb=a976df9b5ebd2fc9b37db053faf4e8f33d59b41e;hp=a4976b8c1bca172e888692f0aff3f78c71c3d429;hpb=4e6f15f602c605804f95c6b06af9bf79eaf2dde1;p=dcpomatic.git diff --git a/src/wx/audio_panel.cc b/src/wx/audio_panel.cc index a4976b8c1..9e2ba9869 100644 --- a/src/wx/audio_panel.cc +++ b/src/wx/audio_panel.cc @@ -29,7 +29,6 @@ #include "lib/job_manager.h" #include "lib/dcp_content.h" #include -#include #include #include @@ -39,7 +38,6 @@ using std::string; using std::list; using std::pair; using boost::dynamic_pointer_cast; -using boost::lexical_cast; using boost::shared_ptr; using boost::optional; @@ -56,17 +54,13 @@ AudioPanel::AudioPanel (ContentPanel* p) grid->Add (_reference, wxGBPosition (r, 0), wxGBSpan (1, 2)); ++r; - { - wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL); - _show = new wxButton (this, wxID_ANY, _("Show graph of audio levels...")); - s->Add (_show); - _peak = new wxStaticText (this, wxID_ANY, wxT ("")); - s->Add (_peak, 0, wxALIGN_CENTER_VERTICAL | wxLEFT | wxRIGHT, DCPOMATIC_SIZER_X_GAP); - grid->Add (s, wxGBPosition (r, 0), wxGBSpan (1, 2)); - ++r; - } + _show = new wxButton (this, wxID_ANY, _("Show graph of audio levels...")); + grid->Add (_show, wxGBPosition (r, 0), wxGBSpan (1, 2)); + _peak = new wxStaticText (this, wxID_ANY, wxT ("")); + grid->Add (_peak, wxGBPosition (r, 2), wxGBSpan (1, 2), wxALIGN_CENTER_VERTICAL); + ++r; - add_label_to_grid_bag_sizer (grid, this, _("Gain"), true, wxGBPosition (r, 0)); + add_label_to_sizer (grid, this, _("Gain"), true, wxGBPosition (r, 0)); _gain = new ContentSpinCtrlDouble ( this, new wxSpinCtrlDouble (this), @@ -76,12 +70,12 @@ AudioPanel::AudioPanel (ContentPanel* p) ); _gain->add (grid, wxGBPosition (r, 1)); - add_label_to_grid_bag_sizer (grid, this, _("dB"), false, wxGBPosition (r, 2)); + add_label_to_sizer (grid, this, _("dB"), false, wxGBPosition (r, 2)); _gain_calculate_button = new wxButton (this, wxID_ANY, _("Calculate...")); grid->Add (_gain_calculate_button, wxGBPosition (r, 3)); ++r; - add_label_to_grid_bag_sizer (grid, this, _("Delay"), true, wxGBPosition (r, 0)); + add_label_to_sizer (grid, this, _("Delay"), true, wxGBPosition (r, 0)); _delay = new ContentSpinCtrl ( this, new wxSpinCtrl (this), @@ -92,7 +86,7 @@ AudioPanel::AudioPanel (ContentPanel* p) _delay->add (grid, wxGBPosition (r, 1)); /// TRANSLATORS: this is an abbreviation for milliseconds, the unit of time - add_label_to_grid_bag_sizer (grid, this, _("ms"), false, wxGBPosition (r, 2)); + add_label_to_sizer (grid, this, _("ms"), false, wxGBPosition (r, 2)); ++r; _mapping = new AudioMappingView (this); @@ -141,6 +135,8 @@ AudioPanel::film_changed (Film::Property property) case Film::VIDEO_FRAME_RATE: setup_description (); break; + case Film::REEL_TYPE: + setup_sensitivity (); default: break; } @@ -171,6 +167,8 @@ AudioPanel::film_content_changed (int property) } setup_sensitivity (); + } else if (property == AudioContentProperty::AUDIO_VIDEO_FRAME_RATE) { + setup_description (); } } @@ -230,6 +228,7 @@ AudioPanel::content_selection_changed () _delay->set_content (sel); film_content_changed (AudioContentProperty::AUDIO_STREAMS); + film_content_changed (DCPContentProperty::REFERENCE_AUDIO); setup_sensitivity (); } @@ -238,7 +237,15 @@ void AudioPanel::setup_sensitivity () { AudioContentList sel = _parent->selected_audio (); - _reference->Enable (sel.size() == 1 && dynamic_pointer_cast (sel.front ())); + + shared_ptr dcp; + if (sel.size() == 1) { + dcp = dynamic_pointer_cast (sel.front ()); + } + + list why_not; + bool const can_reference = dcp && dcp->can_reference_audio (why_not); + setup_refer_button (_reference, dcp, can_reference, why_not); if (_reference->GetValue ()) { _gain->wrapped()->Enable (false); @@ -287,8 +294,8 @@ AudioPanel::setup_peak () playlist->add (sel.front ()); try { shared_ptr analysis (new AudioAnalysis (_parent->film()->audio_analysis_path (playlist))); - if (analysis->peak ()) { - float const peak_dB = 20 * log10 (analysis->peak().get()) + analysis->gain_correction (playlist); + if (analysis->sample_peak ()) { + float const peak_dB = 20 * log10 (analysis->sample_peak().get()) + analysis->gain_correction (playlist); if (peak_dB > -3) { alert = true; }