mirror of
https://github.com/Ardour/ardour.git
synced 2025-12-07 15:25:01 +01:00
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
This commit is contained in:
parent
c6c10f1e7f
commit
9ae0583548
2 changed files with 91 additions and 125 deletions
|
|
@ -42,18 +42,6 @@ using namespace std;
|
||||||
using namespace PBD;
|
using namespace PBD;
|
||||||
using namespace ARDOUR;
|
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[] = {
|
static const char* track_mode_names[] = {
|
||||||
N_("Normal"),
|
N_("Normal"),
|
||||||
N_("Non Layered"),
|
N_("Non Layered"),
|
||||||
|
|
@ -61,31 +49,13 @@ static const char* track_mode_names[] = {
|
||||||
0
|
0
|
||||||
};
|
};
|
||||||
|
|
||||||
static vector<string> channel_combo_strings;
|
|
||||||
static vector<string> track_mode_strings;
|
|
||||||
|
|
||||||
|
|
||||||
AddRouteDialog::AddRouteDialog ()
|
AddRouteDialog::AddRouteDialog ()
|
||||||
: Dialog (_("ardour: add track/bus")),
|
: Dialog (_("ardour: add track/bus")),
|
||||||
track_button (_("Tracks")),
|
track_button (_("Tracks")),
|
||||||
bus_button (_("Busses")),
|
bus_button (_("Busses")),
|
||||||
template_button (_("Using this template:")),
|
|
||||||
routes_adjustment (1, 1, 128, 1, 4),
|
routes_adjustment (1, 1, 128, 1, 4),
|
||||||
routes_spinner (routes_adjustment)
|
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()) {
|
if (track_mode_strings.empty()) {
|
||||||
track_mode_strings = I18N (track_mode_names);
|
track_mode_strings = I18N (track_mode_names);
|
||||||
|
|
||||||
|
|
@ -106,12 +76,10 @@ AddRouteDialog::AddRouteDialog ()
|
||||||
name_template_entry.set_name ("AddRouteDialogNameTemplateEntry");
|
name_template_entry.set_name ("AddRouteDialogNameTemplateEntry");
|
||||||
track_button.set_name ("AddRouteDialogRadioButton");
|
track_button.set_name ("AddRouteDialogRadioButton");
|
||||||
bus_button.set_name ("AddRouteDialogRadioButton");
|
bus_button.set_name ("AddRouteDialogRadioButton");
|
||||||
template_button.set_name ("AddRouteDialogRadioButton");
|
|
||||||
routes_spinner.set_name ("AddRouteDialogSpinner");
|
routes_spinner.set_name ("AddRouteDialogSpinner");
|
||||||
|
|
||||||
RadioButton::Group g = track_button.get_group();
|
RadioButton::Group g = track_button.get_group();
|
||||||
bus_button.set_group (g);
|
bus_button.set_group (g);
|
||||||
template_button.set_group (g);
|
|
||||||
track_button.set_active (true);
|
track_button.set_active (true);
|
||||||
|
|
||||||
/* add */
|
/* add */
|
||||||
|
|
@ -127,33 +95,6 @@ AddRouteDialog::AddRouteDialog ()
|
||||||
hbox2->set_border_width (6);
|
hbox2->set_border_width (6);
|
||||||
hbox2->pack_start (*hbox1, PACK_EXPAND_WIDGET);
|
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 */
|
/* track/bus choice & modes */
|
||||||
|
|
||||||
HBox* hbox5 = manage (new HBox);
|
HBox* hbox5 = manage (new HBox);
|
||||||
|
|
@ -164,7 +105,7 @@ AddRouteDialog::AddRouteDialog ()
|
||||||
channel_combo.set_name (X_("ChannelCountSelector"));
|
channel_combo.set_name (X_("ChannelCountSelector"));
|
||||||
track_mode_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);
|
set_popdown_strings (track_mode_combo, track_mode_strings, true);
|
||||||
|
|
||||||
channel_combo.set_active_text (channel_combo_strings.front());
|
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));
|
track_button.signal_clicked().connect (mem_fun (*this, &AddRouteDialog::track_type_chosen));
|
||||||
bus_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);
|
VBox* vbox1 = manage (new VBox);
|
||||||
vbox1->set_spacing (6);
|
vbox1->set_spacing (6);
|
||||||
|
|
@ -195,9 +134,6 @@ AddRouteDialog::AddRouteDialog ()
|
||||||
get_vbox()->set_border_width (6);
|
get_vbox()->set_border_width (6);
|
||||||
|
|
||||||
get_vbox()->pack_start (*hbox2, PACK_SHRINK);
|
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()->pack_start (*vbox1, PACK_SHRINK);
|
||||||
|
|
||||||
get_vbox()->show_all ();
|
get_vbox()->show_all ();
|
||||||
|
|
@ -219,18 +155,10 @@ AddRouteDialog::~AddRouteDialog ()
|
||||||
void
|
void
|
||||||
AddRouteDialog::track_type_chosen ()
|
AddRouteDialog::track_type_chosen ()
|
||||||
{
|
{
|
||||||
if (template_button.get_active()) {
|
if (track_button.get_active()) {
|
||||||
track_mode_combo.set_sensitive (false);
|
track_mode_combo.set_sensitive (true);
|
||||||
channel_combo.set_sensitive (false);
|
|
||||||
track_template_combo.set_sensitive (true);
|
|
||||||
} else {
|
} else {
|
||||||
track_template_combo.set_sensitive (false);
|
track_mode_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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -291,14 +219,11 @@ int
|
||||||
AddRouteDialog::channels ()
|
AddRouteDialog::channels ()
|
||||||
{
|
{
|
||||||
string str = channel_combo.get_active_text();
|
string str = channel_combo.get_active_text();
|
||||||
int chns;
|
|
||||||
|
|
||||||
if (str == _("Mono")) {
|
for (ChannelSetups::iterator i = channel_setups.begin(); i != channel_setups.end(); ++i) {
|
||||||
return 1;
|
if (str == (*i).name) {
|
||||||
} else if (str == _("Stereo")) {
|
return (*i).channels;
|
||||||
return 2;
|
}
|
||||||
} else if ((chns = PBD::atoi (str)) != 0) {
|
|
||||||
return chns;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -307,15 +232,11 @@ AddRouteDialog::channels ()
|
||||||
string
|
string
|
||||||
AddRouteDialog::track_template ()
|
AddRouteDialog::track_template ()
|
||||||
{
|
{
|
||||||
if (!template_button.get_active()) {
|
string str = channel_combo.get_active_text();
|
||||||
return string ();
|
|
||||||
}
|
|
||||||
|
|
||||||
string str = track_template_combo.get_active_text();
|
for (ChannelSetups::iterator i = channel_setups.begin(); i != channel_setups.end(); ++i) {
|
||||||
|
if (str == (*i).name) {
|
||||||
for (vector<TemplateInfo>::iterator x = route_templates.begin(); x != route_templates.end(); ++x) {
|
return (*i).template_path;
|
||||||
if ((*x).name == str) {
|
|
||||||
return (*x).path;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -325,38 +246,77 @@ AddRouteDialog::track_template ()
|
||||||
void
|
void
|
||||||
AddRouteDialog::on_show ()
|
AddRouteDialog::on_show ()
|
||||||
{
|
{
|
||||||
refill_track_templates ();
|
refill_channel_setups ();
|
||||||
Dialog::on_show ();
|
Dialog::on_show ();
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
AddRouteDialog::refill_track_templates ()
|
AddRouteDialog::refill_channel_setups ()
|
||||||
{
|
{
|
||||||
|
ChannelSetup chn;
|
||||||
|
|
||||||
route_templates.clear ();
|
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);
|
ARDOUR::find_route_templates (route_templates);
|
||||||
|
|
||||||
if (!route_templates.empty()) {
|
if (!ARDOUR::Profile->get_sae()) {
|
||||||
vector<string> v;
|
if (!route_templates.empty()) {
|
||||||
for (vector<TemplateInfo>::iterator x = route_templates.begin(); x != route_templates.end(); ++x) {
|
vector<string> v;
|
||||||
v.push_back ((*x).name);
|
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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
set_popdown_strings (track_template_combo, v);
|
|
||||||
track_template_combo.set_active_text (v.front());
|
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);
|
||||||
}
|
}
|
||||||
|
|
||||||
reset_template_option_visibility ();
|
for (ChannelSetups::iterator i = channel_setups.begin(); i != channel_setups.end(); ++i) {
|
||||||
}
|
channel_combo_strings.push_back ((*i).name);
|
||||||
|
|
||||||
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 ();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
set_popdown_strings (channel_combo, channel_combo_strings, true);
|
||||||
|
channel_combo.set_active_text (channel_combo_strings.front());
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -55,25 +55,31 @@ class AddRouteDialog : public Gtk::Dialog
|
||||||
Gtk::Entry name_template_entry;
|
Gtk::Entry name_template_entry;
|
||||||
Gtk::RadioButton track_button;
|
Gtk::RadioButton track_button;
|
||||||
Gtk::RadioButton bus_button;
|
Gtk::RadioButton bus_button;
|
||||||
Gtk::RadioButton template_button;
|
|
||||||
Gtk::Adjustment routes_adjustment;
|
Gtk::Adjustment routes_adjustment;
|
||||||
Gtk::SpinButton routes_spinner;
|
Gtk::SpinButton routes_spinner;
|
||||||
Gtk::ComboBoxText channel_combo;
|
Gtk::ComboBoxText channel_combo;
|
||||||
Gtk::ComboBoxText track_mode_combo;
|
Gtk::ComboBoxText track_mode_combo;
|
||||||
Gtk::ComboBoxText track_template_combo;
|
|
||||||
|
|
||||||
std::vector<ARDOUR::TemplateInfo> route_templates;
|
std::vector<ARDOUR::TemplateInfo> route_templates;
|
||||||
|
|
||||||
void track_type_chosen ();
|
void track_type_chosen ();
|
||||||
void refill_track_templates ();
|
void refill_channel_setups ();
|
||||||
|
|
||||||
Gtk::HBox* hbox3;
|
|
||||||
Gtk::HBox* hbox9;
|
|
||||||
Gtk::HBox* hbox4;
|
|
||||||
|
|
||||||
void reset_template_option_visibility ();
|
void reset_template_option_visibility ();
|
||||||
|
|
||||||
void on_show ();
|
void on_show ();
|
||||||
|
|
||||||
|
struct ChannelSetup {
|
||||||
|
std::string name;
|
||||||
|
std::string template_path;
|
||||||
|
uint32_t channels;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef std::vector<ChannelSetup> ChannelSetups;
|
||||||
|
ChannelSetups channel_setups;
|
||||||
|
|
||||||
|
std::vector<std::string> channel_combo_strings;
|
||||||
|
std::vector<std::string> track_mode_strings;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif /* __gtk_ardour_add_route_dialog_h__ */
|
#endif /* __gtk_ardour_add_route_dialog_h__ */
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue