2
0

keymap.c 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. #include "crkbd.h"
  2. #include "bootloader.h"
  3. #include "action_layer.h"
  4. #include "action_util.h"
  5. #include "eeconfig.h"
  6. #ifdef PROTOCOL_LUFA
  7. #include "lufa.h"
  8. #include "split_util.h"
  9. #endif
  10. #include "LUFA/Drivers/Peripheral/TWI.h"
  11. #ifdef SSD1306OLED
  12. #include "ssd1306.h"
  13. #endif
  14. #include "../lib/mode_icon_reader.c"
  15. #include "../lib/layer_state_reader.c"
  16. #include "../lib/host_led_state_reader.c"
  17. #include "../lib/logo_reader.c"
  18. #include "../lib/keylogger.c"
  19. #include "../lib/timelogger.c"
  20. extern keymap_config_t keymap_config;
  21. #ifdef RGBLIGHT_ENABLE
  22. //Following line allows macro to read current RGB settings
  23. extern rgblight_config_t rgblight_config;
  24. #endif
  25. extern uint8_t is_master;
  26. // Each layer gets a name for readability, which is then used in the keymap matrix below.
  27. // The underscores don't mean anything - you can have a layer called STUFF or any other name.
  28. // Layer names don't all need to be of the same length, obviously, and you can also skip them
  29. // entirely and just use numbers.
  30. #define _QWERTY 0
  31. #define _LOWER 3
  32. #define _RAISE 4
  33. #define _ADJUST 16
  34. enum custom_keycodes {
  35. QWERTY = SAFE_RANGE,
  36. LOWER,
  37. RAISE,
  38. ADJUST,
  39. BACKLIT,
  40. RGBRST
  41. };
  42. enum macro_keycodes {
  43. KC_SAMPLEMACRO,
  44. };
  45. #define KC______ KC_TRNS
  46. #define KC_XXXXX KC_NO
  47. #define KC_LOWER LOWER
  48. #define KC_RAISE RAISE
  49. #define KC_RST RESET
  50. #define KC_LRST RGBRST
  51. #define KC_LTOG RGB_TOG
  52. #define KC_LHUI RGB_HUI
  53. #define KC_LHUD RGB_HUD
  54. #define KC_LSAI RGB_SAI
  55. #define KC_LSAD RGB_SAD
  56. #define KC_LVAI RGB_VAI
  57. #define KC_LVAD RGB_VAD
  58. #define KC_LSMOD RGB_SMOD
  59. #define KC_CTLTB CTL_T(KC_TAB)
  60. #define KC_GUIEI GUI_T(KC_LANG2)
  61. #define KC_ALTKN ALT_T(KC_LANG1)
  62. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  63. [_QWERTY] = LAYOUT_kc( \
  64. //,-----------------------------------------. ,-----------------------------------------.
  65. ESC, Q, W, E, R, T, Y, U, I, O, P, BSPC,\
  66. //|------+------+------+------+------+------| |------+------+------+------+------+------|
  67. CTLTB, A, S, D, F, G, H, J, K, L, SCLN, QUOT,\
  68. //|------+------+------+------+------+------| |------+------+------+------+------+------|
  69. LSFT, Z, X, C, V, B, N, M, COMM, DOT, SLSH, RSFT,\
  70. //|------+------+------+------+------+------+------| |------+------+------+------+------+------+------|
  71. GUIEI, LOWER, SPC, ENT, RAISE, ALTKN \
  72. //`--------------------' `--------------------'
  73. ),
  74. [_LOWER] = LAYOUT_kc( \
  75. //,-----------------------------------------. ,-----------------------------------------.
  76. ESC, 1, 2, 3, 4, 5, 6, 7, 8, 9, 0, BSPC,\
  77. //|------+------+------+------+------+------| |------+------+------+------+------+------|
  78. CTLTB, F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, XXXXX,\
  79. //|------+------+------+------+------+------| |------+------+------+------+------+------|
  80. LSFT, F11, F12, F13, F14, F15, F16, F17, F18, F19, F20, XXXXX,\
  81. //|------+------+------+------+------+------+------| |------+------+------+------+------+------+------|
  82. GUIEI, LOWER, SPC, ENT, RAISE, ALTKN \
  83. //`--------------------' `--------------------'
  84. ),
  85. [_RAISE] = LAYOUT_kc( \
  86. //,-----------------------------------------. ,-----------------------------------------.
  87. ESC, EXLM, AT, HASH, DLR, PERC, CIRC, AMPR, ASTR, LPRN, RPRN, BSPC,\
  88. //|------+------+------+------+------+------| |------+------+------+------+------+------|
  89. CTLTB, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, MINS, EQL, LCBR, RCBR, PIPE, GRV,\
  90. //|------+------+------+------+------+------| |------+------+------+------+------+------|
  91. LSFT, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, UNDS, PLUS, LBRC, RBRC, BSLS, TILD,\
  92. //|------+------+------+------+------+------+------| |------+------+------+------+------+------+------|
  93. GUIEI, LOWER, SPC, ENT, RAISE, ALTKN \
  94. //`--------------------' `--------------------'
  95. ),
  96. [_ADJUST] = LAYOUT_kc( \
  97. //,-----------------------------------------. ,-----------------------------------------.
  98. RST, LRST, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX,\
  99. //|------+------+------+------+------+------| |------+------+------+------+------+------|
  100. LTOG, LHUI, LSAI, LVAI, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX,\
  101. //|------+------+------+------+------+------| |------+------+------+------+------+------|
  102. LSMOD, LHUD, LSAD, LVAD, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX, XXXXX,\
  103. //|------+------+------+------+------+------+------| |------+------+------+------+------+------+------|
  104. GUIEI, LOWER, SPC, ENT, RAISE, ALTKN \
  105. //`--------------------' `--------------------'
  106. )
  107. };
  108. int RGB_current_mode;
  109. void persistent_default_layer_set(uint16_t default_layer) {
  110. eeconfig_update_default_layer(default_layer);
  111. default_layer_set(default_layer);
  112. }
  113. // Setting ADJUST layer RGB back to default
  114. void update_tri_layer_RGB(uint8_t layer1, uint8_t layer2, uint8_t layer3) {
  115. if (IS_LAYER_ON(layer1) && IS_LAYER_ON(layer2)) {
  116. layer_on(layer3);
  117. } else {
  118. layer_off(layer3);
  119. }
  120. }
  121. void matrix_init_user(void) {
  122. #ifdef RGBLIGHT_ENABLE
  123. RGB_current_mode = rgblight_config.mode;
  124. #endif
  125. //SSD1306 OLED init, make sure to add #define SSD1306OLED in config.h
  126. #ifdef SSD1306OLED
  127. TWI_Init(TWI_BIT_PRESCALE_1, TWI_BITLENGTH_FROM_FREQ(1, 800000));
  128. iota_gfx_init(!has_usb()); // turns on the display
  129. #endif
  130. }
  131. //SSD1306 OLED update loop, make sure to add #define SSD1306OLED in config.h
  132. #ifdef SSD1306OLED
  133. void matrix_scan_user(void) {
  134. iota_gfx_task();
  135. }
  136. void matrix_render_user(struct CharacterMatrix *matrix) {
  137. if (is_master) {
  138. matrix_write_ln(matrix, read_layer_state());
  139. matrix_write_ln(matrix, read_keylog());
  140. matrix_write_ln(matrix, read_keylogs());
  141. //matrix_write_ln(matrix, read_mode_icon(keymap_config.swap_lalt_lgui));
  142. //matrix_write_ln(matrix, read_host_led_state());
  143. //matrix_write_ln(matrix, read_timelog());
  144. } else {
  145. matrix_write(matrix, read_logo());
  146. }
  147. }
  148. void matrix_update(struct CharacterMatrix *dest, const struct CharacterMatrix *source) {
  149. if (memcmp(dest->display, source->display, sizeof(dest->display))) {
  150. memcpy(dest->display, source->display, sizeof(dest->display));
  151. dest->dirty = true;
  152. }
  153. }
  154. void iota_gfx_task_user(void) {
  155. struct CharacterMatrix matrix;
  156. matrix_clear(&matrix);
  157. matrix_render_user(&matrix);
  158. matrix_update(&display, &matrix);
  159. }
  160. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  161. if (record->event.pressed) {
  162. set_keylog(keycode, record);
  163. set_timelog();
  164. }
  165. switch (keycode) {
  166. case QWERTY:
  167. if (record->event.pressed) {
  168. persistent_default_layer_set(1UL<<_QWERTY);
  169. }
  170. return false;
  171. break;
  172. case LOWER:
  173. if (record->event.pressed) {
  174. layer_on(_LOWER);
  175. update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
  176. } else {
  177. layer_off(_LOWER);
  178. update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
  179. }
  180. return false;
  181. break;
  182. case RAISE:
  183. if (record->event.pressed) {
  184. layer_on(_RAISE);
  185. update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
  186. } else {
  187. layer_off(_RAISE);
  188. update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
  189. }
  190. return false;
  191. break;
  192. case ADJUST:
  193. if (record->event.pressed) {
  194. layer_on(_ADJUST);
  195. } else {
  196. layer_off(_ADJUST);
  197. }
  198. return false;
  199. break;
  200. case RGB_MOD:
  201. #ifdef RGBLIGHT_ENABLE
  202. if (record->event.pressed) {
  203. rgblight_mode(RGB_current_mode);
  204. rgblight_step();
  205. RGB_current_mode = rgblight_config.mode;
  206. }
  207. #endif
  208. return false;
  209. break;
  210. case RGBRST:
  211. #ifdef RGBLIGHT_ENABLE
  212. if (record->event.pressed) {
  213. eeconfig_update_rgblight_default();
  214. rgblight_enable();
  215. RGB_current_mode = rgblight_config.mode;
  216. }
  217. #endif
  218. break;
  219. }
  220. return true;
  221. }
  222. #endif