diff options
author | Hans Baier <hansfbaier@googlemail.com> | 2008-12-11 08:06:27 +0000 |
---|---|---|
committer | Hans Baier <hansfbaier@googlemail.com> | 2008-12-11 08:06:27 +0000 |
commit | e009016b03ea5c5c690d7d4939b264313600fd4b (patch) | |
tree | 6de5374502891ad1229fffae5ab5f7d71eed70c2 /gtk2_ardour/midi_time_axis.cc | |
parent | dfed4965b7cf74f21a9e78689dbda1bc5892cde8 (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.cc | 48 |
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() { |