summaryrefslogtreecommitdiff
path: root/gtk2_ardour/midi_time_axis.cc
diff options
context:
space:
mode:
authorHans Baier <hansfbaier@googlemail.com>2008-12-11 08:06:27 +0000
committerHans Baier <hansfbaier@googlemail.com>2008-12-11 08:06:27 +0000
commite009016b03ea5c5c690d7d4939b264313600fd4b (patch)
tree6de5374502891ad1229fffae5ab5f7d71eed70c2 /gtk2_ardour/midi_time_axis.cc
parentdfed4965b7cf74f21a9e78689dbda1bc5892cde8 (diff)
* added myself to about.cc
* created ArdourCanvas::CanvasFlag as a base class for flags * removed obsolete cruft from midi_model * made MidiTimeAxisView and MidiRegionView work together to display program changes as names by means of MidiPatchManager git-svn-id: svn://localhost/ardour2/branches/3.0@4307 d708f5d6-7413-0410-9779-e7cbd77b26cf
Diffstat (limited to 'gtk2_ardour/midi_time_axis.cc')
-rw-r--r--gtk2_ardour/midi_time_axis.cc48
1 files changed, 30 insertions, 18 deletions
diff --git a/gtk2_ardour/midi_time_axis.cc b/gtk2_ardour/midi_time_axis.cc
index ab0f0279f1..a8f6e3a6f4 100644
--- a/gtk2_ardour/midi_time_axis.cc
+++ b/gtk2_ardour/midi_time_axis.cc
@@ -141,36 +141,28 @@ MidiTimeAxisView::MidiTimeAxisView (PublicEditor& ed, Session& sess, boost::shar
}
HBox* midi_controls_hbox = manage(new HBox());
-
- // Instrument patch selector
- ComboBoxText* model_selector = manage(new ComboBoxText());
- ComboBoxText* custom_device_mode_selector = manage(new ComboBoxText());
-
+
MIDI::Name::MidiPatchManager& patch_manager = MIDI::Name::MidiPatchManager::instance();
for (MIDI::Name::MasterDeviceNames::Models::const_iterator model = patch_manager.all_models().begin();
model != patch_manager.all_models().end();
++model) {
- model_selector->append_text(model->c_str());
+ _model_selector.append_text(model->c_str());
}
- // TODO: persist the choice
- model_selector->set_active(0);
+ _model_selector.signal_changed().connect(mem_fun(*this, &MidiTimeAxisView::model_changed));
- std::list<std::string> device_modes = patch_manager.custom_device_mode_names_by_model(model_selector->get_active_text());
+ _custom_device_mode_selector.signal_changed().connect(
+ mem_fun(*this, &MidiTimeAxisView::custom_device_mode_changed));
- for (std::list<std::string>::const_iterator i = device_modes.begin(); i != device_modes.end(); ++i) {
- cerr << "found custom device mode " << *i << endl;
- custom_device_mode_selector->append_text(*i);
- }
-
// TODO: persist the choice
- custom_device_mode_selector->set_active(0);
-
+ // this initializes the comboboxes and sends out the signal
+ _model_selector.set_active(0);
+
midi_controls_hbox->pack_start(_channel_selector, true, false);
if (!patch_manager.all_models().empty()) {
- _midi_controls_box.pack_start(*model_selector, true, false);
- _midi_controls_box.pack_start(*custom_device_mode_selector, true, false);
+ _midi_controls_box.pack_start(_model_selector, true, false);
+ _midi_controls_box.pack_start(_custom_device_mode_selector, true, false);
}
_midi_controls_box.pack_start(*midi_controls_hbox, true, true);
@@ -195,6 +187,26 @@ MidiTimeAxisView::~MidiTimeAxisView ()
_range_scroomer = 0;
}
+void MidiTimeAxisView::model_changed()
+{
+ std::list<std::string> device_modes = MIDI::Name::MidiPatchManager::instance()
+ .custom_device_mode_names_by_model(_model_selector.get_active_text());
+
+ _custom_device_mode_selector.clear_items();
+
+ for (std::list<std::string>::const_iterator i = device_modes.begin(); i != device_modes.end(); ++i) {
+ cerr << "found custom device mode " << *i << endl;
+ _custom_device_mode_selector.append_text(*i);
+ }
+
+ _custom_device_mode_selector.set_active(0);
+}
+
+void MidiTimeAxisView::custom_device_mode_changed()
+{
+ _midi_patch_settings_changed.emit(_model_selector.get_active_text(), _custom_device_mode_selector.get_active_text());
+}
+
MidiStreamView*
MidiTimeAxisView::midi_view()
{