keymap.c 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413
  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. #ifdef OLED_DRIVER_ENABLE
  11. #include "oled_driver.h"
  12. #endif
  13. extern keymap_config_t keymap_config;
  14. extern uint8_t is_master;
  15. #ifdef RGBLIGHT_ENABLE
  16. //Following line allows macro to read current RGB settings
  17. extern rgblight_config_t rgblight_config;
  18. #endif
  19. enum crkbd_keycodes {
  20. RGBRST = NEW_SAFE_RANGE
  21. };
  22. #define LAYOUT_crkbd_base( \
  23. K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, \
  24. K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, \
  25. K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A \
  26. ) \
  27. LAYOUT_wrapper( \
  28. KC_ESC, K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, KC_MINS, \
  29. KC_TAB, ALT_T(K11), K12, K13, K14, K15, K16, K17, K18, K19, K1A, RGUI_T(KC_QUOT), \
  30. OS_LSFT, CTL_T(K21), K22, K23, K24, K25, K26, K27, K28, K29, CTL_T(K2A), OS_RSFT, \
  31. LT(_LOWER,KC_GRV), KC_SPC, KC_BSPC, KC_DEL, KC_ENT, RAISE \
  32. )
  33. #define LAYOUT_crkbd_base_wrapper(...) LAYOUT_crkbd_base(__VA_ARGS__)
  34. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  35. [_QWERTY] = LAYOUT_crkbd_base_wrapper(
  36. _________________QWERTY_L1_________________, _________________QWERTY_R1_________________,
  37. _________________QWERTY_L2_________________, _________________QWERTY_R2_________________,
  38. _________________QWERTY_L3_________________, _________________QWERTY_R3_________________
  39. ),
  40. [_COLEMAK] = LAYOUT_crkbd_base_wrapper(
  41. _________________COLEMAK_L1________________, _________________COLEMAK_R1________________,
  42. _________________COLEMAK_L2________________, _________________COLEMAK_R2________________,
  43. _________________COLEMAK_L3________________, _________________COLEMAK_R3________________
  44. ),
  45. [_DVORAK] = LAYOUT_crkbd_base_wrapper(
  46. _________________DVORAK_L1_________________, _________________DVORAK_R1_________________,
  47. _________________DVORAK_L2_________________, _________________DVORAK_R2_________________,
  48. _________________DVORAK_L3_________________, _________________DVORAK_R3_________________
  49. ),
  50. [_WORKMAN] = LAYOUT_crkbd_base_wrapper(
  51. _________________WORKMAN_L1________________, _________________WORKMAN_R1________________,
  52. _________________WORKMAN_L2________________, _________________WORKMAN_R2________________,
  53. _________________WORKMAN_L3________________, _________________WORKMAN_R3________________
  54. ),
  55. [_NORMAN] = LAYOUT_crkbd_base_wrapper(
  56. _________________NORMAN_L1_________________, _________________NORMAN_L1_________________,
  57. _________________NORMAN_L2_________________, _________________NORMAN_R2_________________,
  58. _________________NORMAN_L3_________________, _________________NORMAN_R3_________________
  59. ),
  60. [_MALTRON] = LAYOUT_crkbd_base_wrapper(
  61. _________________MALTRON_L1________________, _________________MALTRON_R1________________,
  62. _________________MALTRON_L2________________, _________________MALTRON_R2________________,
  63. _________________MALTRON_L3________________, _________________MALTRON_R3________________
  64. ),
  65. [_EUCALYN] = LAYOUT_crkbd_base_wrapper(
  66. _________________EUCALYN_L1________________, _________________EUCALYN_R1________________,
  67. _________________EUCALYN_L2________________, _________________EUCALYN_R2________________,
  68. _________________EUCALYN_L3________________, _________________EUCALYN_R3________________
  69. ),
  70. [_CARPLAX] = LAYOUT_crkbd_base_wrapper(
  71. _____________CARPLAX_QFMLWY_L1_____________, _____________CARPLAX_QFMLWY_R1_____________,
  72. _____________CARPLAX_QFMLWY_L2_____________, _____________CARPLAX_QFMLWY_R2_____________,
  73. _____________CARPLAX_QFMLWY_L3_____________, _____________CARPLAX_QFMLWY_R3_____________
  74. ),
  75. [_MODS] = LAYOUT_wrapper(
  76. _______, ___________________BLANK___________________, ___________________BLANK___________________, _______,
  77. _______, ___________________BLANK___________________, ___________________BLANK___________________, _______,
  78. KC_LSFT, ___________________BLANK___________________, ___________________BLANK___________________, KC_RSFT,
  79. _______, _______, _______, _______, _______, _______
  80. ),
  81. [_LOWER] = LAYOUT_wrapper(
  82. KC_F11, _________________LOWER_L1__________________, _________________LOWER_R1__________________, KC_F11,
  83. KC_F12, _________________LOWER_L2__________________, _________________LOWER_R2__________________, KC_PIPE,
  84. _______, _________________LOWER_L3__________________, _________________LOWER_R3__________________, _______,
  85. _______, _______, _______, _______, _______, _______
  86. ),
  87. [_RAISE] = LAYOUT_wrapper( \
  88. _______, _________________RAISE_L1__________________, _________________RAISE_R1__________________, _______,
  89. _______, _________________RAISE_L2__________________, _________________RAISE_R2__________________, KC_BSLS,
  90. _______, _________________RAISE_L3__________________, _________________RAISE_R3__________________, _______,
  91. _______, _______, _______, _______, _______, _______
  92. ),
  93. [_ADJUST] = LAYOUT_wrapper( \
  94. KC_MAKE, _________________ADJUST_L1_________________, _________________ADJUST_R1_________________, KC_RESET,
  95. VRSN, _________________ADJUST_L2_________________, _________________ADJUST_R2_________________, EEP_RST,
  96. _______, _________________ADJUST_L3_________________, _________________ADJUST_R3_________________, KC_MPLY,
  97. _______, _______, _______, KC_NUKE, TG_MODS, _______
  98. )
  99. };
  100. void matrix_init_keymap(void) {
  101. //SSD1306 OLED init, make sure to add #define SSD1306OLED in config.h
  102. #ifdef SSD1306OLED
  103. iota_gfx_init(!has_usb()); // turns on the display
  104. #endif
  105. #ifndef CONVERT_TO_PROTON_C
  106. setPinOutput(D5);
  107. writePinHigh(D5);
  108. setPinOutput(B0);
  109. writePinHigh(B0);
  110. #endif
  111. }
  112. //SSD1306 OLED update loop, make sure to add #define SSD1306OLED in config.h
  113. #ifdef SSD1306OLED
  114. // When add source files to SRC in rules.mk, you can use functions.
  115. const char *read_logo(void);
  116. char layer_state_str[24];
  117. char modifier_state_str[24];
  118. char host_led_state_str[24];
  119. char keylog_str[24] = {};
  120. char keylogs_str[21] = {};
  121. int keylogs_str_idx = 0;
  122. // const char *read_mode_icon(bool swap);
  123. // void set_timelog(void);
  124. // const char *read_timelog(void);
  125. const char code_to_name[60] = {
  126. ' ', ' ', ' ', ' ', 'a', 'b', 'c', 'd', 'e', 'f',
  127. 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',
  128. 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
  129. '1', '2', '3', '4', '5', '6', '7', '8', '9', '0',
  130. 'R', 'E', 'B', 'T', '_', '-', '=', '[', ']', '\\',
  131. '#', ';', '\'', '`', ',', '.', '/', ' ', ' ', ' '};
  132. void set_keylog(uint16_t keycode, keyrecord_t *record) {
  133. char name = ' ';
  134. if ((keycode >= QK_MOD_TAP && keycode <= QK_MOD_TAP_MAX) || (keycode >= QK_LAYER_TAP && keycode <= QK_LAYER_TAP_MAX)) { keycode = keycode & 0xFF; }
  135. if (keycode < 60) {
  136. name = code_to_name[keycode];
  137. }
  138. // update keylog
  139. snprintf(keylog_str, sizeof(keylog_str), "%dx%d, k%2d : %c",
  140. record->event.key.row, record->event.key.col,
  141. keycode, name);
  142. // update keylogs
  143. if (keylogs_str_idx == sizeof(keylogs_str) - 1) {
  144. keylogs_str_idx = 0;
  145. for (int i = 0; i < sizeof(keylogs_str) - 1; i++) {
  146. keylogs_str[i] = ' ';
  147. }
  148. }
  149. keylogs_str[keylogs_str_idx] = name;
  150. keylogs_str_idx++;
  151. }
  152. const char *read_keylog(void) {
  153. return keylog_str;
  154. }
  155. const char *read_keylogs(void) {
  156. return keylogs_str;
  157. }
  158. const char* read_modifier_state(void) {
  159. uint8_t modifiers = get_mods();
  160. uint8_t one_shot = get_oneshot_mods();
  161. snprintf(modifier_state_str, sizeof(modifier_state_str), "Mods:%s %s %s %s",
  162. (modifiers & MOD_MASK_CTRL || one_shot & MOD_MASK_CTRL) ? "CTL" : " ",
  163. (modifiers & MOD_MASK_GUI || one_shot & MOD_MASK_GUI) ? "GUI" : " ",
  164. (modifiers & MOD_MASK_ALT || one_shot & MOD_MASK_ALT) ? "ALT" : " ",
  165. (modifiers & MOD_MASK_SHIFT || one_shot & MOD_MASK_SHIFT) ? "SFT" : " "
  166. );
  167. return modifier_state_str;
  168. }
  169. const char *read_host_led_state(void) {
  170. uint8_t leds = host_keyboard_leds();
  171. snprintf(host_led_state_str, sizeof(host_led_state_str), "NL:%s CL:%s SL:%s",
  172. (leds & (1 << USB_LED_NUM_LOCK)) ? "on" : "- ",
  173. (leds & (1 << USB_LED_CAPS_LOCK)) ? "on" : "- ",
  174. (leds & (1 << USB_LED_SCROLL_LOCK)) ? "on" : "- "
  175. );
  176. return host_led_state_str;
  177. }
  178. const char* read_layer_state(void) {
  179. switch (biton32(layer_state)) {
  180. case _RAISE:
  181. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise ");
  182. break;
  183. case _LOWER:
  184. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower ");
  185. break;
  186. case _ADJUST:
  187. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust ");
  188. break;
  189. default:
  190. switch (biton32(default_layer_state)) {
  191. case _QWERTY:
  192. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Qwerty ");
  193. break;
  194. case _COLEMAK:
  195. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Colemak");
  196. break;
  197. case _DVORAK:
  198. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Dvorak ");
  199. break;
  200. case _WORKMAN:
  201. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Workman");
  202. break;
  203. }
  204. break;
  205. }
  206. return layer_state_str;
  207. }
  208. void matrix_scan_keymap(void) {
  209. iota_gfx_task();
  210. }
  211. void matrix_render_user(struct CharacterMatrix *matrix) {
  212. if (is_master) {
  213. //If you want to change the display of OLED, you need to change here
  214. matrix_write_ln(matrix, read_layer_state());
  215. matrix_write_ln(matrix, read_modifier_state());
  216. // matrix_write_ln(matrix, read_keylog());
  217. matrix_write_ln(matrix, read_keylogs());
  218. // matrix_write_ln(matrix, read_mode_icon(keymap_config.swap_lalt_lgui));
  219. // matrix_write(matrix, read_host_led_state());
  220. //matrix_write_ln(matrix, read_timelog());
  221. } else {
  222. matrix_write(matrix, read_logo());
  223. }
  224. }
  225. void matrix_update(struct CharacterMatrix *dest, const struct CharacterMatrix *source) {
  226. if (memcmp(dest->display, source->display, sizeof(dest->display))) {
  227. memcpy(dest->display, source->display, sizeof(dest->display));
  228. dest->dirty = true;
  229. }
  230. }
  231. void iota_gfx_task_user(void) {
  232. struct CharacterMatrix matrix;
  233. matrix_clear(&matrix);
  234. matrix_render_user(&matrix);
  235. matrix_update(&display, &matrix);
  236. }
  237. bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
  238. switch (keycode) {
  239. case KC_A ... KC_SLASH:
  240. case KC_F1 ... KC_F12:
  241. case KC_INSERT ... KC_UP:
  242. case KC_KP_SLASH ... KC_KP_DOT:
  243. case KC_F13 ... KC_F24:
  244. if (record->event.pressed) { set_keylog(keycode, record); }
  245. break;
  246. // set_timelog();
  247. }
  248. return true;
  249. }
  250. #endif
  251. #ifdef OLED_DRIVER_ENABLE
  252. oled_rotation_t oled_init_user(oled_rotation_t rotation) {
  253. if (is_master) {
  254. return OLED_ROTATION_270;
  255. } else {
  256. return rotation;
  257. }
  258. }
  259. void render_crkbd_logo(void) {
  260. static const char PROGMEM crkbd_logo[] = {
  261. 0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x8d, 0x8e, 0x8f, 0x90, 0x91, 0x92, 0x93, 0x94,
  262. 0xa0, 0xa1, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7, 0xa8, 0xa9, 0xaa, 0xab, 0xac, 0xad, 0xae, 0xaf, 0xb0, 0xb1, 0xb2, 0xb3, 0xb4,
  263. 0xc0, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf, 0xd0, 0xd1, 0xd2, 0xd3, 0xd4,
  264. 0};
  265. oled_write_P(crkbd_logo, false);
  266. }
  267. void render_status(void) {
  268. oled_write_P(PSTR("Layer"), false);
  269. switch (biton32(layer_state)) {
  270. case 0:
  271. oled_write_P(PSTR("Base "), false);
  272. break;
  273. case _RAISE:
  274. oled_write_P(PSTR("Raise"), false);
  275. break;
  276. case _LOWER:
  277. oled_write_P(PSTR("Lower"), false);
  278. break;
  279. case _ADJUST:
  280. oled_write_P(PSTR("Adjst"), false);
  281. break;
  282. default:
  283. oled_write_P(PSTR("Unkn "), false);
  284. break;
  285. }
  286. oled_write_P(PSTR("Lyout"), false);
  287. switch (biton32(default_layer_state)) {
  288. case _QWERTY:
  289. oled_write_P(PSTR("QWRTY"), false);
  290. break;
  291. case _COLEMAK:
  292. oled_write_P(PSTR("COLMK"), false);
  293. break;
  294. case _DVORAK:
  295. oled_write_P(PSTR("DVRAK"), false);
  296. break;
  297. case _WORKMAN:
  298. oled_write_P(PSTR("WRKMN"), false);
  299. break;
  300. case _NORMAN:
  301. oled_write_P(PSTR("NORMN"), false);
  302. break;
  303. case _MALTRON:
  304. oled_write_P(PSTR("MLTRN"), false);
  305. break;
  306. case _EUCALYN:
  307. oled_write_P(PSTR("ECLYN"), false);
  308. break;
  309. case _CARPLAX:
  310. oled_write_P(PSTR("CRPLX"), false);
  311. break;
  312. }
  313. uint8_t modifiers = get_mods();
  314. uint8_t one_shot = get_oneshot_mods();
  315. oled_write_P(PSTR("Mods:"), false);
  316. oled_write_P( (modifiers & MOD_MASK_CTRL || one_shot & MOD_MASK_CTRL ) ? PSTR(" CTL ") : PSTR(" "), false);
  317. oled_write_P( (modifiers & MOD_MASK_GUI || one_shot & MOD_MASK_GUI ) ? PSTR(" GUI ") : PSTR(" "), false);
  318. oled_write_P( (modifiers & MOD_MASK_ALT || one_shot & MOD_MASK_ALT ) ? PSTR(" ALT ") : PSTR(" "), false);
  319. oled_write_P( (modifiers & MOD_MASK_SHIFT || one_shot & MOD_MASK_SHIFT) ? PSTR(" SFT ") : PSTR(" "), false);
  320. oled_write_P(PSTR("BTMGK"), false);
  321. static const char PROGMEM mode_logo[4][4] = {
  322. {0x95,0x96,0x0a,0},
  323. {0xb5,0xb6,0x0a,0},
  324. {0x97,0x98,0x0a,0},
  325. {0xb7,0xb8,0x0a,0} };
  326. if (keymap_config.swap_lalt_lgui != false) {
  327. oled_write_P(mode_logo[0], false);
  328. oled_write_P(mode_logo[1], false);
  329. } else {
  330. oled_write_P(mode_logo[2], false);
  331. oled_write_P(mode_logo[3], false);
  332. }
  333. uint8_t led_usb_state = host_keyboard_leds();
  334. oled_write_P(PSTR("Lock:"), false);
  335. oled_write_P(led_usb_state & (1<<USB_LED_NUM_LOCK) ? PSTR(" NUM ") : PSTR(" "), false);
  336. oled_write_P(led_usb_state & (1<<USB_LED_CAPS_LOCK) ? PSTR(" CAPS") : PSTR(" "), false);
  337. oled_write_P(led_usb_state & (1<<USB_LED_SCROLL_LOCK) ? PSTR(" SCRL") : PSTR(" "), false);
  338. }
  339. void oled_task_user(void) {
  340. if (is_master) {
  341. render_status(); // Renders the current keyboard state (layer, lock, caps, scroll, etc)
  342. } else {
  343. render_crkbd_logo();
  344. oled_scroll_left(); // Turns on scrolling
  345. }
  346. }
  347. #endif
  348. uint16_t get_tapping_term(uint16_t keycode) {
  349. switch (keycode) {
  350. case ALT_T(KC_A):
  351. return TAPPING_TERM + 100;
  352. default:
  353. return TAPPING_TERM;
  354. }
  355. }