|
|
@ -1,8 +1,8 @@
|
|
|
|
#include "process_midi.h"
|
|
|
|
#include "process_midi.h"
|
|
|
|
|
|
|
|
|
|
|
|
bool midi_activated = false;
|
|
|
|
bool midi_activated = false;
|
|
|
|
uint8_t starting_note = 0x0C;
|
|
|
|
uint8_t midi_starting_note = 0x0C;
|
|
|
|
int offset = 7;
|
|
|
|
int midi_offset = 7;
|
|
|
|
|
|
|
|
|
|
|
|
bool process_midi(uint16_t keycode, keyrecord_t *record) {
|
|
|
|
bool process_midi(uint16_t keycode, keyrecord_t *record) {
|
|
|
|
if (keycode == MI_ON && record->event.pressed) {
|
|
|
|
if (keycode == MI_ON && record->event.pressed) {
|
|
|
@ -20,42 +20,42 @@ bool process_midi(uint16_t keycode, keyrecord_t *record) {
|
|
|
|
if (midi_activated) {
|
|
|
|
if (midi_activated) {
|
|
|
|
if (record->event.key.col == (MATRIX_COLS - 1) && record->event.key.row == (MATRIX_ROWS - 1)) {
|
|
|
|
if (record->event.key.col == (MATRIX_COLS - 1) && record->event.key.row == (MATRIX_ROWS - 1)) {
|
|
|
|
if (record->event.pressed) {
|
|
|
|
if (record->event.pressed) {
|
|
|
|
starting_note++; // Change key
|
|
|
|
midi_starting_note++; // Change key
|
|
|
|
midi_send_cc(&midi_device, 0, 0x7B, 0);
|
|
|
|
midi_send_cc(&midi_device, 0, 0x7B, 0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (record->event.key.col == (MATRIX_COLS - 2) && record->event.key.row == (MATRIX_ROWS - 1)) {
|
|
|
|
if (record->event.key.col == (MATRIX_COLS - 2) && record->event.key.row == (MATRIX_ROWS - 1)) {
|
|
|
|
if (record->event.pressed) {
|
|
|
|
if (record->event.pressed) {
|
|
|
|
starting_note--; // Change key
|
|
|
|
midi_starting_note--; // Change key
|
|
|
|
midi_send_cc(&midi_device, 0, 0x7B, 0);
|
|
|
|
midi_send_cc(&midi_device, 0, 0x7B, 0);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (record->event.key.col == (MATRIX_COLS - 3) && record->event.key.row == (MATRIX_ROWS - 1) && record->event.pressed) {
|
|
|
|
if (record->event.key.col == (MATRIX_COLS - 3) && record->event.key.row == (MATRIX_ROWS - 1) && record->event.pressed) {
|
|
|
|
offset++; // Change scale
|
|
|
|
midi_offset++; // Change scale
|
|
|
|
midi_send_cc(&midi_device, 0, 0x7B, 0);
|
|
|
|
midi_send_cc(&midi_device, 0, 0x7B, 0);
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (record->event.key.col == (MATRIX_COLS - 4) && record->event.key.row == (MATRIX_ROWS - 1) && record->event.pressed) {
|
|
|
|
if (record->event.key.col == (MATRIX_COLS - 4) && record->event.key.row == (MATRIX_ROWS - 1) && record->event.pressed) {
|
|
|
|
offset--; // Change scale
|
|
|
|
midi_offset--; // Change scale
|
|
|
|
midi_send_cc(&midi_device, 0, 0x7B, 0);
|
|
|
|
midi_send_cc(&midi_device, 0, 0x7B, 0);
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// basic
|
|
|
|
// basic
|
|
|
|
// uint8_t note = (starting_note + SCALE[record->event.key.col + offset])+12*(MATRIX_ROWS - record->event.key.row);
|
|
|
|
// uint8_t note = (midi_starting_note + SCALE[record->event.key.col + midi_offset])+12*(MATRIX_ROWS - record->event.key.row);
|
|
|
|
// advanced
|
|
|
|
// advanced
|
|
|
|
// uint8_t note = (starting_note + record->event.key.col + offset)+12*(MATRIX_ROWS - record->event.key.row);
|
|
|
|
// uint8_t note = (midi_starting_note + record->event.key.col + midi_offset)+12*(MATRIX_ROWS - record->event.key.row);
|
|
|
|
// guitar
|
|
|
|
// guitar
|
|
|
|
uint8_t note = (starting_note + record->event.key.col + offset)+5*(MATRIX_ROWS - record->event.key.row);
|
|
|
|
uint8_t note = (midi_starting_note + record->event.key.col + midi_offset)+5*(MATRIX_ROWS - record->event.key.row);
|
|
|
|
// violin
|
|
|
|
// violin
|
|
|
|
// uint8_t note = (starting_note + record->event.key.col + offset)+7*(MATRIX_ROWS - record->event.key.row);
|
|
|
|
// uint8_t note = (midi_starting_note + record->event.key.col + midi_offset)+7*(MATRIX_ROWS - record->event.key.row);
|
|
|
|
|
|
|
|
|
|
|
|
if (record->event.pressed) {
|
|
|
|
if (record->event.pressed) {
|
|
|
|
// midi_send_noteon(&midi_device, record->event.key.row, starting_note + SCALE[record->event.key.col], 127);
|
|
|
|
// midi_send_noteon(&midi_device, record->event.key.row, midi_starting_note + SCALE[record->event.key.col], 127);
|
|
|
|
midi_send_noteon(&midi_device, 0, note, 127);
|
|
|
|
midi_send_noteon(&midi_device, 0, note, 127);
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
// midi_send_noteoff(&midi_device, record->event.key.row, starting_note + SCALE[record->event.key.col], 127);
|
|
|
|
// midi_send_noteoff(&midi_device, record->event.key.row, midi_starting_note + SCALE[record->event.key.col], 127);
|
|
|
|
midi_send_noteoff(&midi_device, 0, note, 127);
|
|
|
|
midi_send_noteoff(&midi_device, 0, note, 127);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|