keymap.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292
  1. #include QMK_KEYBOARD_H
  2. #include "uzu42.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. #ifdef RGBLIGHT_ENABLE
  12. #include <stdio.h>
  13. //Following line allows macro to read current RGB settings
  14. extern rgblight_config_t rgblight_config;
  15. #endif
  16. // Each layer gets a name for readability, which is then used in the keymap matrix below.
  17. // The underscores don't mean anything - you can have a layer called STUFF or any other name.
  18. // Layer names don't all need to be of the same length, obviously, and you can also skip them
  19. // entirely and just use numbers.
  20. enum layer_number {
  21. _QWERTY = 0,
  22. _LOWER,
  23. _RAISE,
  24. _ADJUST,
  25. };
  26. enum custom_keycodes {
  27. QWERTY = SAFE_RANGE,
  28. LOWER,
  29. RAISE,
  30. ADJUST,
  31. RGBRST
  32. };
  33. #define KC_CTES CTL_T(KC_ESC)
  34. #define KC_SFSP SFT_T(KC_SPC)
  35. #define KC_ALBS ALT_T(KC_BSPC)
  36. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  37. [_QWERTY] = LAYOUT( \
  38. //,---------------------------------------. ,---------------------------------------.
  39. KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P,\
  40. //|-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------|
  41. KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_ENT,\
  42. //|-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------|
  43. KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M,KC_COMM, KC_DOT,KC_SLSH,\
  44. //|-------+-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------+-------|
  45. KC_LSFT, KC_SPC,KC_LALT,KC_LGUI, LOWER,KC_CTES, KC_SFSP, RAISE,KC_ALBS,KC_RCTL,KC_LGUI,XXXXXXX \
  46. //|-------+-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------+-------|
  47. ),
  48. [_LOWER] = LAYOUT( \
  49. //,---------------------------------------. ,---------------------------------------.
  50. KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0,\
  51. //|-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------|
  52. KC_TAB,XXXXXXX,XXXXXXX,XXXXXXX,XXXXXXX, KC_LEFT,KC_DOWN, KC_UP,KC_RGHT, KC_ENT,\
  53. //|-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------|
  54. KC_LCTL, KC_SPC,KC_LSFT,KC_LALT, KC_DEL, KC_BSPC,KC_HOME, KC_END,XXXXXXX,XXXXXXX,\
  55. //|-------+-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------+-------|
  56. _______,_______,_______,_______,_______,_______, _______,_______,_______,_______,_______,_______ \
  57. //|-------+-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------+-------|
  58. ),
  59. [_RAISE] = LAYOUT( \
  60. //,---------------------------------------. ,---------------------------------------.
  61. KC_EXLM, KC_AT,KC_HASH, KC_DLR,KC_PERC, KC_CIRC,KC_AMPR,KC_ASTR,KC_LPRN,KC_RPRN,\
  62. //|-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------|
  63. KC_TAB,KC_UNDS,KC_PLUS,KC_PIPE,KC_TILD, KC_COLN,KC_DQUO, KC_GT,KC_LCBR,KC_RCBR,\
  64. //|-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------|
  65. KC_LCTL,KC_MINS, KC_EQL,KC_BSLS, KC_GRV, KC_SCLN,KC_QUOT, KC_LT,KC_LBRC,KC_RBRC,\
  66. //|-------+-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------+-------|
  67. _______,_______,_______,_______,_______,_______, _______,_______,_______,_______,_______,_______ \
  68. //|-------+-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------+-------|
  69. ),
  70. [_ADJUST] = LAYOUT( \
  71. //,---------------------------------------. ,---------------------------------------.
  72. KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10,\
  73. //|-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------|
  74. KC_F11, KC_F12, RESET,KC_PSCR, KC_INS, RGB_TOG,RGB_HUI,RGB_SAI,RGB_VAI,XXXXXXX,\
  75. //|-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------|
  76. XXXXXXX,XXXXXXX,XXXXXXX,XXXXXXX,XXXXXXX, RGB_MOD,RGB_HUD,RGB_SAD,RGB_VAD,RGBRST,\
  77. //|-------+-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------+-------|
  78. _______,_______,_______,_______,_______,_______, _______,_______,_______,_______,_______,_______ \
  79. //|-------+-------+-------+-------+-------+-------| |-------+-------+-------+-------+-------+-------|
  80. )
  81. };
  82. int RGB_current_mode;
  83. // Setting ADJUST layer RGB back to default
  84. void update_tri_layer_RGB(uint8_t layer1, uint8_t layer2, uint8_t layer3) {
  85. if (IS_LAYER_ON(layer1) && IS_LAYER_ON(layer2)) {
  86. layer_on(layer3);
  87. } else {
  88. layer_off(layer3);
  89. }
  90. }
  91. void matrix_init_user(void) {
  92. #ifdef RGBLIGHT_ENABLE
  93. RGB_current_mode = rgblight_config.mode;
  94. #endif
  95. }
  96. //SSD1306 OLED update loop, make sure to enable OLED_DRIVER_ENABLE=yes in rules.mk
  97. #ifdef OLED_DRIVER_ENABLE
  98. #define L_BASE 0
  99. #define L_LOWER (1 << 1)
  100. #define L_RAISE (1 << 2)
  101. #define L_ADJUST (1 << 3)
  102. #define L_ADJUST_TRI (L_ADJUST | L_RAISE | L_LOWER)
  103. char layer_state_str[24];
  104. const char *read_layer_state(void) {
  105. switch (layer_state)
  106. {
  107. case L_BASE:
  108. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Default");
  109. break;
  110. case L_RAISE:
  111. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Raise");
  112. break;
  113. case L_LOWER:
  114. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Lower");
  115. break;
  116. case L_ADJUST:
  117. case L_ADJUST_TRI:
  118. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Adjust");
  119. break;
  120. default:
  121. snprintf(layer_state_str, sizeof(layer_state_str), "Layer: Undef-%ld", layer_state);
  122. }
  123. return layer_state_str;
  124. }
  125. const char *read_logo(void) {
  126. static char logo[] = {
  127. 0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x8d, 0x8e, 0x8f, 0x90, 0x91, 0x92, 0x93, 0x94,
  128. 0xa0, 0xa1, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7, 0xa8, 0xa9, 0xaa, 0xab, 0xac, 0xad, 0xae, 0xaf, 0xb0, 0xb1, 0xb2, 0xb3, 0xb4,
  129. 0xc0, 0xc1, 0xc2, 0xc3, 0xc4, 0xc5, 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xcb, 0xcc, 0xcd, 0xce, 0xcf, 0xd0, 0xd1, 0xd2, 0xd3, 0xd4,
  130. 0};
  131. return logo;
  132. }
  133. char keylog_str[24] = {};
  134. char keylogs_str[21] = {};
  135. int keylogs_str_idx = 0;
  136. const char code_to_name[60] = {
  137. ' ', ' ', ' ', ' ', 'a', 'b', 'c', 'd', 'e', 'f',
  138. 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',
  139. 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z',
  140. '1', '2', '3', '4', '5', '6', '7', '8', '9', '0',
  141. 'R', 'E', 'B', 'T', ' ', ' ', ' ', ' ', ' ', ' ',
  142. ' ', ';', '\'', ' ', ',', '.', '/', ' ', ' ', ' '};
  143. void set_keylog(uint16_t keycode, keyrecord_t *record) {
  144. char name = ' ';
  145. if (keycode < 60) {
  146. name = code_to_name[keycode];
  147. }
  148. // update keylog
  149. snprintf(keylog_str, sizeof(keylog_str), "%dx%d, k%2d : %c",
  150. record->event.key.row, record->event.key.col,
  151. keycode, name);
  152. // update keylogs
  153. if (keylogs_str_idx == sizeof(keylogs_str) - 1) {
  154. keylogs_str_idx = 0;
  155. for (int i = 0; i < sizeof(keylogs_str) - 1; i++) {
  156. keylogs_str[i] = ' ';
  157. }
  158. }
  159. keylogs_str[keylogs_str_idx] = name;
  160. keylogs_str_idx++;
  161. }
  162. const char *read_keylog(void) {
  163. return keylog_str;
  164. }
  165. const char *read_keylogs(void) {
  166. return keylogs_str;
  167. }
  168. oled_rotation_t oled_init_user(oled_rotation_t rotation) {
  169. if (!is_keyboard_master())
  170. return OLED_ROTATION_180; // flips the display 180 degrees if offhand
  171. return rotation;
  172. }
  173. void oled_task_user(void) {
  174. if (is_keyboard_master()) {
  175. // If you want to change the display of OLED, you need to change here
  176. oled_write_ln(read_layer_state(), false);
  177. oled_write_ln(read_keylog(), false);
  178. oled_write_ln(read_keylogs(), false);
  179. //oled_write_ln(read_mode_icon(keymap_config.swap_lalt_lgui), false);
  180. //oled_write_ln(read_host_led_state(), false);
  181. //oled_write_ln(read_timelog(), false);
  182. } else {
  183. oled_write(read_logo(), false);
  184. }
  185. }
  186. #endif // OLED_DRIVER_ENABLE
  187. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  188. if (record->event.pressed) {
  189. #ifdef OLED_DRIVER_ENABLE
  190. set_keylog(keycode, record);
  191. #endif
  192. // set_timelog();
  193. }
  194. switch (keycode) {
  195. case QWERTY:
  196. if (record->event.pressed) {
  197. set_single_persistent_default_layer(_QWERTY);
  198. }
  199. return false;
  200. break;
  201. case LOWER:
  202. if (record->event.pressed) {
  203. layer_on(_LOWER);
  204. update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
  205. } else {
  206. layer_off(_LOWER);
  207. update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
  208. }
  209. return false;
  210. break;
  211. case RAISE:
  212. if (record->event.pressed) {
  213. layer_on(_RAISE);
  214. update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
  215. } else {
  216. layer_off(_RAISE);
  217. update_tri_layer_RGB(_LOWER, _RAISE, _ADJUST);
  218. }
  219. return false;
  220. break;
  221. case ADJUST:
  222. if (record->event.pressed) {
  223. layer_on(_ADJUST);
  224. } else {
  225. layer_off(_ADJUST);
  226. }
  227. return false;
  228. break;
  229. case RGB_MOD:
  230. #ifdef RGBLIGHT_ENABLE
  231. if (record->event.pressed) {
  232. rgblight_mode(RGB_current_mode);
  233. rgblight_step();
  234. RGB_current_mode = rgblight_config.mode;
  235. }
  236. #endif
  237. return false;
  238. break;
  239. case RGBRST:
  240. #ifdef RGBLIGHT_ENABLE
  241. if (record->event.pressed) {
  242. eeconfig_update_rgblight_default();
  243. rgblight_enable();
  244. RGB_current_mode = rgblight_config.mode;
  245. }
  246. #endif
  247. break;
  248. }
  249. return true;
  250. }
  251. #ifdef RGBLIGHT_ENABLE
  252. char rbf_info_str[24];
  253. const char *read_rgb_info(void) {
  254. snprintf(rbf_info_str, sizeof(rbf_info_str), "%s %2d h%3d s%3d v%3d",
  255. rgblight_config.enable ? "on" : "- ", rgblight_config.mode,
  256. rgblight_config.hue, rgblight_config.sat, rgblight_config.val);
  257. return rbf_info_str;
  258. }
  259. #endif