keymap.c 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. #include QMK_KEYBOARD_H
  2. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  3. [0] = LAYOUT_planck_mit(
  4. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC,
  5. KC_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_ENT,
  6. KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_UP,
  7. KC_LCTL, KC_LGUI, KC_LALT, KC_LBRC, KC_MINS, LT(1, KC_SPC), KC_EQL, KC_RBRC, KC_LEFT, KC_DOWN, KC_RGHT,
  8. KC_VOLD, KC_VOLU, KC_PGDN, KC_PGUP),
  9. [1] = LAYOUT_planck_mit(
  10. KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_TRNS,
  11. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  12. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  13. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_BSPC, KC_TRNS, KC_DEL, KC_TRNS, KC_TRNS, KC_BSLS, KC_TRNS,
  14. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  15. };
  16. extern rgblight_config_t rgblight_config;
  17. int RGB_LAYER0_mode = 6;
  18. static uint8_t current_layer = 0;
  19. static bool has_layer_changed = true;
  20. uint16_t i = 0;
  21. uint16_t j = 0;
  22. static uint16_t RGB_encoder_timer;
  23. static uint16_t RGB_encoder_timer2;
  24. static uint8_t RGB_encoder_dir = 0;
  25. const uint8_t RGBLED_RAINBOW_MOOD_INTERVALS[] PROGMEM = {
  26. 30,
  27. 5,
  28. -5
  29. };
  30. void matrix_init_user(void) {
  31. RGB_encoder_timer = timer_read();
  32. RGB_encoder_timer2 = timer_read();
  33. }
  34. void matrix_scan_user(void) {
  35. uint8_t layer = biton32(layer_state);
  36. if (RGB_encoder_dir != 0) {
  37. if (timer_elapsed(RGB_encoder_timer) > 1400) {
  38. RGB_encoder_dir = 0;
  39. rgblight_mode(RGB_LAYER0_mode);
  40. } else {
  41. if (timer_elapsed(RGB_encoder_timer2) > 700) {
  42. rgblight_setrgb(0, 0, 0);
  43. RGB_encoder_timer2 = timer_read();
  44. }
  45. if (timer_elapsed(RGB_encoder_timer2) > 80) {
  46. if (RGB_encoder_dir == 1) {
  47. rgblight_setrgb_at(128, 128, 0, 19);
  48. } else {
  49. rgblight_setrgb_at(128, 128, 0, 16);
  50. }
  51. }
  52. if (timer_elapsed(RGB_encoder_timer2) > 180) {
  53. if (RGB_encoder_dir == 1) {
  54. rgblight_setrgb_at(160, 160, 0, 8);
  55. } else {
  56. rgblight_setrgb_at(160, 160, 0, 3);
  57. }
  58. }
  59. if (timer_elapsed(RGB_encoder_timer2) > 280) {
  60. if (RGB_encoder_dir == 1) {
  61. rgblight_setrgb_at(192, 192, 0, 9);
  62. } else {
  63. rgblight_setrgb_at(192, 192, 0, 2);
  64. }
  65. }
  66. if (timer_elapsed(RGB_encoder_timer2) > 400) {
  67. if (RGB_encoder_dir == 1) {
  68. rgblight_setrgb_at(224, 224, 0, 10);
  69. } else {
  70. rgblight_setrgb_at(224, 224, 0, 1);
  71. }
  72. }
  73. }
  74. }
  75. /* layer rgb */
  76. if (layer != current_layer) {
  77. has_layer_changed = true;
  78. current_layer = layer;
  79. }
  80. if (has_layer_changed) {
  81. if (layer == 0) {
  82. rgblight_mode(RGB_LAYER0_mode);
  83. } else {
  84. rgblight_mode(1);
  85. for (i = 0; i < 48; i++) {
  86. (i > 41) ? (j = i - 1) : (j = i);
  87. uint16_t kc = keymap_key_to_keycode(layer, (keypos_t) {.row = 0, .col = i
  88. });
  89. if (kc == KC_TRNS) {
  90. setrgb(5, 5, 5, (LED_TYPE * ) & led[j]); /* TRNS color 0-255*/
  91. } else if (kc == KC_NO) {
  92. setrgb(0, 0, 0, (LED_TYPE * ) & led[j]); /* NO color 0-255*/
  93. } else {
  94. if (layer == 1) {
  95. setrgb(128, 64, 0, (LED_TYPE * ) & led[j]); /* 1 layer 0-255*/
  96. } else if (layer == 2) {
  97. setrgb(0, 64, 128, (LED_TYPE * ) & led[j]); /* 2*/
  98. } else if (layer == 3) {
  99. setrgb(64, 128, 0, (LED_TYPE * ) & led[j]); /* 3*/
  100. } else if (layer == 4) {
  101. setrgb(0, 128, 64, (LED_TYPE * ) & led[j]); /* 4*/
  102. } else if (layer == 5) {
  103. setrgb(128, 0, 128, (LED_TYPE * ) & led[j]); /* 5*/
  104. } else if (layer == 6) {
  105. setrgb(128, 0, 128, (LED_TYPE * ) & led[j]); /* 6*/
  106. } else if (layer == 7) {
  107. setrgb(128, 128, 0, (LED_TYPE * ) & led[j]); /* 7*/
  108. } else if (layer == 8) {
  109. setrgb(0, 128, 128, (LED_TYPE * ) & led[j]); /* 8*/
  110. } else if (layer == 9) {
  111. setrgb(128, 192, 64, (LED_TYPE * ) & led[j]); /* 9*/
  112. } else if (layer == 10) {
  113. setrgb(64, 192, 128, (LED_TYPE * ) & led[j]); /* 10*/
  114. } else if (layer == 11) {
  115. setrgb(128, 64, 192, (LED_TYPE * ) & led[j]); /* 11*/
  116. } else if (layer == 12) {
  117. setrgb(64, 128, 192, (LED_TYPE * ) & led[j]); /* 12*/
  118. } else if (layer == 13) {
  119. setrgb(128, 192, 0, (LED_TYPE * ) & led[j]); /* 13*/
  120. } else if (layer == 14) {
  121. setrgb(192, 0, 128, (LED_TYPE * ) & led[j]); /* 14*/
  122. } else if (layer == 15) {
  123. setrgb(0, 192, 128, (LED_TYPE * ) & led[j]); /* 15*/
  124. }
  125. }
  126. }
  127. rgblight_set();
  128. }
  129. has_layer_changed = false;
  130. }
  131. /* end of layer rgb */
  132. }
  133. bool process_record_user(uint16_t keycode, keyrecord_t * record) {
  134. switch (keycode) {
  135. case RGB_MOD:
  136. RGB_LAYER0_mode = rgblight_config.mode;
  137. break;
  138. default:
  139. return (true);
  140. }
  141. return (true);
  142. }
  143. void encoder_update_user(uint8_t index, bool clockwise) {
  144. RGB_encoder_timer = timer_read();
  145. RGB_encoder_timer2 = timer_read();
  146. uint8_t layer = biton32(layer_state);
  147. if (clockwise) {
  148. RGB_encoder_dir = 1;
  149. } else {
  150. RGB_encoder_dir = -1;
  151. }
  152. if (index == 0) /* Right encoder */ {
  153. if (clockwise) {
  154. register_code(keymap_key_to_keycode(layer, (keypos_t) {.row = 4, .col = 11
  155. }));
  156. unregister_code(keymap_key_to_keycode(layer, (keypos_t) {.row = 4, .col = 11
  157. }));
  158. } else {
  159. register_code(keymap_key_to_keycode(layer, (keypos_t) {.row = 4, .col = 10
  160. }));
  161. unregister_code(keymap_key_to_keycode(layer, (keypos_t) {.row = 4, .col = 10
  162. }));
  163. }
  164. } else if (index == 1) /* Left encoder */ {
  165. if (clockwise) {
  166. register_code(keymap_key_to_keycode(layer, (keypos_t) {.row = 4, .col = 1
  167. }));
  168. unregister_code(keymap_key_to_keycode(layer, (keypos_t) {.row = 4, .col = 1
  169. }));
  170. } else {
  171. register_code(keymap_key_to_keycode(layer, (keypos_t) {.row = 4, .col = 0
  172. }));
  173. unregister_code(keymap_key_to_keycode(layer, (keypos_t) {.row = 4, .col = 0
  174. }));
  175. }
  176. }
  177. }