keymap.c 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. #include "viterbi.h"
  2. #include "action_layer.h"
  3. #include "eeconfig.h"
  4. #ifdef RGBLIGHT_ENABLE
  5. #include "rgblight.h"
  6. #endif
  7. extern keymap_config_t keymap_config;
  8. #define _QWERTY 0
  9. #define _FN 1
  10. enum custom_keycodes {
  11. QWERTY = SAFE_RANGE,
  12. STK_SHIFT,
  13. STK_CTRL,
  14. STK_ALT,
  15. STK_GUI,
  16. STK_META,
  17. STK_CLEAR,
  18. RGB_LEVEL_UP,
  19. RGB_LEVEL_DOWN,
  20. };
  21. #define KC_ KC_TRNS
  22. #define _______ KC_TRNS
  23. #define KC_SWIN LGUI(KC_TILD) // Switch between windows
  24. #define KC_SAPP LGUI(KC_TAB) // Switch between applications
  25. #define KC_FN1 MO(_FN)
  26. #define KC_LCAG LCAG(KC_NO)
  27. #define KC_RTOG RGB_TOG
  28. #define KC_RGUP RGB_LEVEL_UP
  29. #define KC_RGDN RGB_LEVEL_DOWN
  30. #define KC_RST RESET
  31. #define KC_SSFT STK_SHIFT
  32. #define KC_SCTL STK_CTRL
  33. #define KC_SALT STK_ALT
  34. #define KC_SGUI STK_GUI
  35. #define KC_SMTA STK_META
  36. #define KC_SCLR STK_CLEAR
  37. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  38. [_QWERTY] = LAYOUT_kc(
  39. //,----+----+----+----+----+----+----. ,----+----+----+----+----+----+----.
  40. GRV , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 , 0 ,MINS,EQL ,BSPC,
  41. //|----+----+----+----+----+----+----| |----+----+----+----+----+----+----|
  42. TAB , Q , W , E , R , T ,LBRC, Y , U , I , O , P ,BSLS,PGUP,
  43. //|----+----+----+----+----+----+----| |----+----+----+----+----+----+----|
  44. ESC , A , S , D , F , G ,RBRC, H , J , K , L ,SCLN,QUOT,ENT ,
  45. //|----+----+----+----+----+----+----| |----+----+----+----+----+----+----|
  46. SSFT, Z , X , C , V , B ,SWIN, N , M ,COMM,DOT , UP ,SLSH,RSFT,
  47. //|----+----+----+----+----+----+----| |----+----+----+----+----+----+----|
  48. SCTL,SMTA,SALT,SGUI,SPC ,SCLR,SAPP, FN1 ,SPC ,RGUI,LEFT,DOWN,RGHT,PGDN
  49. //`----+----+----+----+----+----+----' `----+----+----+----+----+----+----'
  50. ),
  51. [_FN] = LAYOUT_kc(
  52. //,----+----+----+----+----+----+----. ,----+----+----+----+----+----+----.
  53. , F1 , F2 , F3 , F4 , F5 , F6 , F7 , F8 , F9 ,F10 ,F11 ,F12 , ,
  54. //|----+----+----+----+----+----+----| |----+----+----+----+----+----+----|
  55. , , , ,RST , , , , , , , , , ,
  56. //|----+----+----+----+----+----+----| |----+----+----+----+----+----+----|
  57. , , , , , , , RTOG, ,RGDN,RGUP, , , ,
  58. //|----+----+----+----+----+----+----| |----+----+----+----+----+----+----|
  59. , , , , , , , ,MUTE,VOLD,VOLU, , , ,
  60. //|----+----+----+----+----+----+----| |----+----+----+----+----+----+----|
  61. , , , , , , , , , , , , ,
  62. //`----+----+----+----+----+----+----' `----+----+----+----+----+----+----'
  63. )
  64. };
  65. #ifdef AUDIO_ENABLE
  66. float tone_qwerty[][2] = SONG(QWERTY_SOUND);
  67. #endif
  68. void persistent_default_layer_set(uint16_t default_layer) {
  69. eeconfig_update_default_layer(default_layer);
  70. default_layer_set(default_layer);
  71. }
  72. bool modifier_already_applied = false;
  73. uint8_t physically_held_modifiers = 0;
  74. uint8_t last_mods = 0xFF;
  75. uint8_t rgb_dimming = 0;
  76. #define SET_LED_RGB(val, led_num) setrgb(((val >> 16) & 0xFF) >> rgb_dimming, ((val >> 8) & 0xFF) >> rgb_dimming, (val & 0xFF) >> rgb_dimming, (LED_TYPE *)&led[led_num])
  77. void update_underglow_level(void) {
  78. if (get_mods() == last_mods)
  79. return;
  80. last_mods = get_mods();
  81. if (get_mods() == 0) {
  82. uint8_t level = 0x10 >> rgb_dimming;
  83. rgblight_setrgb(level, level, level);
  84. return;
  85. }
  86. uint32_t mod_colors[4] = {0};
  87. uint8_t mod_count = 0;
  88. rgblight_setrgb(0x00, 0x00, 0x00);
  89. if (get_mods() & MOD_BIT(KC_LSFT))
  90. mod_colors[mod_count++] = 0xFF0000;
  91. if (get_mods() & MOD_BIT(KC_LCTL))
  92. mod_colors[mod_count++] = 0x00FF00;
  93. if (get_mods() & MOD_BIT(KC_LALT))
  94. mod_colors[mod_count++] = 0x0000FF;
  95. if (get_mods() & MOD_BIT(KC_LGUI))
  96. mod_colors[mod_count++] = 0xFFFF00;
  97. uint8_t led_num = 0;
  98. for (int m = 0; m < mod_count; m++) {
  99. for (; led_num < RGBLED_NUM*(m+1)/mod_count; led_num++) {
  100. SET_LED_RGB(mod_colors[m], led_num);
  101. }
  102. }
  103. rgblight_set();
  104. }
  105. void add_sticky_modifier(uint16_t keycode) {
  106. add_mods(MOD_BIT(keycode));
  107. register_code(keycode);
  108. modifier_already_applied = false;
  109. }
  110. void clear_sticky_modifiers(void) {
  111. unregister_code(KC_LSFT);
  112. unregister_code(KC_LCTL);
  113. unregister_code(KC_LALT);
  114. unregister_code(KC_LGUI);
  115. update_underglow_level();
  116. }
  117. void handle_sticky_modifier_event(uint16_t keycode, bool pressed) {
  118. if (pressed) {
  119. add_sticky_modifier(keycode);
  120. physically_held_modifiers |= MOD_BIT(keycode);
  121. } else {
  122. del_mods(MOD_BIT(keycode));
  123. physically_held_modifiers &= ~MOD_BIT(keycode);
  124. if (modifier_already_applied) {
  125. clear_sticky_modifiers();
  126. } else {
  127. add_sticky_modifier(keycode);
  128. }
  129. }
  130. update_underglow_level();
  131. }
  132. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  133. switch (keycode) {
  134. case QWERTY:
  135. if (record->event.pressed) {
  136. #ifdef AUDIO_ENABLE
  137. PLAY_NOTE_ARRAY(tone_qwerty, false, 0);
  138. #endif
  139. persistent_default_layer_set(1UL<<_QWERTY);
  140. }
  141. return false;
  142. break;
  143. case STK_SHIFT:
  144. handle_sticky_modifier_event(KC_LSFT, record->event.pressed);
  145. return false;
  146. break;
  147. case STK_CTRL:
  148. handle_sticky_modifier_event(KC_LCTL, record->event.pressed);
  149. return false;
  150. break;
  151. case STK_ALT:
  152. handle_sticky_modifier_event(KC_LALT, record->event.pressed);
  153. return false;
  154. break;
  155. case STK_GUI:
  156. handle_sticky_modifier_event(KC_LGUI, record->event.pressed);
  157. return false;
  158. break;
  159. case STK_META:
  160. handle_sticky_modifier_event(KC_LCTL, record->event.pressed);
  161. handle_sticky_modifier_event(KC_LALT, record->event.pressed);
  162. handle_sticky_modifier_event(KC_LGUI, record->event.pressed);
  163. return false;
  164. break;
  165. case STK_CLEAR:
  166. if (record->event.pressed) {
  167. clear_sticky_modifiers();
  168. }
  169. return false;
  170. break;
  171. case RGB_LEVEL_DOWN:
  172. if (record->event.pressed && rgb_dimming < 8) {
  173. rgb_dimming++;
  174. }
  175. return false;
  176. break;
  177. case RGB_LEVEL_UP:
  178. if (record->event.pressed && rgb_dimming > 0) {
  179. rgb_dimming--;
  180. }
  181. return false;
  182. break;
  183. }
  184. if (!record->event.pressed && IS_KEY(keycode)) {
  185. modifier_already_applied = true;
  186. if (physically_held_modifiers == 0)
  187. clear_sticky_modifiers();
  188. }
  189. return true;
  190. }
  191. void matrix_init_user(void) {
  192. #ifdef RGBLIGHT_ENABLE
  193. rgblight_enable();
  194. #endif //RGBLIGHT_ENABLE
  195. }
  196. void matrix_scan_user(void) {
  197. #ifdef RGBLIGHT_ENABLE
  198. update_underglow_level();
  199. #endif //RGBLIGHT_ENABLE
  200. }