X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fadd_route_dialog.cc;h=cc1a99759d1a3ab761aa1cd6608e882579a454a9;hb=6001b8d28dd764bada8b9198a5f91e0a2f5251f6;hp=448fa7ea8f30bb8fccfd14b801b1e55acccfd20b;hpb=8e79cd5610789b377d0975640a555cc45d9300cb;p=ardour.git diff --git a/gtk2_ardour/add_route_dialog.cc b/gtk2_ardour/add_route_dialog.cc index 448fa7ea8f..cc1a99759d 100644 --- a/gtk2_ardour/add_route_dialog.cc +++ b/gtk2_ardour/add_route_dialog.cc @@ -1,21 +1,20 @@ /* - Copyright (C) 2003 Paul Davis + Copyright (C) 2003 Paul Davis - This program is free software; you can redistribute it and/or modify - it under the terms of the GNU General Public License as published by - the Free Software Foundation; either version 2 of the License, or - (at your option) any later version. + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. - This program is distributed in the hope that it will be useful, - but WITHOUT ANY WARRANTY; without even the implied warranty of - MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - GNU General Public License for more details. + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. - You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + You should have received a copy of the GNU General Public License + along with this program; if not, write to the Free Software + Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id$ */ #include @@ -23,9 +22,14 @@ #include #include -#include -#include -#include +#include + +#include "pbd/error.h" +#include "pbd/convert.h" +#include "gtkmm2ext/utils.h" +#include "ardour/profile.h" +#include "ardour/template_utils.h" +#include "ardour/session.h" #include "utils.h" #include "add_route_dialog.h" @@ -36,6 +40,7 @@ using namespace Gtkmm2ext; using namespace sigc; using namespace std; using namespace PBD; +using namespace ARDOUR; static const char* channel_setup_names[] = { N_("Mono"), @@ -45,11 +50,13 @@ static const char* channel_setup_names[] = { N_("6 Channels"), N_("8 Channels"), N_("Manual Setup"), + N_("MIDI"), 0 }; static const char* track_mode_names[] = { N_("Normal"), + N_("Non Layered"), N_("Tape"), 0 }; @@ -62,80 +69,147 @@ AddRouteDialog::AddRouteDialog () : Dialog (_("ardour: add track/bus")), track_button (_("Tracks")), bus_button (_("Busses")), + template_button (_("Using this template:")), routes_adjustment (1, 1, 128, 1, 4), routes_spinner (routes_adjustment) { if (channel_combo_strings.empty()) { channel_combo_strings = I18N (channel_setup_names); + + if (ARDOUR::Profile->get_sae()) { + /* remove all but the first two (Mono & Stereo) */ + + while (track_mode_strings.size() > 2) { + track_mode_strings.pop_back(); + } + } + } if (track_mode_strings.empty()) { track_mode_strings = I18N (track_mode_names); - } + if (ARDOUR::Profile->get_sae()) { + /* remove all but the first track mode (Normal) */ + + while (track_mode_strings.size() > 1) { + track_mode_strings.pop_back(); + } + } + } + set_name ("AddRouteDialog"); set_wmclass (X_("ardour_add_track_bus"), "Ardour"); set_position (Gtk::WIN_POS_MOUSE); + set_resizable (false); name_template_entry.set_name ("AddRouteDialogNameTemplateEntry"); track_button.set_name ("AddRouteDialogRadioButton"); bus_button.set_name ("AddRouteDialogRadioButton"); + template_button.set_name ("AddRouteDialogRadioButton"); routes_spinner.set_name ("AddRouteDialogSpinner"); RadioButton::Group g = track_button.get_group(); bus_button.set_group (g); + template_button.set_group (g); track_button.set_active (true); - HBox *hbrb = manage (new HBox); + /* add */ - hbrb->set_spacing (6); - hbrb->pack_start (routes_spinner, true, false, 5); - hbrb->pack_start (track_button, true, false, 5); - hbrb->pack_start (bus_button, true, false, 5); + HBox* hbox1 = manage (new HBox); + hbox1->set_spacing (6); + Label* label1 = manage (new Label (_("Add this many:"))); + hbox1->pack_start (*label1, PACK_SHRINK); + hbox1->pack_start (routes_spinner, PACK_SHRINK); - aframe.set_label (_("Add")); - aframe.set_shadow_type (SHADOW_IN); - aframe.add (*hbrb); + HBox* hbox2 = manage (new HBox); + hbox2->set_spacing (6); + hbox2->set_border_width (6); + hbox2->pack_start (*hbox1, PACK_EXPAND_WIDGET); + + /* templates */ + + hbox3 = new HBox; + hbox3->set_spacing (6); + hbox3->set_border_width (6); + hbox3->pack_start (template_button, PACK_SHRINK); + + hbox9 = new HBox; + hbox9->set_spacing (6); + hbox9->set_border_width (6); + hbox9->pack_start (track_template_combo, PACK_EXPAND_WIDGET); + + /* separator */ + + hbox4 = new HBox; + hbox4->set_spacing (6); + Label* label2 = manage (new Label (_("OR"))); + hbox4->pack_start (*(manage (new HSeparator)), PACK_EXPAND_WIDGET); + hbox4->pack_start (*label2, false, false); + hbox4->pack_start (*(manage (new HSeparator)), PACK_EXPAND_WIDGET); + + /* we need more control over the visibility of these boxes */ + /* + hbox3->set_no_show_all (true); + hbox9->set_no_show_all (true); + hbox4->set_no_show_all (true); + */ + /* track/bus choice & modes */ + + HBox* hbox5 = manage (new HBox); + hbox5->set_spacing (6); + hbox5->pack_start (track_button, PACK_EXPAND_PADDING); + hbox5->pack_start (bus_button, PACK_EXPAND_PADDING); - set_popdown_strings (channel_combo, channel_combo_strings); - set_popdown_strings (track_mode_combo, track_mode_strings); - channel_combo.set_active_text (channel_combo_strings.front()); channel_combo.set_name (X_("ChannelCountSelector")); + track_mode_combo.set_name (X_("ChannelCountSelector")); + + set_popdown_strings (channel_combo, channel_combo_strings, true); + set_popdown_strings (track_mode_combo, track_mode_strings, true); + + channel_combo.set_active_text (channel_combo_strings.front()); + track_mode_combo.set_active_text (track_mode_strings.front()); track_button.signal_clicked().connect (mem_fun (*this, &AddRouteDialog::track_type_chosen)); bus_button.signal_clicked().connect (mem_fun (*this, &AddRouteDialog::track_type_chosen)); + template_button.signal_clicked().connect (mem_fun (*this, &AddRouteDialog::track_type_chosen)); - track_mode_combo.set_active_text (track_mode_strings.front()); - track_mode_combo.set_name (X_("ChannelCountSelector")); -#if NOT_USEFUL_YET - HBox *hbnt = manage (new HBox); + VBox* vbox1 = manage (new VBox); + vbox1->set_spacing (6); + vbox1->set_border_width (6); - hbnt->pack_start (*(manage (new Label (_("Name (template)")))), false, false); - hbnt->pack_start (name_template_entry, true, true); -#endif - VBox *dvbox = manage (new VBox); - HBox *dhbox = manage (new HBox); + Frame* frame1 = manage (new Frame (_("Channel Configuration"))); + frame1->add (channel_combo); + Frame* frame2 = manage (new Frame (_("Track Mode"))); + frame2->add (track_mode_combo); - ccframe.set_label (_("Channel Configuration")); - ccframe.set_shadow_type (SHADOW_IN); + vbox1->pack_start (*hbox5, PACK_SHRINK); + vbox1->pack_start (*frame1, PACK_SHRINK); - dvbox->pack_start (channel_combo, true, false, 5); - dvbox->pack_start (track_mode_combo, true, false, 5); - dhbox->pack_start (*dvbox, true, false, 5); + if (!ARDOUR::Profile->get_sae()) { + vbox1->pack_start (*frame2, PACK_SHRINK); + } - ccframe.add (*dhbox); + get_vbox()->set_spacing (6); + get_vbox()->set_border_width (6); - get_vbox()->pack_start (aframe, true, false, 10); - get_vbox()->pack_start (ccframe, true, false); -#if NOT_USEFUL_YET - get_vbox()->pack_start (*hbnt, false, false); -#endif + get_vbox()->pack_start (*hbox2, PACK_SHRINK); + get_vbox()->pack_start (*hbox3, PACK_SHRINK); + get_vbox()->pack_start (*hbox9, PACK_SHRINK); + get_vbox()->pack_start (*hbox4, PACK_SHRINK); + get_vbox()->pack_start (*vbox1, PACK_SHRINK); get_vbox()->show_all (); + /* track template info will be managed whenever + this dialog is shown, via ::on_show() + */ + add_button (Stock::CANCEL, RESPONSE_CANCEL); add_button (Stock::ADD, RESPONSE_ACCEPT); + + track_type_chosen (); } AddRouteDialog::~AddRouteDialog () @@ -145,10 +219,18 @@ AddRouteDialog::~AddRouteDialog () void AddRouteDialog::track_type_chosen () { - if (track_button.get_active()) { - track_mode_combo.set_sensitive (true); - } else { + if (template_button.get_active()) { track_mode_combo.set_sensitive (false); + channel_combo.set_sensitive (false); + track_template_combo.set_sensitive (true); + } else { + track_template_combo.set_sensitive (false); + channel_combo.set_sensitive (true); + if (track_button.get_active()) { + track_mode_combo.set_sensitive (true); + } else { + track_mode_combo.set_sensitive (false); + } } } @@ -158,6 +240,18 @@ AddRouteDialog::track () return track_button.get_active (); } +ARDOUR::DataType +AddRouteDialog::type () +{ + // FIXME: ew + + const string str = channel_combo.get_active_text(); + if (str == _("MIDI")) + return ARDOUR::DataType::MIDI; + else + return ARDOUR::DataType::AUDIO; +} + string AddRouteDialog::name_template () { @@ -173,9 +267,15 @@ AddRouteDialog::count () ARDOUR::TrackMode AddRouteDialog::mode () { + if (ARDOUR::Profile->get_sae()) { + return ARDOUR::Normal; + } + Glib::ustring str = track_mode_combo.get_active_text(); if (str == _("Normal")) { return ARDOUR::Normal; + } else if (str == _("Non Layered")){ + return ARDOUR::NonLayered; } else if (str == _("Tape")) { return ARDOUR::Destructive; } else { @@ -204,3 +304,59 @@ AddRouteDialog::channels () return 0; } +string +AddRouteDialog::track_template () +{ + if (!template_button.get_active()) { + return string (); + } + + string str = track_template_combo.get_active_text(); + + for (vector::iterator x = route_templates.begin(); x != route_templates.end(); ++x) { + if ((*x).name == str) { + return (*x).path; + } + } + + return string(); +} + +void +AddRouteDialog::on_show () +{ + refill_track_templates (); + Dialog::on_show (); +} + +void +AddRouteDialog::refill_track_templates () +{ + route_templates.clear (); + ARDOUR::find_route_templates (route_templates); + + if (!route_templates.empty()) { + vector v; + for (vector::iterator x = route_templates.begin(); x != route_templates.end(); ++x) { + v.push_back ((*x).name); + } + set_popdown_strings (track_template_combo, v); + track_template_combo.set_active_text (v.front()); + } + + reset_template_option_visibility (); +} + +void +AddRouteDialog::reset_template_option_visibility () +{ + if (route_templates.empty()) { + hbox3->hide (); + hbox9->hide (); + hbox4->hide (); + } else { + hbox3->show_all (); + hbox9->show_all (); + hbox4->show_all (); + } +}