99 lines
2.8 KiB
C++
99 lines
2.8 KiB
C++
/*
|
|
* SPDX-License-Identifier: GPL-3.0-only
|
|
* MuseScore-CLA-applies
|
|
*
|
|
* MuseScore
|
|
* Music Composition & Notation
|
|
*
|
|
* Copyright (C) 2021 MuseScore BVBA and others
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 3 as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
#include "midiinputcontroller.h"
|
|
#include "log.h"
|
|
|
|
using namespace mu::notation;
|
|
|
|
void MidiInputController::init()
|
|
{
|
|
connectCurrentInputDevice();
|
|
connectCurrentOutputDevice();
|
|
|
|
midiInPort()->devicesChanged().onNotify(this, [this]() {
|
|
if (!midiInPort()->isConnected()) {
|
|
connectCurrentInputDevice();
|
|
}
|
|
});
|
|
|
|
midiOutPort()->devicesChanged().onNotify(this, [this]() {
|
|
if (!midiOutPort()->isConnected()) {
|
|
connectCurrentOutputDevice();
|
|
}
|
|
});
|
|
|
|
midiInPort()->eventReceived().onReceive(this, [this](midi::tick_t tick, const midi::Event& event) {
|
|
if (!configuration()->isMidiInputEnabled()) {
|
|
return;
|
|
}
|
|
|
|
onMidiEventReceived(tick, event);
|
|
});
|
|
}
|
|
|
|
void MidiInputController::connectCurrentInputDevice()
|
|
{
|
|
midi::MidiDeviceID deviceId = midiConfiguration()->midiInputDeviceId();
|
|
if (deviceId.empty()) {
|
|
return;
|
|
}
|
|
|
|
Ret ret = midiInPort()->connect(deviceId);
|
|
if (!ret) {
|
|
LOGW() << "failed connect to input device, deviceID: " << deviceId << ", err: " << ret.text();
|
|
}
|
|
}
|
|
|
|
void MidiInputController::connectCurrentOutputDevice()
|
|
{
|
|
midi::MidiDeviceID deviceId = midiConfiguration()->midiOutputDeviceId();
|
|
if (deviceId.empty()) {
|
|
return;
|
|
}
|
|
|
|
Ret ret = midiOutPort()->connect(deviceId);
|
|
if (!ret) {
|
|
LOGW() << "failed connect to output device, deviceID: " << deviceId << ", err: " << ret.text();
|
|
}
|
|
}
|
|
|
|
void MidiInputController::onMidiEventReceived(midi::tick_t tick, const midi::Event& event)
|
|
{
|
|
UNUSED(tick);
|
|
|
|
Ret ret = midiRemote()->process(event);
|
|
if (check_ret(ret, Ret::Code::Undefined)) {
|
|
//! NOTE Event not command, pass further
|
|
// pass
|
|
} else if (!ret) {
|
|
LOGE() << "failed midi remote process, err: " << ret.toString();
|
|
// pass
|
|
} else {
|
|
//! NOTE Success midi remote process (the event is command)
|
|
return;
|
|
}
|
|
|
|
auto notation = globalContext()->currentNotation();
|
|
if (notation) {
|
|
notation->midiInput()->onMidiEventReceived(event);
|
|
}
|
|
}
|