keymap.c 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. #include QMK_KEYBOARD_H
  2. #include "drashna.h"
  3. #ifdef PROTOCOL_LUFA
  4. #include "lufa.h"
  5. #include "split_util.h"
  6. #endif
  7. #ifdef SSD1306OLED
  8. #include "ssd1306.h"
  9. #endif
  10. extern keymap_config_t keymap_config;
  11. extern uint8_t is_master;
  12. #ifdef RGBLIGHT_ENABLE
  13. //Following line allows macro to read current RGB settings
  14. extern rgblight_config_t rgblight_config;
  15. #endif
  16. enum crkbd_keycodes {
  17. RGBRST = NEW_SAFE_RANGE
  18. };
  19. #define LAYOUT_crkbd_base( \
  20. K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, \
  21. K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, \
  22. K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A \
  23. ) \
  24. LAYOUT_wrapper( \
  25. KC_ESC, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, KC_MINS, \
  26. KC_TAB, ALT_T(K11), K12, K13, K14, K15, K16, K17, K18, K19, K1A, RGUI_T(KC_QUOT), \
  27. OS_LSFT, CTL_T(K21), K22, K23, K24, K25, K26, K27, K28, K29, CTL_T(K2A), OS_RSFT, \
  28. LT(_LOWER,KC_GRV), KC_SPC, KC_BSPC, KC_DEL, KC_ENT, RAISE \
  29. )
  30. #define LAYOUT_crkbd_base_wrapper(...) LAYOUT_crkbd_base(__VA_ARGS__)
  31. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  32. [_QWERTY] = LAYOUT_crkbd_base_wrapper(
  33. _________________QWERTY_L1_________________, _________________QWERTY_R1_________________,
  34. _________________QWERTY_L2_________________, _________________QWERTY_R2_________________,
  35. _________________QWERTY_L3_________________, _________________QWERTY_R3_________________
  36. ),
  37. [_COLEMAK] = LAYOUT_crkbd_base_wrapper(
  38. _________________COLEMAK_L1________________, _________________COLEMAK_R1________________,
  39. _________________COLEMAK_L2________________, _________________COLEMAK_R2________________,
  40. _________________COLEMAK_L3________________, _________________COLEMAK_R3________________
  41. ),
  42. [_DVORAK] = LAYOUT_crkbd_base_wrapper(
  43. _________________DVORAK_L1_________________, _________________DVORAK_R1_________________,
  44. _________________DVORAK_L2_________________, _________________DVORAK_R2_________________,
  45. _________________DVORAK_L3_________________, _________________DVORAK_R3_________________
  46. ),
  47. [_WORKMAN] = LAYOUT_crkbd_base_wrapper(
  48. _________________WORKMAN_L1________________, _________________WORKMAN_R1________________,
  49. _________________WORKMAN_L2________________, _________________WORKMAN_R2________________,
  50. _________________WORKMAN_L3________________, _________________WORKMAN_R3________________
  51. ),
  52. [_MODS] = LAYOUT_wrapper(
  53. _______, ___________________BLANK___________________, ___________________BLANK___________________, _______,
  54. _______, ___________________BLANK___________________, ___________________BLANK___________________, _______,
  55. KC_LSFT, ___________________BLANK___________________, ___________________BLANK___________________, KC_RSFT,
  56. _______, _______, _______, _______, _______, _______
  57. ),
  58. [_LOWER] = LAYOUT_wrapper(
  59. KC_F11, _________________LOWER_L1__________________, _________________LOWER_R1__________________, KC_F11,
  60. KC_F12, _________________LOWER_L2__________________, _________________LOWER_R2__________________, KC_PIPE,
  61. _______, _________________LOWER_L3__________________, _________________LOWER_R3__________________, _______,
  62. _______, _______, _______, _______, _______, _______
  63. ),
  64. [_RAISE] = LAYOUT_wrapper( \
  65. _______, _________________RAISE_L1__________________, _________________RAISE_R1__________________, _______,
  66. _______, _________________RAISE_L2__________________, _________________RAISE_R2__________________, KC_BSLS,
  67. _______, _________________RAISE_L3__________________, _________________RAISE_R3__________________, _______,
  68. _______, _______, _______, _______, _______, _______
  69. ),
  70. [_ADJUST] = LAYOUT_wrapper( \
  71. KC_MAKE, _________________ADJUST_L1_________________, _________________ADJUST_R1_________________, KC_RESET,
  72. VRSN, _________________ADJUST_L2_________________, _________________ADJUST_R2_________________, EEP_RST,
  73. _______, _________________ADJUST_L3_________________, _________________ADJUST_R3_________________, KC_MPLY,
  74. _______, _______, _______, KC_NUKE, TG_MODS, _______
  75. )
  76. };
  77. void matrix_init_keymap(void) {
  78. //SSD1306 OLED init, make sure to add #define SSD1306OLED in config.h
  79. #ifdef SSD1306OLED
  80. iota_gfx_init(!has_usb()); // turns on the display
  81. #endif
  82. DDRD &= ~(1<<5);
  83. PORTD &= ~(1<<5);
  84. DDRB &= ~(1<<0);
  85. PORTB &= ~(1<<0);
  86. }
  87. //SSD1306 OLED update loop, make sure to add #define SSD1306OLED in config.h
  88. #ifdef SSD1306OLED
  89. // When add source files to SRC in rules.mk, you can use functions.
  90. const char *read_logo(void);
  91. char layer_state_str[24];
  92. char modifier_state_str[24];
  93. char host_led_state_str[24];
  94. char keylog_str[24] = {};
  95. char keylogs_str[21] = {};
  96. int keylogs_str_idx = 0;
  97. // const char *read_mode_icon(bool swap);
  98. // void set_timelog(void);
  99. // const char *read_timelog(void);
  100. const char code_to_name[60] = {
  101. ' ', ' ', ' ', ' ', 'a', 'b', 'c', 'd', 'e', 'f',
  102. 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',
  103. 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
  104. '1', '2', '3', '4', '5', '6', '7', '8', '9', '0',
  105. 'R', 'E', 'B', 'T', '_', '-', '=', '[', ']', '\\',
  106. '#', ';', '\'', '`', ',', '.', '/', ' ', ' ', ' '};
  107. void set_keylog(uint16_t keycode, keyrecord_t *record) {
  108. char name = ' ';
  109. if (keycode < 60) {
  110. name = code_to_name[keycode];
  111. }
  112. // update keylog
  113. snprintf(keylog_str, sizeof(keylog_str), "%dx%d, k%2d : %c",
  114. record->event.key.row, record->event.key.col,
  115. keycode, name);
  116. // update keylogs
  117. if (keylogs_str_idx == sizeof(keylogs_str) - 1) {
  118. keylogs_str_idx = 0;
  119. for (int i = 0; i < sizeof(keylogs_str) - 1; i++) {
  120. keylogs_str[i] = ' ';
  121. }
  122. }
  123. keylogs_str[keylogs_str_idx] = name;
  124. keylogs_str_idx++;
  125. }
  126. const char *read_keylog(void) {
  127. return keylog_str;
  128. }
  129. const char *read_keylogs(void) {
  130. return keylogs_str;
  131. }
  132. const char* read_modifier_state(void) {
  133. uint8_t modifiers = get_mods();
  134. uint8_t one_shot = get_oneshot_mods();
  135. snprintf(modifier_state_str, sizeof(modifier_state_str), "Mods:%s %s %s %s",
  136. (modifiers & MODS_CTRL_MASK || one_shot & MODS_CTRL_MASK) ? "CTL" : " ",
  137. (modifiers & MODS_GUI_MASK || one_shot & MODS_GUI_MASK) ? "GUI" : " ",
  138. (modifiers & MODS_ALT_MASK || one_shot & MODS_ALT_MASK) ? "ALT" : " ",
  139. (modifiers & MODS_SHIFT_MASK || one_shot & MODS_SHIFT_MASK) ? "SFT" : " "
  140. );
  141. return modifier_state_str;
  142. }
  143. const char *read_host_led_state(void) {
  144. uint8_t leds = host_keyboard_leds();
  145. snprintf(host_led_state_str, sizeof(host_led_state_str), "NL:%s CL:%s SL:%s",
  146. (leds & (1 << USB_LED_NUM_LOCK)) ? "on" : "- ",
  147. (leds & (1 << USB_LED_CAPS_LOCK)) ? "on" : "- ",
  148. (leds & (1 << USB_LED_SCROLL_LOCK)) ? "on" : "- "
  149. );
  150. return host_led_state_str;
  151. }
  152. const char* read_layer_state(void) {
  153. switch (biton32(layer_state)) {
  154. case _RAISE:
  155. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise ");
  156. break;
  157. case _LOWER:
  158. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower ");
  159. break;
  160. case _ADJUST:
  161. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust ");
  162. break;
  163. default:
  164. switch (biton32(default_layer_state)) {
  165. case _QWERTY:
  166. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Qwerty ");
  167. break;
  168. case _COLEMAK:
  169. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Colemak");
  170. break;
  171. case _DVORAK:
  172. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Dvorak ");
  173. break;
  174. case _WORKMAN:
  175. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Workman");
  176. break;
  177. }
  178. break;
  179. }
  180. return layer_state_str;
  181. }
  182. void matrix_scan_keymap(void) {
  183. iota_gfx_task();
  184. }
  185. void matrix_render_user(struct CharacterMatrix *matrix) {
  186. if (is_master) {
  187. //If you want to change the display of OLED, you need to change here
  188. matrix_write_ln(matrix, read_layer_state());
  189. matrix_write_ln(matrix, read_modifier_state());
  190. // matrix_write_ln(matrix, read_keylog());
  191. matrix_write_ln(matrix, read_keylogs());
  192. // matrix_write_ln(matrix, read_mode_icon(keymap_config.swap_lalt_lgui));
  193. matrix_write(matrix, read_host_led_state());
  194. //matrix_write_ln(matrix, read_timelog());
  195. } else {
  196. matrix_write(matrix, read_logo());
  197. }
  198. }
  199. void matrix_update(struct CharacterMatrix *dest, const struct CharacterMatrix *source) {
  200. if (memcmp(dest->display, source->display, sizeof(dest->display))) {
  201. memcpy(dest->display, source->display, sizeof(dest->display));
  202. dest->dirty = true;
  203. }
  204. }
  205. void iota_gfx_task_user(void) {
  206. struct CharacterMatrix matrix;
  207. matrix_clear(&matrix);
  208. matrix_render_user(&matrix);
  209. matrix_update(&display, &matrix);
  210. }
  211. bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
  212. switch (keycode) {
  213. case KC_A ... KC_SLASH:
  214. case KC_F1 ... KC_F12:
  215. case KC_INSERT ... KC_UP:
  216. case KC_KP_SLASH ... KC_KP_DOT:
  217. case KC_F13 ... KC_F24:
  218. if (record->event.pressed) { set_keylog(keycode, record); }
  219. break;
  220. // set_timelog();
  221. }
  222. return true;
  223. }
  224. #endif