keymap.c 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. #include QMK_KEYBOARD_H
  2. #include "jarred.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. #define LAYOUT_crkbd_base( \
  17. K01, K02, K03, K04, K05, K06, K07, K08, K09, K0A, K0B, K0C, \
  18. K11, K12, K13, K14, K15, K16, K17, K18, K19, K1A, K1B, K1C, \
  19. K21, K22, K23, K24, K25, K26, K27, K28, K29, K2A, K2B, K2C, \
  20. K31, K32, K33, K34, K35, K36 \
  21. )
  22. #define LAYOUT_crkbd_wrapper(...) LAYOUT(__VA_ARGS__)
  23. #define QWERTY_4_CRKBD KC_LCTL, MO(_LW), KC_SPC, KC_ENT, MO(_LW), KC_RALT
  24. #define BLANK_4_CRKBD KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS
  25. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  26. [_QW] = LAYOUT_crkbd_wrapper(
  27. QWERTY_1_12,
  28. QWERTY_2_12,
  29. QWERTY_3_12,
  30. QWERTY_4_DOX
  31. ),
  32. [_LW] = LAYOUT_crkbd_wrapper(
  33. LOWER_1_12,
  34. LOWER_2_12,
  35. LOWER_3_12,
  36. LOWER_4_DOX
  37. ),
  38. [_NV] = LAYOUT_crkbd_wrapper(
  39. NAV_1_12,
  40. NAV_2_12,
  41. NAV_3_12,
  42. NAV_4_DOX
  43. ),
  44. [_NP] = LAYOUT_crkbd_wrapper(
  45. NUMPAD_1_12,
  46. NUMPAD_2_12,
  47. NUMPAD_3_12,
  48. NUMPAD_4_DOX
  49. ),
  50. [_MS] = LAYOUT_crkbd_wrapper(
  51. MOUSE_1_12,
  52. MOUSE_2_12,
  53. MOUSE_3_12,
  54. MOUSE_4_DOX
  55. )
  56. };
  57. void matrix_init_user(void) {
  58. //SSD1306 OLED init, make sure to add #define SSD1306OLED in config.h
  59. #ifdef SSD1306OLED
  60. iota_gfx_init(!has_usb()); // turns on the display
  61. #endif
  62. }
  63. //SSD1306 OLED update loop, make sure to add #define SSD1306OLED in config.h
  64. #ifdef SSD1306OLED
  65. // When add source files to SRC in rules.mk, you can use functions.
  66. const char *read_logo(void);
  67. void set_keylog(uint16_t keycode, keyrecord_t *record);
  68. const char *read_keylog(void);
  69. const char *read_keylogs(void);
  70. char matrix_line_str[24];
  71. const char *read_layer_state(void) {
  72. uint8_t layer = biton32(layer_state);
  73. strcpy(matrix_line_str, "Layer: ");
  74. switch (layer)
  75. {
  76. case _QW:
  77. strcat(matrix_line_str, "Default");
  78. break;
  79. case _LW:
  80. strcat(matrix_line_str, "Lower");
  81. break;
  82. case _NV:
  83. strcat(matrix_line_str, "Navigation");
  84. break;
  85. case _NP:
  86. strcat(matrix_line_str, "Adjust");
  87. break;
  88. case _MS:
  89. strcat(matrix_line_str, "Mouse");
  90. break;
  91. default:
  92. sprintf(matrix_line_str + strlen(matrix_line_str), "Unknown (%d)", layer);
  93. }
  94. return matrix_line_str;
  95. }
  96. const char *read_usb_state(void) {
  97. strcpy(matrix_line_str, "USB : ");
  98. switch (USB_DeviceState) {
  99. case DEVICE_STATE_Unattached:
  100. strcat(matrix_line_str, "Unattached");
  101. break;
  102. case DEVICE_STATE_Suspended:
  103. strcat(matrix_line_str, "Suspended");
  104. break;
  105. case DEVICE_STATE_Configured:
  106. strcat(matrix_line_str, "Connected");
  107. break;
  108. case DEVICE_STATE_Powered:
  109. strcat(matrix_line_str, "Powered");
  110. break;
  111. case DEVICE_STATE_Default:
  112. strcat(matrix_line_str, "Default");
  113. break;
  114. case DEVICE_STATE_Addressed:
  115. strcat(matrix_line_str, "Addressed");
  116. break;
  117. default:
  118. strcat(matrix_line_str, "Invalid");
  119. }
  120. return matrix_line_str;
  121. }
  122. void matrix_scan_user(void) {
  123. iota_gfx_task();
  124. }
  125. void matrix_render_user(struct CharacterMatrix *matrix) {
  126. if (is_master) {
  127. matrix_write_ln(matrix, read_layer_state());
  128. matrix_write_ln(matrix, read_usb_state());
  129. matrix_write_ln(matrix, read_keylogs());
  130. } else {
  131. matrix_write(matrix, read_logo());
  132. }
  133. }
  134. void matrix_update(struct CharacterMatrix *dest, const struct CharacterMatrix *source) {
  135. if (memcmp(dest->display, source->display, sizeof(dest->display))) {
  136. memcpy(dest->display, source->display, sizeof(dest->display));
  137. dest->dirty = true;
  138. }
  139. }
  140. void iota_gfx_task_user(void) {
  141. struct CharacterMatrix matrix;
  142. matrix_clear(&matrix);
  143. matrix_render_user(&matrix);
  144. matrix_update(&display, &matrix);
  145. }
  146. #endif//SSD1306OLED
  147. bool process_record_keymap(uint16_t keycode, keyrecord_t *record) {
  148. if (record->event.pressed) {
  149. set_keylog(keycode, record);
  150. }
  151. return true;
  152. }