X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Fwx%2Fdcp_panel.cc;h=12345ace21b6998c9f75259a6f52615f4edc8895;hb=53c7f717da44c6ff681bde8946875e4f39764b25;hp=397a29d4819f7cd4b64067d47be24570873a4481;hpb=bc2b76ae17ad11bbcaf4291accc49f4fd5ad8157;p=dcpomatic.git diff --git a/src/wx/dcp_panel.cc b/src/wx/dcp_panel.cc index 397a29d48..12345ace2 100644 --- a/src/wx/dcp_panel.cc +++ b/src/wx/dcp_panel.cc @@ -23,6 +23,7 @@ #include "key_dialog.h" #include "isdcf_metadata_dialog.h" #include "audio_dialog.h" +#include "focus_manager.h" #include "lib/ratio.h" #include "lib/config.h" #include "lib/dcp_content_type.h" @@ -31,7 +32,7 @@ #include "lib/ffmpeg_content.h" #include "lib/audio_processor.h" #include "lib/video_content.h" -#include "lib/subtitle_content.h" +#include "lib/text_content.h" #include "lib/dcp_content.h" #include "lib/audio_content.h" #include @@ -64,33 +65,16 @@ DCPPanel::DCPPanel (wxNotebook* n, boost::shared_ptr film) _sizer = new wxBoxSizer (wxVERTICAL); _panel->SetSizer (_sizer); - wxGridBagSizer* grid = new wxGridBagSizer (DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP); - _sizer->Add (grid, 0, wxEXPAND | wxALL, 8); + _grid = new wxGridBagSizer (DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP); + _sizer->Add (_grid, 0, wxEXPAND | wxALL, 8); - int r = 0; - - add_label_to_sizer (grid, _panel, _("Name"), true, wxGBPosition (r, 0)); + _name_label = create_label (_panel, _("Name"), true); _name = new wxTextCtrl (_panel, wxID_ANY); - grid->Add (_name, wxGBPosition(r, 1), wxDefaultSpan, wxEXPAND | wxLEFT | wxRIGHT); - ++r; - - int flags = wxALIGN_CENTER_VERTICAL; -#ifdef __WXOSX__ - flags |= wxALIGN_RIGHT; -#endif + FocusManager::instance()->add(_name); _use_isdcf_name = new wxCheckBox (_panel, wxID_ANY, _("Use ISDCF name")); - grid->Add (_use_isdcf_name, wxGBPosition (r, 0), wxDefaultSpan, flags); - - { - wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL); - _edit_isdcf_button = new wxButton (_panel, wxID_ANY, _("Details...")); - s->Add (_edit_isdcf_button, 1, wxEXPAND | wxRIGHT, DCPOMATIC_SIZER_X_GAP); - _copy_isdcf_name_button = new wxButton (_panel, wxID_ANY, _("Copy as name")); - s->Add (_copy_isdcf_name_button, 1, wxEXPAND | wxLEFT, DCPOMATIC_SIZER_X_GAP); - grid->Add (s, wxGBPosition (r, 1), wxDefaultSpan, wxEXPAND); - ++r; - } + _edit_isdcf_button = new wxButton (_panel, wxID_ANY, _("Details...")); + _copy_isdcf_name_button = new wxButton (_panel, wxID_ANY, _("Copy as name")); /* wxST_ELLIPSIZE_MIDDLE works around a bug in GTK2 and/or wxWidgets, see http://trac.wxwidgets.org/ticket/12539 @@ -100,79 +84,49 @@ DCPPanel::DCPPanel (wxNotebook* n, boost::shared_ptr film) wxALIGN_CENTRE_HORIZONTAL | wxST_NO_AUTORESIZE | wxST_ELLIPSIZE_MIDDLE ); - grid->Add (_dcp_name, wxGBPosition(r, 0), wxGBSpan (1, 2), wxALIGN_CENTER_VERTICAL | wxEXPAND); - ++r; - - add_label_to_sizer (grid, _panel, _("Content Type"), true, wxGBPosition (r, 0)); + _dcp_content_type_label = create_label (_panel, _("Content Type"), true); _dcp_content_type = new wxChoice (_panel, wxID_ANY); - grid->Add (_dcp_content_type, wxGBPosition (r, 1)); - ++r; - - _notebook = new wxNotebook (_panel, wxID_ANY); - _sizer->Add (_notebook, 1, wxEXPAND | wxTOP, 6); - - _notebook->AddPage (make_video_panel (), _("Video"), false); - _notebook->AddPage (make_audio_panel (), _("Audio"), false); _signed = new wxCheckBox (_panel, wxID_ANY, _("Signed")); - grid->Add (_signed, wxGBPosition (r, 0), wxGBSpan (1, 2)); - ++r; - _encrypted = new wxCheckBox (_panel, wxID_ANY, _("Encrypted")); - grid->Add (_encrypted, wxGBPosition (r, 0), wxGBSpan (1, 2)); - ++r; wxClientDC dc (_panel); wxSize size = dc.GetTextExtent (wxT ("GGGGGGGG...")); size.SetHeight (-1); - { - add_label_to_sizer (grid, _panel, _("Key"), true, wxGBPosition (r, 0)); - wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL); - _key = new wxStaticText (_panel, wxID_ANY, "", wxDefaultPosition, size); - s->Add (_key, 1, wxALIGN_CENTER_VERTICAL); - _edit_key = new wxButton (_panel, wxID_ANY, _("Edit...")); - s->Add (_edit_key); - grid->Add (s, wxGBPosition (r, 1)); - ++r; - } + _key_label = create_label (_panel, _("Key"), true); + _key = new wxStaticText (_panel, wxID_ANY, "", wxDefaultPosition, size); + _edit_key = new wxButton (_panel, wxID_ANY, _("Edit...")); - add_label_to_sizer (grid, _panel, _("Reels"), true, wxGBPosition (r, 0)); + _reels_label = create_label (_panel, _("Reels"), true); _reel_type = new wxChoice (_panel, wxID_ANY); - grid->Add (_reel_type, wxGBPosition (r, 1), wxDefaultSpan, wxALIGN_CENTER_VERTICAL); - ++r; - add_label_to_sizer (grid, _panel, _("Reel length"), true, wxGBPosition (r, 0)); - - { - wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL); - _reel_length = new wxSpinCtrl (_panel, wxID_ANY); - s->Add (_reel_length); - add_label_to_sizer (s, _panel, _("GB"), false); - grid->Add (s, wxGBPosition (r, 1)); - ++r; - } + _reel_length_label = create_label (_panel, _("Reel length"), true); + _reel_length = new wxSpinCtrl (_panel, wxID_ANY); + _reel_length_gb_label = create_label (_panel, _("GB"), false); - add_label_to_sizer (grid, _panel, _("Standard"), true, wxGBPosition (r, 0)); + _standard_label = create_label (_panel, _("Standard"), true); _standard = new wxChoice (_panel, wxID_ANY); - grid->Add (_standard, wxGBPosition (r, 1), wxDefaultSpan, wxALIGN_CENTER_VERTICAL); - ++r; _upload_after_make_dcp = new wxCheckBox (_panel, wxID_ANY, _("Upload DCP to TMS after it is made")); - grid->Add (_upload_after_make_dcp, wxGBPosition (r, 0), wxGBSpan (1, 2)); - ++r; + + _notebook = new wxNotebook (_panel, wxID_ANY); + _sizer->Add (_notebook, 1, wxEXPAND | wxTOP, 6); + + _notebook->AddPage (make_video_panel (), _("Video"), false); + _notebook->AddPage (make_audio_panel (), _("Audio"), false); _name->Bind (wxEVT_TEXT, boost::bind (&DCPPanel::name_changed, this)); _use_isdcf_name->Bind (wxEVT_CHECKBOX, boost::bind (&DCPPanel::use_isdcf_name_toggled, this)); _edit_isdcf_button->Bind (wxEVT_BUTTON, boost::bind (&DCPPanel::edit_isdcf_button_clicked, this)); _copy_isdcf_name_button->Bind(wxEVT_BUTTON, boost::bind (&DCPPanel::copy_isdcf_name_button_clicked, this)); - _dcp_content_type->Bind (wxEVT_CHOICE, boost::bind (&DCPPanel::dcp_content_type_changed, this)); + _dcp_content_type->Bind (wxEVT_CHOICE, boost::bind (&DCPPanel::dcp_content_type_changed, this)); _signed->Bind (wxEVT_CHECKBOX, boost::bind (&DCPPanel::signed_toggled, this)); _encrypted->Bind (wxEVT_CHECKBOX, boost::bind (&DCPPanel::encrypted_toggled, this)); _edit_key->Bind (wxEVT_BUTTON, boost::bind (&DCPPanel::edit_key_clicked, this)); - _reel_type->Bind (wxEVT_CHOICE, boost::bind (&DCPPanel::reel_type_changed, this)); + _reel_type->Bind (wxEVT_CHOICE, boost::bind (&DCPPanel::reel_type_changed, this)); _reel_length->Bind (wxEVT_SPINCTRL, boost::bind (&DCPPanel::reel_length_changed, this)); - _standard->Bind (wxEVT_CHOICE, boost::bind (&DCPPanel::standard_changed, this)); + _standard->Bind (wxEVT_CHOICE, boost::bind (&DCPPanel::standard_changed, this)); _upload_after_make_dcp->Bind (wxEVT_CHECKBOX, boost::bind (&DCPPanel::upload_after_make_dcp_changed, this)); BOOST_FOREACH (DCPContentType const * i, DCPContentType::all()) { @@ -189,7 +143,100 @@ DCPPanel::DCPPanel (wxNotebook* n, boost::shared_ptr film) _standard->Append (_("SMPTE")); _standard->Append (_("Interop")); - Config::instance()->Changed.connect (boost::bind (&DCPPanel::config_changed, this)); + Config::instance()->Changed.connect (boost::bind (&DCPPanel::config_changed, this, _1)); + + add_to_grid (); +} + +void +DCPPanel::add_to_grid () +{ + Config::Interface interface = Config::instance()->interface_complexity (); + + int r = 0; + + add_label_to_sizer (_grid, _name_label, true, wxGBPosition (r, 0)); + _grid->Add (_name, wxGBPosition(r, 1), wxDefaultSpan, wxEXPAND | wxLEFT | wxRIGHT); + ++r; + + int flags = wxALIGN_CENTER_VERTICAL; +#ifdef __WXOSX__ + flags |= wxALIGN_RIGHT; +#endif + + _use_isdcf_name->Show (interface == Config::INTERFACE_FULL); + _edit_isdcf_button->Show (interface == Config::INTERFACE_FULL); + _copy_isdcf_name_button->Show (interface == Config::INTERFACE_FULL); + + if (interface == Config::INTERFACE_FULL) { + _grid->Add (_use_isdcf_name, wxGBPosition (r, 0), wxDefaultSpan, flags); + { + wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL); + s->Add (_edit_isdcf_button, 1, wxEXPAND | wxRIGHT, DCPOMATIC_SIZER_X_GAP); + s->Add (_copy_isdcf_name_button, 1, wxEXPAND | wxLEFT, DCPOMATIC_SIZER_X_GAP); + _grid->Add (s, wxGBPosition (r, 1), wxDefaultSpan, wxEXPAND); + } + ++r; + } + + _grid->Add (_dcp_name, wxGBPosition(r, 0), wxGBSpan (1, 2), wxALIGN_CENTER_VERTICAL | wxEXPAND); + ++r; + + add_label_to_sizer (_grid, _dcp_content_type_label, true, wxGBPosition (r, 0)); + _grid->Add (_dcp_content_type, wxGBPosition (r, 1)); + ++r; + + _signed->Show (interface == Config::INTERFACE_FULL); + if (interface == Config::INTERFACE_FULL) { + _grid->Add (_signed, wxGBPosition (r, 0), wxGBSpan (1, 2)); + ++r; + } + + _grid->Add (_encrypted, wxGBPosition (r, 0), wxGBSpan (1, 2)); + ++r; + + _key_label->Show (interface == Config::INTERFACE_FULL); + _key->Show (interface == Config::INTERFACE_FULL); + _edit_key->Show (interface == Config::INTERFACE_FULL); + _reels_label->Show (interface == Config::INTERFACE_FULL); + _reel_type->Show (interface == Config::INTERFACE_FULL); + _reel_length_label->Show (interface == Config::INTERFACE_FULL); + _reel_length->Show (interface == Config::INTERFACE_FULL); + _reel_length_gb_label->Show (interface == Config::INTERFACE_FULL); + _standard_label->Show (interface == Config::INTERFACE_FULL); + _standard->Show (interface == Config::INTERFACE_FULL); + _upload_after_make_dcp->Show (interface == Config::INTERFACE_FULL); + + if (interface == Config::INTERFACE_FULL) { + add_label_to_sizer (_grid, _key_label, true, wxGBPosition (r, 0)); + { + wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL); + s->Add (_key, 1, wxALIGN_CENTER_VERTICAL); + s->Add (_edit_key); + _grid->Add (s, wxGBPosition (r, 1)); + } + ++r; + + add_label_to_sizer (_grid, _reels_label, true, wxGBPosition (r, 0)); + _grid->Add (_reel_type, wxGBPosition (r, 1), wxDefaultSpan, wxALIGN_CENTER_VERTICAL); + ++r; + + add_label_to_sizer (_grid, _reel_length_label, true, wxGBPosition (r, 0)); + { + wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL); + s->Add (_reel_length); + add_label_to_sizer (s, _reel_length_gb_label, false); + _grid->Add (s, wxGBPosition (r, 1)); + } + ++r; + + add_label_to_sizer (_grid, _standard_label, true, wxGBPosition (r, 0)); + _grid->Add (_standard, wxGBPosition (r, 1), wxDefaultSpan, wxALIGN_CENTER_VERTICAL); + ++r; + + _grid->Add (_upload_after_make_dcp, wxGBPosition (r, 0), wxGBSpan (1, 2)); + ++r; + } } void @@ -430,12 +477,12 @@ void DCPPanel::film_content_changed (int property) { if (property == AudioContentProperty::STREAMS || - property == SubtitleContentProperty::USE || - property == SubtitleContentProperty::BURN || + property == TextContentProperty::USE || + property == TextContentProperty::BURN || property == VideoContentProperty::SCALE || property == DCPContentProperty::REFERENCE_VIDEO || property == DCPContentProperty::REFERENCE_AUDIO || - property == DCPContentProperty::REFERENCE_SUBTITLE) { + property == DCPContentProperty::REFERENCE_TEXT) { setup_dcp_name (); setup_sensitivity (); } @@ -621,10 +668,25 @@ DCPPanel::three_d_changed () } void -DCPPanel::config_changed () +DCPPanel::config_changed (Config::Property p) { _j2k_bandwidth->SetRange (1, Config::instance()->maximum_j2k_bandwidth() / 1000000); setup_frame_rate_widget (); + + if (p == Config::INTERFACE_COMPLEXITY) { + _grid->Clear (); + add_to_grid (); + _sizer->Layout (); + _grid->Layout (); + + _video_grid->Clear (); + add_video_panel_to_grid (); + _video_grid->Layout (); + + _audio_grid->Clear (); + add_audio_panel_to_grid (); + _audio_grid->Layout (); + } } void @@ -646,55 +708,35 @@ DCPPanel::make_video_panel () { wxPanel* panel = new wxPanel (_notebook); wxSizer* sizer = new wxBoxSizer (wxVERTICAL); - wxGridBagSizer* grid = new wxGridBagSizer (DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP); - sizer->Add (grid, 0, wxALL, 8); + _video_grid = new wxGridBagSizer (DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP); + sizer->Add (_video_grid, 0, wxALL, 8); panel->SetSizer (sizer); int r = 0; - add_label_to_sizer (grid, panel, _("Container"), true, wxGBPosition (r, 0)); - { - wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL); - _container = new wxChoice (panel, wxID_ANY); - s->Add (_container, 1, wxEXPAND | wxRIGHT, DCPOMATIC_SIZER_X_GAP); - _container_size = new wxStaticText (panel, wxID_ANY, wxT ("")); - s->Add (_container_size, 1, wxLEFT | wxALIGN_CENTER_VERTICAL); - grid->Add (s, wxGBPosition (r,1 ), wxDefaultSpan, wxEXPAND); - ++r; - } + _container_label = create_label (panel, _("Container"), true); + _container = new wxChoice (panel, wxID_ANY); + _container_size = new wxStaticText (panel, wxID_ANY, wxT ("")); - add_label_to_sizer (grid, panel, _("Resolution"), true, wxGBPosition (r, 0)); + _resolution_label = create_label (panel, _("Resolution"), true); _resolution = new wxChoice (panel, wxID_ANY); - grid->Add (_resolution, wxGBPosition (r, 1)); - ++r; - add_label_to_sizer (grid, panel, _("Frame Rate"), true, wxGBPosition (r, 0)); - { - _frame_rate_sizer = new wxBoxSizer (wxHORIZONTAL); - _frame_rate_choice = new wxChoice (panel, wxID_ANY); - _frame_rate_sizer->Add (_frame_rate_choice, 1, wxALIGN_CENTER_VERTICAL); - _frame_rate_spin = new wxSpinCtrl (panel, wxID_ANY); - _frame_rate_sizer->Add (_frame_rate_spin, 1, wxALIGN_CENTER_VERTICAL); - setup_frame_rate_widget (); - _best_frame_rate = new wxButton (panel, wxID_ANY, _("Use best")); - _frame_rate_sizer->Add (_best_frame_rate, 1, wxALIGN_CENTER_VERTICAL); - grid->Add (_frame_rate_sizer, wxGBPosition (r, 1)); - ++r; - } + _frame_rate_label = create_label (panel, _("Frame Rate"), true); + _frame_rate_choice = new wxChoice (panel, wxID_ANY); + _frame_rate_sizer = new wxBoxSizer (wxHORIZONTAL); + _frame_rate_sizer->Add (_frame_rate_choice, 1, wxALIGN_CENTER_VERTICAL); + _frame_rate_spin = new wxSpinCtrl (panel, wxID_ANY); + _frame_rate_sizer->Add (_frame_rate_spin, 1, wxALIGN_CENTER_VERTICAL); + setup_frame_rate_widget (); + _best_frame_rate = new wxButton (panel, wxID_ANY, _("Use best")); + _frame_rate_sizer->Add (_best_frame_rate, 1, wxALIGN_CENTER_VERTICAL); _three_d = new wxCheckBox (panel, wxID_ANY, _("3D")); - grid->Add (_three_d, wxGBPosition (r, 0), wxGBSpan (1, 2)); ++r; - { - add_label_to_sizer (grid, panel, _("JPEG2000 bandwidth\nfor newly-encoded data"), true, wxGBPosition (r, 0)); - wxSizer* s = new wxBoxSizer (wxHORIZONTAL); - _j2k_bandwidth = new wxSpinCtrl (panel, wxID_ANY); - s->Add (_j2k_bandwidth, 1); - add_label_to_sizer (s, panel, _("Mbit/s"), false); - grid->Add (s, wxGBPosition (r, 1)); - } - ++r; + _j2k_bandwidth_label = create_label (panel, _("JPEG2000 bandwidth\nfor newly-encoded data"), true); + _j2k_bandwidth = new wxSpinCtrl (panel, wxID_ANY); + _mbits_label = create_label (panel, _("Mbit/s"), false); _container->Bind (wxEVT_CHOICE, boost::bind (&DCPPanel::container_changed, this)); _frame_rate_choice->Bind(wxEVT_CHOICE, boost::bind (&DCPPanel::frame_rate_choice_changed, this)); @@ -720,9 +762,58 @@ DCPPanel::make_video_panel () _resolution->Append (_("2K")); _resolution->Append (_("4K")); + add_video_panel_to_grid (); + return panel; } +void +DCPPanel::add_video_panel_to_grid () +{ + bool const full = Config::instance()->interface_complexity() == Config::INTERFACE_FULL; + + int r = 0; + + add_label_to_sizer (_video_grid, _container_label, true, wxGBPosition (r, 0)); + { + wxBoxSizer* s = new wxBoxSizer (wxHORIZONTAL); + s->Add (_container, 1, wxEXPAND | wxRIGHT, DCPOMATIC_SIZER_X_GAP); + s->Add (_container_size, 1, wxLEFT | wxALIGN_CENTER_VERTICAL); + _video_grid->Add (s, wxGBPosition(r, 1)); + ++r; + } + + add_label_to_sizer (_video_grid, _resolution_label, true, wxGBPosition (r, 0)); + _video_grid->Add (_resolution, wxGBPosition (r, 1)); + ++r; + + add_label_to_sizer (_video_grid, _frame_rate_label, true, wxGBPosition (r, 0)); + { + _frame_rate_sizer = new wxBoxSizer (wxHORIZONTAL); + _frame_rate_sizer->Add (_frame_rate_choice, 1, wxALIGN_CENTER_VERTICAL); + _frame_rate_sizer->Add (_frame_rate_spin, 1, wxALIGN_CENTER_VERTICAL); + _frame_rate_sizer->Add (_best_frame_rate, 1, wxALIGN_CENTER_VERTICAL); + _video_grid->Add (_frame_rate_sizer, wxGBPosition (r, 1)); + ++r; + } + + _video_grid->Add (_three_d, wxGBPosition (r, 0), wxGBSpan (1, 2)); + ++r; + + _j2k_bandwidth_label->Show (full); + _j2k_bandwidth->Show (full); + _mbits_label->Show (full); + + if (full) { + add_label_to_sizer (_video_grid, _j2k_bandwidth_label, true, wxGBPosition (r, 0)); + wxSizer* s = new wxBoxSizer (wxHORIZONTAL); + s->Add (_j2k_bandwidth, 1); + add_label_to_sizer (s, _mbits_label, false); + _video_grid->Add (s, wxGBPosition (r, 1)); + ++r; + } +} + int DCPPanel::minimum_allowed_audio_channels () const { @@ -743,38 +834,61 @@ DCPPanel::make_audio_panel () { wxPanel* panel = new wxPanel (_notebook); wxSizer* sizer = new wxBoxSizer (wxVERTICAL); - wxGridBagSizer* grid = new wxGridBagSizer (DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP); - sizer->Add (grid, 0, wxALL, 8); + _audio_grid = new wxGridBagSizer (DCPOMATIC_SIZER_X_GAP, DCPOMATIC_SIZER_Y_GAP); + sizer->Add (_audio_grid, 0, wxALL, 8); panel->SetSizer (sizer); - int r = 0; - - add_label_to_sizer (grid, panel, _("Channels"), true, wxGBPosition (r, 0)); + _channels_label = create_label (panel, _("Channels"), true); _audio_channels = new wxChoice (panel, wxID_ANY); setup_audio_channels_choice (_audio_channels, minimum_allowed_audio_channels ()); - grid->Add (_audio_channels, wxGBPosition (r, 1)); - ++r; - add_label_to_sizer (grid, panel, _("Processor"), true, wxGBPosition (r, 0)); + _processor_label = create_label (panel, _("Processor"), true); _audio_processor = new wxChoice (panel, wxID_ANY); _audio_processor->Append (_("None"), new wxStringClientData (N_("none"))); BOOST_FOREACH (AudioProcessor const * ap, AudioProcessor::all ()) { _audio_processor->Append (std_to_wx (ap->name ()), new wxStringClientData (std_to_wx (ap->id ()))); } - grid->Add (_audio_processor, wxGBPosition (r, 1)); - ++r; _show_audio = new wxButton (panel, wxID_ANY, _("Show audio...")); - grid->Add (_show_audio, wxGBPosition (r, 0), wxGBSpan (1, 2)); - ++r; _audio_channels->Bind (wxEVT_CHOICE, boost::bind (&DCPPanel::audio_channels_changed, this)); _audio_processor->Bind (wxEVT_CHOICE, boost::bind (&DCPPanel::audio_processor_changed, this)); _show_audio->Bind (wxEVT_BUTTON, boost::bind (&DCPPanel::show_audio_clicked, this)); + add_audio_panel_to_grid (); + return panel; } +void +DCPPanel::add_audio_panel_to_grid () +{ + bool const full = Config::instance()->interface_complexity() == Config::INTERFACE_FULL; + + int r = 0; + + _channels_label->Show (full); + _audio_channels->Show (full); + + if (full) { + add_label_to_sizer (_audio_grid, _channels_label, true, wxGBPosition (r, 0)); + _audio_grid->Add (_audio_channels, wxGBPosition (r, 1)); + ++r; + } + + _processor_label->Show (full); + _audio_processor->Show (full); + + if (full) { + add_label_to_sizer (_audio_grid, _processor_label, true, wxGBPosition (r, 0)); + _audio_grid->Add (_audio_processor, wxGBPosition (r, 1)); + ++r; + } + + _audio_grid->Add (_show_audio, wxGBPosition (r, 0), wxGBSpan (1, 2)); + ++r; +} + void DCPPanel::copy_isdcf_name_button_clicked () {