mirror of
https://github.com/qmk/qmk_firmware.git
synced 2024-11-22 19:39:27 +00:00
updated music mask
This commit is contained in:
parent
14b7602a65
commit
63d5c947d3
@ -89,6 +89,20 @@ By default, `MUSIC_MASK` is set to `keycode < 0xFF` which means keycodes less th
|
|||||||
|
|
||||||
Which will capture all keycodes - be careful, this will get you stuck in music mode until you restart your keyboard!
|
Which will capture all keycodes - be careful, this will get you stuck in music mode until you restart your keyboard!
|
||||||
|
|
||||||
|
For a more advanced way to control which keycodes should still be processed, you can use `music_mask_kb(keycode)` in `<keyboard>.c` and `music_mask_user(keycode)` in your `keymap.c`:
|
||||||
|
|
||||||
|
bool music_mask_user(uint16_t keycode) {
|
||||||
|
switch (keycode) {
|
||||||
|
case RAISE:
|
||||||
|
case LOWER:
|
||||||
|
return false;
|
||||||
|
default:
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Things that return false are not part of the mask, and are always processed.
|
||||||
|
|
||||||
The pitch standard (`PITCH_STANDARD_A`) is 440.0f by default - to change this, add something like this to your `config.h`:
|
The pitch standard (`PITCH_STANDARD_A`) is 440.0f by default - to change this, add something like this to your `config.h`:
|
||||||
|
|
||||||
#define PITCH_STANDARD_A 432.0f
|
#define PITCH_STANDARD_A 432.0f
|
||||||
|
@ -13,8 +13,6 @@
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define MUSIC_MASK (keycode != KC_NO)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* MIDI options
|
* MIDI options
|
||||||
*/
|
*/
|
||||||
|
@ -247,3 +247,13 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool music_mask_user(uint16_t keycode) {
|
||||||
|
switch (keycode) {
|
||||||
|
case RAISE:
|
||||||
|
case LOWER:
|
||||||
|
return false;
|
||||||
|
default:
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -28,7 +28,7 @@ bool music_activated = false;
|
|||||||
bool midi_activated = false;
|
bool midi_activated = false;
|
||||||
uint8_t music_starting_note = 0x0C;
|
uint8_t music_starting_note = 0x0C;
|
||||||
int music_offset = 7;
|
int music_offset = 7;
|
||||||
uint8_t music_mode = MUSIC_MODE_CHROMATIC;
|
uint8_t music_mode = MUSIC_MODE_MAJOR;
|
||||||
|
|
||||||
// music sequencer
|
// music sequencer
|
||||||
static bool music_sequence_recording = false;
|
static bool music_sequence_recording = false;
|
||||||
@ -78,10 +78,6 @@ static uint16_t music_sequence_interval = 100;
|
|||||||
float midi_off_song[][2] = MIDI_OFF_SONG;
|
float midi_off_song[][2] = MIDI_OFF_SONG;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef MUSIC_MASK
|
|
||||||
#define MUSIC_MASK keycode < 0xFF
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static void music_noteon(uint8_t note) {
|
static void music_noteon(uint8_t note) {
|
||||||
#ifdef AUDIO_ENABLE
|
#ifdef AUDIO_ENABLE
|
||||||
if (music_activated)
|
if (music_activated)
|
||||||
@ -223,13 +219,31 @@ bool process_music(uint16_t keycode, keyrecord_t *record) {
|
|||||||
music_noteoff(note);
|
music_noteoff(note);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (MUSIC_MASK)
|
if (music_mask(keycode))
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool music_mask(uint16_t keycode) {
|
||||||
|
#ifdef MUSIC_MASK
|
||||||
|
return MUSIC_MASK;
|
||||||
|
#else
|
||||||
|
return music_mask_kb(keycode);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
__attribute__((weak))
|
||||||
|
bool music_mask_kb(uint16_t keycode) {
|
||||||
|
return music_mask_user(keycode);
|
||||||
|
}
|
||||||
|
|
||||||
|
__attribute__((weak))
|
||||||
|
bool music_mask_user(uint16_t keycode) {
|
||||||
|
return keycode < 0xFF;
|
||||||
|
}
|
||||||
|
|
||||||
bool is_music_on(void) {
|
bool is_music_on(void) {
|
||||||
return (music_activated != 0);
|
return (music_activated != 0);
|
||||||
}
|
}
|
||||||
|
@ -49,6 +49,10 @@ void music_mode_cycle(void);
|
|||||||
|
|
||||||
void matrix_scan_music(void);
|
void matrix_scan_music(void);
|
||||||
|
|
||||||
|
bool music_mask(uint16_t keycode);
|
||||||
|
bool music_mask_kb(uint16_t keycode);
|
||||||
|
bool music_mask_user(uint16_t keycode);
|
||||||
|
|
||||||
#ifndef SCALE
|
#ifndef SCALE
|
||||||
#define SCALE (int8_t []){ 0 + (12*0), 2 + (12*0), 4 + (12*0), 5 + (12*0), 7 + (12*0), 9 + (12*0), 11 + (12*0), \
|
#define SCALE (int8_t []){ 0 + (12*0), 2 + (12*0), 4 + (12*0), 5 + (12*0), 7 + (12*0), 9 + (12*0), 11 + (12*0), \
|
||||||
0 + (12*1), 2 + (12*1), 4 + (12*1), 5 + (12*1), 7 + (12*1), 9 + (12*1), 11 + (12*1), \
|
0 + (12*1), 2 + (12*1), 4 + (12*1), 5 + (12*1), 7 + (12*1), 9 + (12*1), 11 + (12*1), \
|
||||||
|
Loading…
Reference in New Issue
Block a user