summaryrefslogtreecommitdiff
path: root/gtk2_ardour/add_route_dialog.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2009-06-11 15:06:00 +0000
committerPaul Davis <paul@linuxaudiosystems.com>2009-06-11 15:06:00 +0000
commit9ae058354819a58752a301183c0d4b13a759823c (patch)
tree3ced9f69aff241f635945f5b7e2e20611159737b /gtk2_ardour/add_route_dialog.cc
parentc6c10f1e7fad18f370b60010afe7f5871b2839d1 (diff)
hugely improved design for add route dialog (why didn't i do it this way before?)
git-svn-id: svn://localhost/ardour2/branches/3.0@5170 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'gtk2_ardour/add_route_dialog.cc')
-rw-r--r--gtk2_ardour/add_route_dialog.cc196
1 files changed, 78 insertions, 118 deletions
diff --git a/gtk2_ardour/add_route_dialog.cc b/gtk2_ardour/add_route_dialog.cc
index cc1a99759d..6b7b5edc97 100644
--- a/gtk2_ardour/add_route_dialog.cc
+++ b/gtk2_ardour/add_route_dialog.cc
@@ -42,18 +42,6 @@ using namespace std;
using namespace PBD;
using namespace ARDOUR;
-static const char* channel_setup_names[] = {
- N_("Mono"),
- N_("Stereo"),
- N_("3 Channels"),
- N_("4 Channels"),
- N_("6 Channels"),
- N_("8 Channels"),
- N_("Manual Setup"),
- N_("MIDI"),
- 0
-};
-
static const char* track_mode_names[] = {
N_("Normal"),
N_("Non Layered"),
@@ -61,31 +49,13 @@ static const char* track_mode_names[] = {
0
};
-static vector<string> channel_combo_strings;
-static vector<string> track_mode_strings;
-
-
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);
@@ -106,12 +76,10 @@ AddRouteDialog::AddRouteDialog ()
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);
/* add */
@@ -127,33 +95,6 @@ AddRouteDialog::AddRouteDialog ()
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);
@@ -164,7 +105,7 @@ AddRouteDialog::AddRouteDialog ()
channel_combo.set_name (X_("ChannelCountSelector"));
track_mode_combo.set_name (X_("ChannelCountSelector"));
- set_popdown_strings (channel_combo, channel_combo_strings, true);
+ refill_channel_setups ();
set_popdown_strings (track_mode_combo, track_mode_strings, true);
channel_combo.set_active_text (channel_combo_strings.front());
@@ -172,8 +113,6 @@ AddRouteDialog::AddRouteDialog ()
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));
-
VBox* vbox1 = manage (new VBox);
vbox1->set_spacing (6);
@@ -195,9 +134,6 @@ AddRouteDialog::AddRouteDialog ()
get_vbox()->set_border_width (6);
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 ();
@@ -219,18 +155,10 @@ AddRouteDialog::~AddRouteDialog ()
void
AddRouteDialog::track_type_chosen ()
{
- if (template_button.get_active()) {
- track_mode_combo.set_sensitive (false);
- channel_combo.set_sensitive (false);
- track_template_combo.set_sensitive (true);
+ if (track_button.get_active()) {
+ track_mode_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);
- }
+ track_mode_combo.set_sensitive (false);
}
}
@@ -291,15 +219,12 @@ int
AddRouteDialog::channels ()
{
string str = channel_combo.get_active_text();
- int chns;
-
- if (str == _("Mono")) {
- return 1;
- } else if (str == _("Stereo")) {
- return 2;
- } else if ((chns = PBD::atoi (str)) != 0) {
- return chns;
- }
+
+ for (ChannelSetups::iterator i = channel_setups.begin(); i != channel_setups.end(); ++i) {
+ if (str == (*i).name) {
+ return (*i).channels;
+ }
+ }
return 0;
}
@@ -307,15 +232,11 @@ AddRouteDialog::channels ()
string
AddRouteDialog::track_template ()
{
- if (!template_button.get_active()) {
- return string ();
- }
-
- string str = track_template_combo.get_active_text();
-
- for (vector<TemplateInfo>::iterator x = route_templates.begin(); x != route_templates.end(); ++x) {
- if ((*x).name == str) {
- return (*x).path;
+ string str = channel_combo.get_active_text();
+
+ for (ChannelSetups::iterator i = channel_setups.begin(); i != channel_setups.end(); ++i) {
+ if (str == (*i).name) {
+ return (*i).template_path;
}
}
@@ -325,38 +246,77 @@ AddRouteDialog::track_template ()
void
AddRouteDialog::on_show ()
{
- refill_track_templates ();
+ refill_channel_setups ();
Dialog::on_show ();
}
void
-AddRouteDialog::refill_track_templates ()
+AddRouteDialog::refill_channel_setups ()
{
+ ChannelSetup chn;
+
route_templates.clear ();
+ channel_combo_strings.clear ();
+ channel_setups.clear ();
+
+ chn.name = X_("MIDI");
+ chn.channels = 0;
+ channel_setups.push_back (chn);
+
+ chn.name = _("Mono");
+ chn.channels = 1;
+ channel_setups.push_back (chn);
+
+ chn.name = _("Stereo");
+ chn.channels = 2;
+ channel_setups.push_back (chn);
+
ARDOUR::find_route_templates (route_templates);
-
- if (!route_templates.empty()) {
- vector<string> v;
- for (vector<TemplateInfo>::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 ();
-}
+ if (!ARDOUR::Profile->get_sae()) {
+ if (!route_templates.empty()) {
+ vector<string> v;
+ for (vector<TemplateInfo>::iterator x = route_templates.begin(); x != route_templates.end(); ++x) {
+ chn.name = x->name;
+ chn.channels = 0;
+ chn.template_path = x->path;
+ channel_setups.push_back (chn);
+ }
+ }
-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 ();
+ chn.name = _("3 Channel");
+ chn.channels = 3;
+ channel_setups.push_back (chn);
+
+ chn.name = _("4 Channel");
+ chn.channels = 4;
+ channel_setups.push_back (chn);
+
+ chn.name = _("5 Channel");
+ chn.channels = 5;
+ channel_setups.push_back (chn);
+
+ chn.name = _("6 Channel");
+ chn.channels = 6;
+ channel_setups.push_back (chn);
+
+ chn.name = _("8 Channel");
+ chn.channels = 8;
+ channel_setups.push_back (chn);
+
+ chn.name = _("12 Channel");
+ chn.channels = 12;
+ channel_setups.push_back (chn);
+
+ chn.name = X_("Custom");
+ chn.channels = 0;
+ channel_setups.push_back (chn);
+ }
+
+ for (ChannelSetups::iterator i = channel_setups.begin(); i != channel_setups.end(); ++i) {
+ channel_combo_strings.push_back ((*i).name);
}
+
+ set_popdown_strings (channel_combo, channel_combo_strings, true);
+ channel_combo.set_active_text (channel_combo_strings.front());
}