~ruther/qmk_firmware

63d5c947d3bce7ad9db014b7930e4809aa16fa4c — Jack Humbert 7 years ago 14b7602
updated music mask
M docs/feature_audio.md => docs/feature_audio.md +14 -0
@@ 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!

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`:

    #define PITCH_STANDARD_A 432.0f

M keyboards/planck/keymaps/default/config.h => keyboards/planck/keymaps/default/config.h +2 -4
@@ 13,8 13,6 @@
                                }
#endif

#define MUSIC_MASK (keycode != KC_NO)

/*
 * MIDI options
 */


@@ 25,7 23,7 @@
/* enable basic MIDI features:
   - MIDI notes can be sent when in Music mode is on
*/
                                

#define MIDI_BASIC

/* enable advanced MIDI features:


@@ 39,4 37,4 @@
/* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */
//#define MIDI_TONE_KEYCODE_OCTAVES 2

#endif
\ No newline at end of file
#endif

M keyboards/planck/keymaps/default/keymap.c => keyboards/planck/keymaps/default/keymap.c +10 -0
@@ 247,3 247,13 @@ bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  }
  return true;
}

bool music_mask_user(uint16_t keycode) {
  switch (keycode) {
    case RAISE:
    case LOWER:
      return false;
    default:
      return true;
  }
}

M quantum/process_keycode/process_music.c => quantum/process_keycode/process_music.c +24 -10
@@ 28,7 28,7 @@ bool music_activated = false;
bool midi_activated = false;
uint8_t music_starting_note = 0x0C;
int music_offset = 7;
uint8_t music_mode = MUSIC_MODE_CHROMATIC;
uint8_t music_mode = MUSIC_MODE_MAJOR;

// music sequencer
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;
#endif

#ifndef MUSIC_MASK
  #define MUSIC_MASK keycode < 0xFF
#endif

static void music_noteon(uint8_t note) {
    #ifdef AUDIO_ENABLE
    if (music_activated)


@@ 120,7 116,7 @@ bool process_music(uint16_t keycode, keyrecord_t *record) {
    if (keycode == MU_ON && record->event.pressed) {
        music_on();
        return false;
    }    
    }

    if (keycode == MU_OFF && record->event.pressed) {
        music_off();


@@ 139,7 135,7 @@ bool process_music(uint16_t keycode, keyrecord_t *record) {
    if (keycode == MI_ON && record->event.pressed) {
        midi_on();
        return false;
    }    
    }

    if (keycode == MI_OFF && record->event.pressed) {
        midi_off();


@@ 202,7 198,7 @@ bool process_music(uint16_t keycode, keyrecord_t *record) {
      }

      uint8_t note;
      if (music_mode == MUSIC_MODE_CHROMATIC) 
      if (music_mode == MUSIC_MODE_CHROMATIC)
        note = (music_starting_note + record->event.key.col + music_offset - 3)+12*(MATRIX_ROWS - record->event.key.row);
      else if (music_mode == MUSIC_MODE_GUITAR)
        note = (music_starting_note + record->event.key.col + music_offset + 32)+5*(MATRIX_ROWS - record->event.key.row);


@@ 223,13 219,31 @@ bool process_music(uint16_t keycode, keyrecord_t *record) {
        music_noteoff(note);
      }

      if (MUSIC_MASK)
      if (music_mask(keycode))
        return false;
    }

    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) {
    return (music_activated != 0);
}


@@ 318,4 332,4 @@ void midi_on_user() {}
__attribute__ ((weak))
void music_scale_user() {}

#endif // defined(AUDIO_ENABLE) || (defined(MIDI_ENABLE) && defined(MIDI_BASIC))
\ No newline at end of file
#endif // defined(AUDIO_ENABLE) || (defined(MIDI_ENABLE) && defined(MIDI_BASIC))

M quantum/process_keycode/process_music.h => quantum/process_keycode/process_music.h +4 -0
@@ 49,6 49,10 @@ void music_mode_cycle(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
#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), \