diff options
author | Robin Gareus <robin@gareus.org> | 2019-10-18 17:26:25 +0200 |
---|---|---|
committer | Robin Gareus <robin@gareus.org> | 2019-10-18 22:56:46 +0200 |
commit | 19e4f47b4bd968be6471aa22f196bced33296568 (patch) | |
tree | 307865f945c777043c1d6e5eb5f49d96641b4c55 /gtk2_ardour/virtual_keyboard_window.cc | |
parent | 148a9682be3fcf1c83c738287f875c9c629edbd1 (diff) |
Cont'd work on Virtual-keyboard
* allow gtk_pianokeyboard to respond to y-axis click position
and include MIDI velocity with note-on signal
* add configuration settings to virual-keyboard
min/max velocity, keyboard-layout
* add a CC7 controller knob
Diffstat (limited to 'gtk2_ardour/virtual_keyboard_window.cc')
-rw-r--r-- | gtk2_ardour/virtual_keyboard_window.cc | 160 |
1 files changed, 145 insertions, 15 deletions
diff --git a/gtk2_ardour/virtual_keyboard_window.cc b/gtk2_ardour/virtual_keyboard_window.cc index bda15edce4..60afaffa1b 100644 --- a/gtk2_ardour/virtual_keyboard_window.cc +++ b/gtk2_ardour/virtual_keyboard_window.cc @@ -22,42 +22,96 @@ #include "ardour_ui.h" #include "virtual_keyboard_window.h" +#include "ui_config.h" #include "utils.h" #include "pbd/i18n.h" using namespace Glib; using namespace Gtk; +using namespace ArdourWidgets; + +#define PX_SCALE(px) std::max((float)px, rintf((float)px * UIConfiguration::instance().get_ui_scale())) VirtualKeyboardWindow::VirtualKeyboardWindow () : ArdourWindow (_("Virtual Keyboard")) - , _piano_velocity (*manage (new Adjustment (100, 1, 127, 1, 16))) , _piano_channel (*manage (new Adjustment (0, 1, 16, 1, 1))) + , _yaxis_velocity ("Y-Axis Click Velocity", ArdourButton::led_default_elements) + , _piano_key_velocity (*manage (new Adjustment (100, 1, 127, 1, 16))) + , _piano_min_velocity (*manage (new Adjustment (1 , 1, 127, 1, 16))) + , _piano_max_velocity (*manage (new Adjustment (127, 1, 127, 1, 16))) + , _cc7 (new VKBDControl ("CC7", 127)) + , _cc7_knob (ArdourKnob::default_elements, ArdourKnob::Flags (0)) { _piano = (PianoKeyboard*)piano_keyboard_new(); _pianomm = Glib::wrap((GtkWidget*)_piano); _pianomm->set_flags(Gtk::CAN_FOCUS); _pianomm->add_events(Gdk::KEY_PRESS_MASK|Gdk::KEY_RELEASE_MASK); - - g_signal_connect (G_OBJECT (_piano), "note-on", G_CALLBACK (VirtualKeyboardWindow::_note_on_event_handler), this); - g_signal_connect (G_OBJECT (_piano), "note-off", G_CALLBACK (VirtualKeyboardWindow::_note_off_event_handler), this); - piano_keyboard_set_keyboard_layout (_piano, "QWERTY"); - HBox* box = manage (new HBox); - box->pack_start (*manage (new Label (_("Channel:"))), false, false); - box->pack_start (_piano_channel, false, false); - box->pack_start (*manage (new Label (_("Velocity:"))), false, false); - box->pack_start (_piano_velocity, false, false); - + using namespace Menu_Helpers; + _keyboard_layout.AddMenuElem (MenuElem (_("QWERTY"), + sigc::bind (sigc::mem_fun (*this, &VirtualKeyboardWindow::select_keyboard_layout), 0))); + _keyboard_layout.AddMenuElem (MenuElem (_("QWERTZ"), + sigc::bind (sigc::mem_fun (*this, &VirtualKeyboardWindow::select_keyboard_layout), 1))); + _keyboard_layout.AddMenuElem (MenuElem (_("AZERTY"), + sigc::bind (sigc::mem_fun (*this, &VirtualKeyboardWindow::select_keyboard_layout), 2))); + _keyboard_layout.set_text (_("QWERTY")); + + _yaxis_velocity.set_active (false); + + _cc7_knob.set_controllable (_cc7); + _cc7_knob.set_size_request (PX_SCALE(21), PX_SCALE(21)); + _cc7_knob.set_tooltip_prefix (_("CC7: ")); + _cc7_knob.set_name ("monitor section knob"); + + // TODO allow to hide config panel + // save/restore settings + + /* config */ + HBox* cfg_box = manage (new HBox); + cfg_box->set_spacing (4); + cfg_box->pack_start (*manage (new Label (_("Key Velocity:"))), false, false); + cfg_box->pack_start (_piano_key_velocity, false, false); + cfg_box->pack_start (_yaxis_velocity, false, false, 8); + cfg_box->pack_start (*manage (new Label (_("Min Velocity:"))), false, false); + cfg_box->pack_start (_piano_min_velocity, false, false); + cfg_box->pack_start (*manage (new Label (_("Max Velocity:"))), false, false); + cfg_box->pack_start (_piano_max_velocity, false, false); + cfg_box->pack_start (_keyboard_layout, false, false, 8); + + /* settings */ + HBox* set_box = manage (new HBox); + set_box->set_spacing (4); + set_box->pack_start (*manage (new Label (_("Channel:"))), false, false); + set_box->pack_start (_piano_channel, false, false, 8); + set_box->pack_start (*manage (new Label (_("CC7:"))), false, false); + set_box->pack_start (_cc7_knob, false, false); + + /* layout */ + Box* box1 = manage (new HBox ()); + box1->pack_start (*cfg_box, true, false); Box* box2 = manage (new HBox ()); - box2->pack_start (*box, true, false); - + box2->pack_start (*set_box, true, false); VBox* vbox = manage (new VBox); + vbox->pack_start (*box1, false, false, 4); vbox->pack_start (*box2, false, false, 4); vbox->pack_start (*_pianomm, true, true); add (*vbox); + _piano_key_velocity.signal_value_changed ().connect (sigc::bind (sigc::mem_fun (*this, &VirtualKeyboardWindow::update_velocity_settings), 0)); + _piano_min_velocity.signal_value_changed ().connect (sigc::bind (sigc::mem_fun (*this, &VirtualKeyboardWindow::update_velocity_settings), 1)); + _piano_max_velocity.signal_value_changed ().connect (sigc::bind (sigc::mem_fun (*this, &VirtualKeyboardWindow::update_velocity_settings), 2)); + + _yaxis_velocity.signal_button_release_event().connect (sigc::mem_fun(*this, &VirtualKeyboardWindow::yaxis_velocity_button_release), false); + + g_signal_connect (G_OBJECT (_piano), "note-on", G_CALLBACK (VirtualKeyboardWindow::_note_on_event_handler), this); + g_signal_connect (G_OBJECT (_piano), "note-off", G_CALLBACK (VirtualKeyboardWindow::_note_off_event_handler), this); + + _cc7->ValueChanged.connect_same_thread (_cc_connections, boost::bind (&VirtualKeyboardWindow::control_change_event_handler, this, 7, _1)); + + update_velocity_settings (0); + set_keep_above (true); vbox->show_all(); } @@ -81,7 +135,72 @@ VirtualKeyboardWindow::on_key_press_event (GdkEventKey* ev) } void -VirtualKeyboardWindow::note_on_event_handler (int note) +VirtualKeyboardWindow::select_keyboard_layout (int l) +{ + switch (l) { + default: + case 0: + piano_keyboard_set_keyboard_layout (_piano, "QWERTY"); + _keyboard_layout.set_text (_("QWERTY")); + break; + case 1: + piano_keyboard_set_keyboard_layout (_piano, "QWERTZ"); + _keyboard_layout.set_text (_("QWERTZ")); + break; + case 2: + piano_keyboard_set_keyboard_layout (_piano, "AZERTY"); + _keyboard_layout.set_text (_("AZERTY")); + break; + } +} + +bool +VirtualKeyboardWindow::yaxis_velocity_button_release (GdkEventButton* ev) +{ + _yaxis_velocity.set_active (!_yaxis_velocity.get_active ()); + update_velocity_settings (0); + return false; +} + +void +VirtualKeyboardWindow::update_velocity_settings (int ctrl) +{ + if (_piano_min_velocity.get_value_as_int () > _piano_max_velocity.get_value_as_int ()) { + if (ctrl == 2) { + _piano_min_velocity.set_value (_piano_max_velocity.get_value_as_int ()); + return; + } else { + _piano_max_velocity.set_value (_piano_min_velocity.get_value_as_int ()); + return; + } + } + + if (_yaxis_velocity.get_active ()) { + piano_keyboard_set_velocities (_piano, + _piano_min_velocity.get_value_as_int (), + _piano_max_velocity.get_value_as_int (), + _piano_key_velocity.get_value_as_int () + ); + } else { + piano_keyboard_set_velocities (_piano, + _piano_key_velocity.get_value_as_int (), + _piano_key_velocity.get_value_as_int (), + _piano_key_velocity.get_value_as_int () + ); + } + update_sensitivity (); +} + +void +VirtualKeyboardWindow::update_sensitivity () +{ + bool c = _yaxis_velocity.get_active (); + _piano_min_velocity.set_sensitive (c); + _piano_max_velocity.set_sensitive (c); +} + +void +VirtualKeyboardWindow::note_on_event_handler (int note, int velocity) { _pianomm->grab_focus (); if (!_session) { @@ -91,7 +210,7 @@ VirtualKeyboardWindow::note_on_event_handler (int note) uint8_t ev[3]; ev[0] = (MIDI_CMD_NOTE_ON | channel); ev[1] = note; - ev[2] = _piano_velocity.get_value_as_int (); + ev[2] = velocity; _session->vkbd_output_port()->write (ev, 3, 0); } @@ -109,3 +228,14 @@ VirtualKeyboardWindow::note_off_event_handler (int note) ev[2] = 0; _session->vkbd_output_port()->write (ev, 3, 0); } + +void +VirtualKeyboardWindow::control_change_event_handler (int key, int val) +{ + uint8_t channel = _piano_channel.get_value_as_int () - 1; + uint8_t ev[3]; + ev[0] = (MIDI_CMD_CONTROL | channel); + ev[1] = key; + ev[2] = val; + _session->vkbd_output_port()->write (ev, 3, 0); +} |