keychron_qmk_firmware/quantum/process_keycode/process_audio.c

65 lines
1.5 KiB
C
Raw Normal View History

#include "audio.h"
#include "process_audio.h"
#include <math.h>
#ifndef VOICE_CHANGE_SONG
2019-08-31 00:19:03 +06:00
# define VOICE_CHANGE_SONG SONG(VOICE_CHANGE_SOUND)
#endif
float voice_change_song[][2] = VOICE_CHANGE_SONG;
2017-07-24 22:44:03 +06:00
#ifndef PITCH_STANDARD_A
2019-08-31 00:19:03 +06:00
# define PITCH_STANDARD_A 440.0f
2017-07-24 22:44:03 +06:00
#endif
2019-08-31 00:19:03 +06:00
float compute_freq_for_midi_note(uint8_t note) {
// https://en.wikipedia.org/wiki/MIDI_tuning_standard
return powf(2.0f, (note - 69) / 12.0f) * PITCH_STANDARD_A;
}
bool process_audio(uint16_t keycode, keyrecord_t *record) {
if (keycode == QK_AUDIO_ON && record->event.pressed) {
2019-08-31 00:19:03 +06:00
audio_on();
return false;
}
if (keycode == QK_AUDIO_OFF && record->event.pressed) {
2019-08-31 00:19:03 +06:00
audio_off();
return false;
}
if (keycode == QK_AUDIO_TOGGLE && record->event.pressed) {
if (is_audio_on()) {
audio_off();
} else {
audio_on();
}
2017-02-26 09:37:33 +06:00
return false;
}
if (keycode == QK_AUDIO_VOICE_NEXT && record->event.pressed) {
voice_iterate();
PLAY_SONG(voice_change_song);
return false;
}
if (keycode == QK_AUDIO_VOICE_PREVIOUS && record->event.pressed) {
voice_deiterate();
PLAY_SONG(voice_change_song);
return false;
}
return true;
}
void process_audio_noteon(uint8_t note) {
play_note(compute_freq_for_midi_note(note), 0xF);
}
void process_audio_noteoff(uint8_t note) {
stop_note(compute_freq_for_midi_note(note));
}
void process_audio_all_notes_off(void) {
stop_all_notes();
}