2
0

keymap.c 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266
  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. #ifndef CONVERT_TO_PROTON_C
  83. setPinOutput(D5);
  84. writePinHigh(D5);
  85. setPinOutput(B0);
  86. writePinHigh(B0);
  87. #endif
  88. }
  89. //SSD1306 OLED update loop, make sure to add #define SSD1306OLED in config.h
  90. #ifdef SSD1306OLED
  91. // When add source files to SRC in rules.mk, you can use functions.
  92. const char *read_logo(void);
  93. char layer_state_str[24];
  94. char modifier_state_str[24];
  95. char host_led_state_str[24];
  96. char keylog_str[24] = {};
  97. char keylogs_str[21] = {};
  98. int keylogs_str_idx = 0;
  99. // const char *read_mode_icon(bool swap);
  100. // void set_timelog(void);
  101. // const char *read_timelog(void);
  102. const char code_to_name[60] = {
  103. ' ', ' ', ' ', ' ', 'a', 'b', 'c', 'd', 'e', 'f',
  104. 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',
  105. 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
  106. '1', '2', '3', '4', '5', '6', '7', '8', '9', '0',
  107. 'R', 'E', 'B', 'T', '_', '-', '=', '[', ']', '\\',
  108. '#', ';', '\'', '`', ',', '.', '/', ' ', ' ', ' '};
  109. void set_keylog(uint16_t keycode, keyrecord_t *record) {
  110. char name = ' ';
  111. if ((keycode >= QK_MOD_TAP && keycode <= QK_MOD_TAP_MAX) || (keycode >= QK_LAYER_TAP && keycode <= QK_LAYER_TAP_MAX)) { keycode = keycode & 0xFF; }
  112. if (keycode < 60) {
  113. name = code_to_name[keycode];
  114. }
  115. // update keylog
  116. snprintf(keylog_str, sizeof(keylog_str), "%dx%d, k%2d : %c",
  117. record->event.key.row, record->event.key.col,
  118. keycode, name);
  119. // update keylogs
  120. if (keylogs_str_idx == sizeof(keylogs_str) - 1) {
  121. keylogs_str_idx = 0;
  122. for (int i = 0; i < sizeof(keylogs_str) - 1; i++) {
  123. keylogs_str[i] = ' ';
  124. }
  125. }
  126. keylogs_str[keylogs_str_idx] = name;
  127. keylogs_str_idx++;
  128. }
  129. const char *read_keylog(void) {
  130. return keylog_str;
  131. }
  132. const char *read_keylogs(void) {
  133. return keylogs_str;
  134. }
  135. const char* read_modifier_state(void) {
  136. uint8_t modifiers = get_mods();
  137. uint8_t one_shot = get_oneshot_mods();
  138. snprintf(modifier_state_str, sizeof(modifier_state_str), "Mods:%s %s %s %s",
  139. (modifiers & MODS_CTRL_MASK || one_shot & MODS_CTRL_MASK) ? "CTL" : " ",
  140. (modifiers & MODS_GUI_MASK || one_shot & MODS_GUI_MASK) ? "GUI" : " ",
  141. (modifiers & MODS_ALT_MASK || one_shot & MODS_ALT_MASK) ? "ALT" : " ",
  142. (modifiers & MODS_SHIFT_MASK || one_shot & MODS_SHIFT_MASK) ? "SFT" : " "
  143. );
  144. return modifier_state_str;
  145. }
  146. const char *read_host_led_state(void) {
  147. uint8_t leds = host_keyboard_leds();
  148. snprintf(host_led_state_str, sizeof(host_led_state_str), "NL:%s CL:%s SL:%s",
  149. (leds & (1 << USB_LED_NUM_LOCK)) ? "on" : "- ",
  150. (leds & (1 << USB_LED_CAPS_LOCK)) ? "on" : "- ",
  151. (leds & (1 << USB_LED_SCROLL_LOCK)) ? "on" : "- "
  152. );
  153. return host_led_state_str;
  154. }
  155. const char* read_layer_state(void) {
  156. switch (biton32(layer_state)) {
  157. case _RAISE:
  158. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise ");
  159. break;
  160. case _LOWER:
  161. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower ");
  162. break;
  163. case _ADJUST:
  164. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust ");
  165. break;
  166. default:
  167. switch (biton32(default_layer_state)) {
  168. case _QWERTY:
  169. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Qwerty ");
  170. break;
  171. case _COLEMAK:
  172. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Colemak");
  173. break;
  174. case _DVORAK:
  175. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Dvorak ");
  176. break;
  177. case _WORKMAN:
  178. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Workman");
  179. break;
  180. }
  181. break;
  182. }
  183. return layer_state_str;
  184. }
  185. void matrix_scan_keymap(void) {
  186. iota_gfx_task();
  187. }
  188. void matrix_render_user(struct CharacterMatrix *matrix) {
  189. if (is_master) {
  190. //If you want to change the display of OLED, you need to change here
  191. matrix_write_ln(matrix, read_layer_state());
  192. matrix_write_ln(matrix, read_modifier_state());
  193. // matrix_write_ln(matrix, read_keylog());
  194. matrix_write_ln(matrix, read_keylogs());
  195. // matrix_write_ln(matrix, read_mode_icon(keymap_config.swap_lalt_lgui));
  196. matrix_write(matrix, read_host_led_state());
  197. //matrix_write_ln(matrix, read_timelog());
  198. } else {
  199. matrix_write(matrix, read_logo());
  200. }
  201. }
  202. void matrix_update(struct CharacterMatrix *dest, const struct CharacterMatrix *source) {
  203. if (memcmp(dest->display, source->display, sizeof(dest->display))) {
  204. memcpy(dest->display, source->display, sizeof(dest->display));
  205. dest->dirty = true;
  206. }
  207. }
  208. void iota_gfx_task_user(void) {
  209. struct CharacterMatrix matrix;
  210. matrix_clear(&matrix);
  211. matrix_render_user(&matrix);
  212. matrix_update(&display, &matrix);
  213. }
  214. bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
  215. switch (keycode) {
  216. case KC_A ... KC_SLASH:
  217. case KC_F1 ... KC_F12:
  218. case KC_INSERT ... KC_UP:
  219. case KC_KP_SLASH ... KC_KP_DOT:
  220. case KC_F13 ... KC_F24:
  221. if (record->event.pressed) { set_keylog(keycode, record); }
  222. break;
  223. // set_timelog();
  224. }
  225. return true;
  226. }
  227. #endif