diff options
Diffstat (limited to 'src/engine')
-rw-r--r-- | src/engine/ControlBindings.cpp | 42 | ||||
-rw-r--r-- | src/engine/ControlBindings.hpp | 3 | ||||
-rw-r--r-- | src/engine/events/SendBinding.cpp | 3 |
3 files changed, 39 insertions, 9 deletions
diff --git a/src/engine/ControlBindings.cpp b/src/engine/ControlBindings.cpp index ee41bd51..0c31c731 100644 --- a/src/engine/ControlBindings.cpp +++ b/src/engine/ControlBindings.cpp @@ -41,16 +41,22 @@ ControlBindings::update_port(ProcessContext& context, PortImpl* port) const Raul::Atom& binding = port->get_property(uris.ingen_controlBinding); if (binding.type() == Atom::DICT) { Atom::DictValue::const_iterator t = binding.get_dict().find(uris.rdf_type); - Atom::DictValue::const_iterator n = binding.get_dict().find(uris.midi_controllerNumber); - if (t != binding.get_dict().end() && n != binding.get_dict().end()) { - if (t->second == uris.midi_Controller) { - _bindings->insert(make_pair(Key(MIDI_CC, n->second.get_int32()), port)); + Atom::DictValue::const_iterator n; + if (t != binding.get_dict().end()) { + if (t->second == uris.midi_Bender) { + _bindings->insert(make_pair(Key(MIDI_BENDER), port)); } else if (t->second == uris.midi_Bender) { _bindings->insert(make_pair(Key(MIDI_BENDER), port)); } else if (t->second == uris.midi_ChannelPressure) { _bindings->insert(make_pair(Key(MIDI_CHANNEL_PRESSURE), port)); - } else { - error << "Unknown binding type " << t->second << endl; + } else if (t->second == uris.midi_Controller) { + n = binding.get_dict().find(uris.midi_controllerNumber); + if (n != binding.get_dict().end()) + _bindings->insert(make_pair(Key(MIDI_CC, n->second.get_int32()), port)); + } else if (t->second == uris.midi_Note) { + n = binding.get_dict().find(uris.midi_noteNumber); + if (n != binding.get_dict().end()) + _bindings->insert(make_pair(Key(MIDI_NOTE, n->second.get_int32()), port)); } } } @@ -78,10 +84,14 @@ ControlBindings::set_port_value(ProcessContext& context, PortImpl* port, Type ty switch (type) { case MIDI_CC: case MIDI_CHANNEL_PRESSURE: - normal = (float)value / 127.0; + normal = (float)value / 127.0f; break; case MIDI_BENDER: - normal = (float)value / 16383.0; + normal = (float)value / 16383.0f; + break; + case MIDI_NOTE: + normal = (value == 0.0f) ? 0.0f : 1.0f; + break; default: break; } @@ -162,6 +172,10 @@ ControlBindings::process(ProcessContext& context, EventBuffer* buffer) case MIDI_CMD_CHANNEL_PRESSURE: bind(context, MIDI_CHANNEL_PRESSURE); break; + case MIDI_CMD_NOTE_ON: + num = static_cast<const int8_t>(buf[1]); + bind(context, MIDI_NOTE, num); + break; default: break; } @@ -197,6 +211,18 @@ ControlBindings::process(ProcessContext& context, EventBuffer* buffer) const int8_t value = static_cast<const int8_t>(buf[1]); set_port_value(context, i->second, MIDI_CHANNEL_PRESSURE, value); } + } else if ((buf[0] & 0xF0) == MIDI_CMD_NOTE_ON) { + const int8_t num = static_cast<const int8_t>(buf[1]); + Bindings::const_iterator i = bindings->find(Key(MIDI_NOTE, num)); + if (i != bindings->end()) { + set_port_value(context, i->second, MIDI_NOTE, 1.0f); + } + } else if ((buf[0] & 0xF0) == MIDI_CMD_NOTE_OFF) { + const int8_t num = static_cast<const int8_t>(buf[1]); + Bindings::const_iterator i = bindings->find(Key(MIDI_NOTE, num)); + if (i != bindings->end()) { + set_port_value(context, i->second, MIDI_NOTE, 0.0f); + } } } buffer->increment(); diff --git a/src/engine/ControlBindings.hpp b/src/engine/ControlBindings.hpp index bae3cc73..092a2730 100644 --- a/src/engine/ControlBindings.hpp +++ b/src/engine/ControlBindings.hpp @@ -38,7 +38,8 @@ public: MIDI_CC, MIDI_RPN, MIDI_NRPN, - MIDI_CHANNEL_PRESSURE + MIDI_CHANNEL_PRESSURE, + MIDI_NOTE }; struct Key { diff --git a/src/engine/events/SendBinding.cpp b/src/engine/events/SendBinding.cpp index 8cc03c79..c3c83ea4 100644 --- a/src/engine/events/SendBinding.cpp +++ b/src/engine/events/SendBinding.cpp @@ -40,6 +40,9 @@ SendBinding::post_process() dict[uris.rdf_type] = uris.midi_Bender; } else if (_type == ControlBindings::MIDI_CHANNEL_PRESSURE) { dict[uris.rdf_type] = uris.midi_ChannelPressure; + } else if (_type == ControlBindings::MIDI_NOTE) { + dict[uris.rdf_type] = uris.midi_Note; + dict[uris.midi_noteNumber] = _num; } // TODO: other event types _port->set_property(uris.ingen_controlBinding, dict); // FIXME: thread unsafe |