keymap.c 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. /* Copyright 2021 3araht
  2. *
  3. * This program is free software: you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License as published by
  5. * the Free Software Foundation, either version 2 of the License, or
  6. * (at your option) any later version.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU General Public License
  14. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. */
  16. #include QMK_KEYBOARD_H
  17. #include "version.h"
  18. // Defines names for use in layer keycodes and the keymap
  19. enum layer_names {
  20. _BASE, // Base layer, shift mode, single channel.
  21. _TRANS, // Transpose feature is enabled instead of shift mode, single channel.
  22. _RESERVE, // RESERVE
  23. _FN // FuNction layer. This must be at the end of the enumurate to use the range from _LS_FN ... _LS_FN_MAX for FN layer LED settings.
  24. };
  25. // Layer State
  26. #define _LS_BASE (1UL << _BASE)
  27. #define _LS_TRANS (1UL << _BASE | 1UL << _TRANS)
  28. #define _LS_FN (1UL << _FN)
  29. #define _LS_MAX (_LS_FN << 1)
  30. // Don't change the DEFAULT_SCALE_COL value below. It must be 0.
  31. #define DEFAULT_SCALE_COL 0
  32. static uint8_t scale_indicator_col = DEFAULT_SCALE_COL;
  33. static bool trans_mode_indicator_loc_sel = true; // when it is true, the location is _KEY01, _KEY13, ...
  34. // use led indicator or not.
  35. static bool led_indicator_enable = true;
  36. // Defines the keycodes used by our macros in process_record_user
  37. enum custom_keycodes {
  38. SHIFT_L = USER00,
  39. SHIFT_R,
  40. TGLINDI, // ToGgLe INDIcator
  41. TGLINTR, // ToGgLe INdicator location {(_KEY01, _KEY13, _KEY25, _KEY37) or (_KEY02, _KEY14, _KEY26) / (_KEY12, _KEY24, _KEY36)}in TRans mode
  42. TGLTRNS, // ToGgLe TRaNS and shift
  43. B_BASE, // border set to the left end.
  44. VERSION
  45. };
  46. // Long press: go to _FN layer, tap: MUTE
  47. #define FN_MUTE LT(_FN, KC_MUTE)
  48. // Used to set octave to MI_OCT_0
  49. extern midi_config_t midi_config;
  50. static bool is_trans_mode = false; // By default, shift mode is chosen.
  51. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  52. /* Base */
  53. [_BASE] = LAYOUT(
  54. FN_MUTE, MI_SUS,
  55. MI_BENDU,
  56. SHIFT_L, SHIFT_R, MI_C_2, MI_D_2, MI_E_2, MI_Fs_2, MI_Ab_2, MI_Bb_2, MI_C_3, MI_D_3, MI_E_3, MI_Fs_3, MI_Ab_3, MI_Bb_3, MI_C_4, MI_D_4, MI_E_4, MI_Fs_4, MI_Ab_4, MI_Bb_4, MI_C_5,
  57. MI_BENDD, MI_Db_2, MI_Eb_2, MI_F_2, MI_G_2, MI_A_2, MI_B_2, MI_Db_3, MI_Eb_3, MI_F_3, MI_G_3, MI_A_3, MI_B_3, MI_Db_4, MI_Eb_4, MI_F_4, MI_G_4, MI_A_4, MI_B_4
  58. ),
  59. /* TRANS This layer must locate 1 layer below _FN layer. */
  60. [_TRANS] = LAYOUT(
  61. _______, _______,
  62. _______,
  63. MI_TRNSD, MI_TRNSU, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
  64. _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______
  65. ),
  66. /* RESERVE */
  67. [_RESERVE] = LAYOUT(
  68. _______, _______,
  69. _______,
  70. _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
  71. _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______
  72. ),
  73. [_FN] = LAYOUT(
  74. _______, XXXXXXX,
  75. MI_VELU,
  76. MI_OCTD, MI_OCTU, B_BASE, DF(_RESERVE), XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, XXXXXXX, VERSION, XXXXXXX, XXXXXXX,
  77. MI_VELD, TGLINTR, TGLTRNS, XXXXXXX, XXXXXXX, XXXXXXX, RGB_SAD, RGB_SAI, RGB_HUD, RGB_HUI, RGB_SPD, RGB_SPI, RGB_VAD, RGB_VAI, RGB_RMOD, RGB_MOD, EE_CLR, TGLINDI, RGB_TOG
  78. )
  79. };
  80. #if defined(ENCODER_MAP_ENABLE)
  81. const uint16_t PROGMEM encoder_map[][NUM_ENCODERS][2] = {
  82. [_BASE] = { ENCODER_CCW_CW(KC_VOLD, KC_VOLU) },
  83. [_TRANS] = { ENCODER_CCW_CW(_______, _______) },
  84. [_RESERVE] = { ENCODER_CCW_CW(_______, _______) },
  85. [_FN] = { ENCODER_CCW_CW(RGB_RMOD, RGB_MOD) },
  86. };
  87. #endif
  88. // commom codes called from eeconfig_init_user() and keyboard_post_init_user().
  89. void my_init(void){
  90. // Set octave to MI_OCT_1
  91. midi_config.octave = MI_OCT_0 - MIDI_OCTAVE_MIN;
  92. // avoid using 127 since it is used as a special number in some sound sources.
  93. midi_config.velocity = MIDI_INITIAL_VELOCITY;
  94. default_layer_set(_LS_BASE);
  95. layer_state_set(_LS_BASE);
  96. #ifdef RGB_MATRIX_ENABLE
  97. rgb_matrix_mode(RGB_MATRIX_CUSTOM_my_solid_reactive_col);
  98. #endif // RGB_MATRIX_ENABLE
  99. }
  100. void eeconfig_init_user(void) { // EEPROM is getting reset!
  101. midi_init();
  102. #ifdef RGB_MATRIX_ENABLE
  103. rgb_matrix_enable();
  104. rgb_matrix_set_speed(RGB_MATRIX_STARTUP_SPD);
  105. rgb_matrix_sethsv(HSV_BLUE);
  106. #endif // RGB_MATRIX_ENABLE
  107. my_init(); // commom codes called from eeconfig_init_user() and keyboard_post_init_user().
  108. }
  109. void keyboard_post_init_user(void) {
  110. my_init(); // commom codes called from eeconfig_init_user() and keyboard_post_init_user().
  111. }
  112. void reset_scale_indicator(void) {
  113. // reset transpose value and scale_indicator_col to default.
  114. midi_config.transpose = 0;
  115. scale_indicator_col = DEFAULT_SCALE_COL;
  116. trans_mode_indicator_loc_sel = true;
  117. }
  118. void reset_all(void) {
  119. reset_scale_indicator();
  120. is_trans_mode = false; // trans mode is disabled by default.
  121. }
  122. void select_layer_state_set(void) {
  123. if (is_trans_mode) {
  124. layer_state_set(_LS_TRANS);
  125. } else {
  126. layer_state_set(_LS_BASE);
  127. }
  128. }
  129. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  130. // uprintf("keycode=%u, YM_C_3=%u, YM_Db_2 =%u, YM_MIN = %u, YM_MAX = %u\n", keycode, YM_C_3, YM_Db_2, YM_TONE_MIN, YM_TONE_MAX);
  131. switch (keycode) {
  132. case VERSION: // Output firmware info.
  133. if (record->event.pressed) {
  134. SEND_STRING(QMK_KEYBOARD ":" QMK_KEYMAP " @ " QMK_VERSION " | " QMK_BUILDDATE);
  135. }
  136. break;
  137. // Layer-related settings.
  138. // reset_scale_indicator() first, followed by each modification, and then change the default layer.
  139. // 1, separator column modification
  140. case B_BASE:
  141. if (record->event.pressed) {
  142. reset_all();
  143. select_layer_state_set();
  144. }
  145. break;
  146. // 2, Toggle scale shift mode and transpose mode
  147. case TGLTRNS:
  148. if (record->event.pressed) {
  149. reset_scale_indicator();
  150. is_trans_mode = !is_trans_mode;
  151. select_layer_state_set();
  152. }
  153. break;
  154. // SHIFT_L and SHIFT_R can be pressed only when layer is either _BASE, _FLIPBASE.
  155. case SHIFT_L:
  156. if (record->event.pressed) {
  157. if (layer_state == _LS_BASE) {
  158. scale_indicator_col = shift_led_indicator_left(scale_indicator_col);
  159. }
  160. }
  161. break;
  162. case SHIFT_R:
  163. if (record->event.pressed) {
  164. if (layer_state == _LS_BASE ) {
  165. scale_indicator_col = shift_led_indicator_right(scale_indicator_col);
  166. }
  167. }
  168. break;
  169. case TGLINDI:
  170. if (record->event.pressed) {
  171. led_indicator_enable = !led_indicator_enable;
  172. }
  173. break;
  174. case TGLINTR:
  175. if (record->event.pressed) {
  176. switch (layer_state) {
  177. // main function of the TGLINTR part 1. alternate the status of trans_mode_indicator_loc_sel.
  178. case _LS_TRANS | (1UL << _FN):
  179. trans_mode_indicator_loc_sel = !trans_mode_indicator_loc_sel;
  180. // when trans_mode_indicator_loc_sel == false, change the scale indicator and transpose.
  181. scale_indicator_col = trans_mode_indicator_loc_sel ? 0:1;
  182. // when TGLINTR is pressed, it also change the initial transpose setting to follow the scale indicator.
  183. if (scale_indicator_col == 1) {
  184. midi_config.transpose = -1;
  185. } else {
  186. midi_config.transpose = 0;
  187. }
  188. break;
  189. // special treatment when TGLINTR is pressed in other non-Trans layer.
  190. default : // when other layers = non-Trans mode, change it to Trans mode.
  191. trans_mode_indicator_loc_sel = false;
  192. scale_indicator_col = 1;
  193. midi_config.transpose = -1;
  194. is_trans_mode = true;
  195. select_layer_state_set();
  196. }
  197. }
  198. break;
  199. }
  200. return true;
  201. }
  202. #ifdef RGB_MATRIX_ENABLE
  203. void set_led_scale_indicator(uint8_t r, uint8_t g, uint8_t b) {
  204. uint8_t max_scale_indicator_led_loop;
  205. uint8_t i;
  206. if (led_indicator_enable) { // turn on indicators when enabled.
  207. max_scale_indicator_led_loop = ( scale_indicator_col == DEFAULT_SCALE_COL ) ? 12 : 9;
  208. for (i = 0; i < max_scale_indicator_led_loop; i++) {
  209. rgb_matrix_set_color(led_scale_indicator[scale_indicator_col][i], r, g, b);
  210. }
  211. }
  212. }
  213. bool rgb_matrix_indicators_user(void) {
  214. // uint32_t mode = rgblight_get_mode();
  215. if (rgb_matrix_is_enabled()) { // turn the lights on when it is enabled.
  216. // uint8_t max_scale_indicator_led_loop;
  217. uint8_t i;
  218. switch (layer_state) {
  219. case _LS_BASE:
  220. set_led_scale_indicator(BASE_LAYER_COLOR);
  221. break;
  222. case _LS_TRANS:
  223. set_led_scale_indicator(TRANS_LAYER_COLOR);
  224. break;
  225. case _LS_FN ... _LS_MAX: // When Mute Button is long-pressed, the previous layers are still active.
  226. for (i = 1; i < 5; i++) {
  227. rgb_matrix_set_color(i, RGB_DARKSPRINGGREEN); // up(1) down(4) left(3) right(2) keys
  228. }
  229. rgb_matrix_set_color(led_single_col_indicator[_KEY02][0], RGB_DARKSPRINGGREEN); // TGLTRNS
  230. rgb_matrix_set_color(led_single_col_indicator[_KEY04][0], RGB_DARKSPRINGGREEN); // TGLINTR
  231. for (i = 0; i < 3; i++) {
  232. rgb_matrix_set_color(led_single_col_indicator[_KEY01][i], BASE_LAYER_COLOR); // B_BASE
  233. }
  234. for (i = _KEY12; i < _KEY37; i+=2){ // even numbers from _KEY12 to _KEY36 are LED related settings.
  235. // turn on the bottom row only to keep the visibility of the RGB MATRIX effects.
  236. rgb_matrix_set_color(led_single_col_indicator[i][0], RGB_DARKSPRINGGREEN); // // LED related settings.
  237. }
  238. break;
  239. }
  240. }
  241. return false;
  242. }
  243. #endif // RGB_MATRIX_ENABLE