keymap.c 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. #include QMK_KEYBOARD_H
  2. // Layer shorthand
  3. #define _QW 0
  4. #define _CM 1
  5. #define _FN 2
  6. typedef enum {
  7. NONE_NONE,
  8. SINGLE_TAP,
  9. SINGLE_HOLD,
  10. DOUBLE_SINGLE_TAP
  11. } td_state_t;
  12. static td_state_t td_state = NONE_NONE;
  13. int cur_dance (qk_tap_dance_state_t *state);
  14. void altlp_finished (qk_tap_dance_state_t *state, void *user_data);
  15. void altlp_reset (qk_tap_dance_state_t *state, void *user_data);
  16. // Four differend underglow states for 2 language layouts x 2 states of colemak layer
  17. enum layer_states {
  18. S_ENGLISH,
  19. S_COLEMAK,
  20. S_CRUSSIAN,
  21. S_QRUSSIAN
  22. } l_state = S_ENGLISH;
  23. // CLMK to toggle colemak (active only with english qwerty, saves intent in russian but does nothing untill switched back to english)
  24. // RNBW - rainbow underglow
  25. // PING - ping pong underglow
  26. // SP_UP/DW - underglow speed controls
  27. enum custom_keycodes {
  28. STUB = SAFE_RANGE,
  29. CLMK,
  30. RNBW,
  31. PING,
  32. SP_UP,
  33. SP_DW
  34. };
  35. // Escape if taped, FN layer mod if held
  36. enum tapdance_codes {
  37. LESC
  38. };
  39. bool sstate = false;
  40. int rgb = 0;
  41. int speed = 300;
  42. void set_colors(int r, int g, int b) {
  43. for(int i = 0; i<6; i++) {
  44. sethsv(r, g, b, (LED_TYPE *)&led[i]);
  45. }
  46. rgblight_set();
  47. }
  48. void update_led_state_c(void) {
  49. if (rgb>0) return;
  50. if (td_state == SINGLE_HOLD) set_colors(HSV_BLUE);
  51. else {
  52. if (l_state == S_ENGLISH) set_colors(HSV_RED);
  53. if (l_state == S_QRUSSIAN) set_colors(HSV_GREEN);
  54. if (l_state == S_COLEMAK) set_colors(HSV_YELLOW);
  55. if (l_state == S_CRUSSIAN) set_colors(85, 100, 100);
  56. }
  57. }
  58. int cur_dance (qk_tap_dance_state_t *state) {
  59. if (state->count == 1) {
  60. if (state->interrupted && state->pressed) { return SINGLE_HOLD; }
  61. else if (!state->pressed) { return SINGLE_TAP; }
  62. else { return SINGLE_HOLD; }
  63. }
  64. if (state->count == 2) { return DOUBLE_SINGLE_TAP; }
  65. else { return 3; }
  66. }
  67. // Tapdance code stolen long time ago from one of the forum answers i found related to my problem, sadly can't provide link for the credits
  68. void lesc_finished (qk_tap_dance_state_t *state, void *user_data) {
  69. td_state = cur_dance(state);
  70. switch (td_state) {
  71. case SINGLE_TAP:
  72. register_code16(KC_ESC);
  73. break;
  74. case SINGLE_HOLD:
  75. layer_on(_FN);
  76. update_led_state_c();
  77. sstate = false;
  78. break;
  79. case DOUBLE_SINGLE_TAP:
  80. break;
  81. case NONE_NONE:
  82. break;
  83. }
  84. }
  85. void lesc_reset (qk_tap_dance_state_t *state, void *user_data) {
  86. switch (td_state) {
  87. case SINGLE_TAP:
  88. unregister_code16(KC_ESC);
  89. break;
  90. case SINGLE_HOLD:
  91. layer_off(_FN);
  92. if (sstate == false) {
  93. register_code16(KC_ESC);
  94. unregister_code16(KC_ESC);
  95. }
  96. break;
  97. case DOUBLE_SINGLE_TAP:
  98. break;
  99. case NONE_NONE:
  100. break;
  101. }
  102. td_state = NONE_NONE;
  103. update_led_state_c();
  104. }
  105. qk_tap_dance_action_t tap_dance_actions[] = {
  106. [LESC] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, lesc_finished, lesc_reset)
  107. };
  108. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  109. [_QW] = LAYOUT_ortho_5x15( /* QWERTY */
  110. KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_MINS, RNBW, KC_EQL, KC_6, KC_7, KC_8, KC_9, KC_0, KC_BSPC,
  111. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_LBRC, KC_BSLS, KC_RBRC, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_QUOT,
  112. KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, CLMK, KC_DEL, SP_UP, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_ENT,
  113. KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, _______, KC_UP, SP_DW, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT,
  114. KC_LCTL, LSFT(KC_9), KC_LALT, KC_LGUI, TD(LESC),KC_SPC, KC_LEFT, KC_DOWN, KC_RGHT, KC_ENT, TD(LESC),KC_RGUI, KC_RALT, RSFT(KC_0),KC_RCTL
  115. ),
  116. [_CM] = LAYOUT_ortho_5x15( /* COLEMAK */
  117. _______, _______, _______, _______, _______, _______, _______, PING, _______, _______, _______, _______, _______, _______, _______,
  118. _______, KC_Q, KC_W, KC_F, KC_P, KC_Z, _______, _______, _______, KC_J, KC_L, KC_U, KC_Y, KC_SCLN, KC_SLSH,
  119. _______, KC_A, KC_R, KC_S, KC_T, KC_G, _______, _______, _______, KC_M, KC_N, KC_E, KC_I, KC_O, _______,
  120. _______, KC_X, KC_V, KC_C, KC_D, KC_B, _______, _______, _______, KC_K, KC_H, KC_DOT, KC_COMM, KC_QUOT, _______,
  121. _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______
  122. ),
  123. [_FN] = LAYOUT_ortho_5x15( /* FUNCTION */
  124. KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_P7, KC_P8, KC_P9, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12,
  125. RESET, KC_BTN1, KC_MS_U, KC_BTN2, KC_BTN3, KC_WH_U, KC_P4, KC_P5, KC_P6, _______, _______, _______, RSFT(KC_MINS), LSFT(KC_MINS), _______,
  126. _______, KC_MS_L, KC_MS_D, KC_MS_R, KC_MINS, KC_WH_D, KC_P1, KC_P2, KC_P3, _______, KC_PPLS, KC_ACL0, KC_ACL1, KC_ACL2, _______,
  127. _______, KC_ACL0, KC_ACL1, KC_ACL2, KC_WH_L, KC_WH_R, KC_NLCK, KC_PGUP, KC_P0, _______, _______, _______, _______, _______, _______,
  128. RGB_TOG, _______, _______, _______, KC_BSPC, KC_BSPC, KC_HOME, KC_PGDN, KC_END, KC_BSPC, KC_BSPC, _______, _______, _______, _______
  129. )
  130. };
  131. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  132. if(keycode != TD(LESC))
  133. sstate = true;
  134. switch (keycode) {
  135. case SP_UP:
  136. if (speed>25)
  137. speed -= 25;
  138. break;
  139. case SP_DW:
  140. if (speed < 1000)
  141. speed += 25;
  142. break;
  143. case RNBW:
  144. if(record->event.pressed) {
  145. rgb = rgb == 0 ? 1 : 0;
  146. update_led_state_c();
  147. }
  148. break;
  149. case PING:
  150. if(record->event.pressed) {
  151. rgb = rgb == 0 ? 2 : 0;
  152. update_led_state_c();
  153. }
  154. break;
  155. case CLMK:
  156. if(record->event.pressed) {
  157. if (l_state == S_COLEMAK) {
  158. layer_off(_CM);
  159. l_state = S_ENGLISH;
  160. }
  161. else if (l_state == S_ENGLISH) {
  162. layer_on(_CM);
  163. l_state = S_COLEMAK;
  164. }
  165. else if (l_state == S_CRUSSIAN) { l_state = S_QRUSSIAN; }
  166. else if (l_state == S_QRUSSIAN) { l_state = S_CRUSSIAN; }
  167. }
  168. update_led_state_c();
  169. break;
  170. case KC_CAPS:
  171. if(record->event.pressed) {
  172. if (l_state == S_ENGLISH) l_state = S_QRUSSIAN;
  173. else if (l_state == S_QRUSSIAN) l_state = S_ENGLISH;
  174. else if (l_state == S_COLEMAK) {
  175. layer_off(_CM);
  176. l_state = S_CRUSSIAN;
  177. }
  178. else if (l_state == S_CRUSSIAN) {
  179. layer_on(_CM);
  180. l_state = S_COLEMAK;
  181. }
  182. update_led_state_c();
  183. }
  184. break;
  185. }
  186. return true;
  187. }
  188. void matrix_init_user(void) { }
  189. // Rainbow globals
  190. int t = 0;
  191. int rc = 0;
  192. int col = 0;
  193. bool right = false;
  194. void matrix_scan_user(void) {
  195. if (rgb==0) return; // Do nothing each tick right away if neither of animations enabled
  196. if (rgb==1) {
  197. if (rc == 0) {
  198. rc = speed;
  199. for(int i = 0; i<6; i++) {
  200. sethsv(42*((t+i)%6), 255, 255, (LED_TYPE *)&led[i]);
  201. }
  202. rgblight_set();
  203. t++; t = t % 6;
  204. }
  205. } else if (rgb==2) {
  206. if (rc == 0) {
  207. rc = speed;
  208. col = (col + 1) % 36;
  209. for (int i = 0; i<6; i++) {
  210. if (i==t)
  211. sethsv(42*(((col-1)/6)%6), 255, 255, (LED_TYPE *)&led[(right ? t : 5-t)]);
  212. else
  213. sethsv(0, 0, 0, (LED_TYPE *)&led[right ? i : 5-i]);
  214. }
  215. rgblight_set();
  216. t++; t = t % 6;
  217. if (t == 0) right = !right;
  218. }
  219. }
  220. rc--;
  221. }
  222. void led_set_user(uint8_t usb_led) { }