keymap.c 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. #pragma message "You may need to add LAYOUT_planck_grid to your keymap layers - see default for an example"
  2. #include "planck.h"
  3. #ifdef BACKLIGHT_ENABLE
  4. # include "backlight.h"
  5. #endif
  6. #include "timer.h"
  7. #include <bootloader.h>
  8. // Each layer gets a name for readability, which is then used in the keymap matrix below.
  9. // The underscores don't mean anything - you can have a layer called STUFF or any other name.
  10. // Layer names don't all need to be of the same length, obviously, and you can also skip them
  11. // entirely and just use numbers.
  12. enum userlayer {
  13. _QW = 0,
  14. _CM,
  15. _PP,
  16. _PPG,
  17. _NM,
  18. _LW,
  19. _RS,
  20. _DL,
  21. _DYN,
  22. };
  23. enum planck_keycodes {
  24. KM_LW = SAFE_RANGE,
  25. KM_RS,
  26. KM_SHLK, /* ShiftLock */
  27. KM_RST, /* Reset */
  28. KM_NUM, /* Numeric layer */
  29. KM_SLP, /* Sleep 250 ms */
  30. KM_PPLR, /* Pure Pro layer */
  31. DYNAMIC_MACRO_RANGE,
  32. };
  33. #include "dynamic_macro.h"
  34. #define _______ KC_TRNS
  35. #define XXXXXXX KC_NO
  36. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  37. [_QW] = { /* Qwerty */
  38. {KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC},
  39. {CTL_T(KC_ESC), KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT},
  40. {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_FN0 },
  41. {KC_LCTL, MO(_DYN),KC_LGUI, KC_LALT, KM_LW, KC_SPC, KC_SPC, KM_RS, KC_RALT, KC_DOWN, KC_UP, KC_RCTL}
  42. },
  43. [_CM] = { /* Colemak */
  44. {KC_TAB, KC_Q, KC_W, KC_F, KC_P, KC_G, KC_J, KC_L, KC_U, KC_Y, KC_SCLN, KC_BSPC},
  45. {CTL_T(KC_ESC), KC_A, KC_R, KC_S, KC_T, KC_D, KC_H, KC_N, KC_E, KC_I, KC_O, KC_QUOT},
  46. {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_K, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_FN0 },
  47. {KC_LCTL, MO(_DYN),KC_LGUI, KC_LALT, KM_LW, KC_SPC, KC_SPC, KM_RS, KC_RALT, KC_DOWN, KC_UP, KC_RCTL}
  48. },
  49. [_PP] = { /* Pure Pro */
  50. {KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_BSPC},
  51. {KC_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_ENT },
  52. {KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_RSFT, KC_UP, KC_RCTL},
  53. {KC_LCTL, MO(_DYN),KC_LGUI, KC_LALT, KM_LW, KC_SPC, KC_SPC, KM_RS, KC_RALT, KC_LEFT, KC_DOWN, KC_RGHT}
  54. },
  55. [_PPG] = { /* Pure Pro: Gaming */
  56. {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______},
  57. {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______},
  58. {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______},
  59. {_______, _______, XXXXXXX, _______, KM_RS , _______, _______, KM_LW , _______, _______, _______, _______},
  60. },
  61. [_NM] = { /* Numeric */
  62. {KC_TAB, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_BSPC},
  63. {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______},
  64. {KC_LSFT, _______, _______, _______, _______, _______, _______, _______, KC_COMM, KC_DOT, _______, KC_FN0 },
  65. {_______, _______, _______, _______, _______, KC_SPC, KC_SPC, _______, _______, _______, _______, _______}
  66. },
  67. [_LW]= { /* LOWER */
  68. {KC_TILD, KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN, KC_BSPC},
  69. {KC_ESC, LGUI(KC_1), LGUI(KC_2), LGUI(KC_3), LGUI(KC_4), LGUI(KC_5), KM_NUM, KC_UNDS, KC_PLUS, KC_LCBR, KC_RCBR, KC_PIPE},
  70. {_______, LGUI(KC_6), LGUI(KC_7), LGUI(KC_8), LGUI(KC_9), LGUI(KC_0), KM_SLP, KC_HOME, KC_PGDN, KC_PGUP, KC_END, KC_ENT },
  71. {_______, BL_TOGG, _______, _______, _______, KC_BTN1, KC_BTN1, _______, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT}
  72. },
  73. [_RS]= { /* RAISE */
  74. {KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_DEL },
  75. {KC_ESC, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_MINS, KC_EQL, KC_LBRC, KC_RBRC, KC_BSLS},
  76. {_______, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, DF(_QW), DF(_CM), KM_PPLR, KM_RST, KC_ENT },
  77. {_______, BL_STEP, _______, _______, _______, KC_BTN2, KC_BTN2, _______, KC_MPLY, KC_VOLD, KC_VOLU, _______}
  78. },
  79. [_DL]= { /* DUAL */
  80. {_______, _______, KC_WH_U, KC_MS_U, KC_WH_D, _______, _______, KC_APP, KC_INS, _______, KC_PSCR, _______},
  81. {_______, _______, KC_MS_L, KC_MS_D, KC_MS_R, _______, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, KC_ACL0, KC_ACL2},
  82. {_______, _______, KC_BTN2, KC_BTN3, KC_BTN1, KC_WWW_BACK, KC_WWW_FORWARD, KC_MUTE, _______, _______, _______, _______},
  83. {_______, _______, KC_LGUI, KC_LALT, _______, _______, _______, _______, _______, _______, _______, _______}
  84. },
  85. [_DYN]= { /* special */
  86. {_______, DYN_REC_START1, DYN_MACRO_PLAY1, _______, _______, _______, _______, KC_APP, KC_INS, _______, KC_PSCR, KC_PAUS},
  87. {_______, DYN_REC_START2, DYN_MACRO_PLAY2, _______, _______, _______, _______, _______, _______, KC_CAPS, KC_SLCK, KC_NLCK},
  88. {KM_SHLK, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______},
  89. {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______}
  90. },
  91. };
  92. #undef _______
  93. const uint16_t PROGMEM fn_actions[] = {
  94. ACTION_MODS_TAP_KEY(MOD_RSFT, KC_ENT),
  95. };
  96. bool process_record_user(uint16_t keycode, keyrecord_t *record) {
  97. static uint16_t key_timer;
  98. uint16_t macro_kc = (keycode == MO(_DYN) ? DYN_REC_STOP : keycode);
  99. if (!process_record_dynamic_macro(macro_kc, record)) {
  100. return false;
  101. }
  102. switch (keycode) {
  103. case KM_LW:
  104. if (record->event.pressed) {
  105. layer_on(_LW);
  106. } else {
  107. layer_off(_LW);
  108. }
  109. update_tri_layer(_LW, _RS, _DL);
  110. return false;
  111. break;
  112. case KM_RS:
  113. if (record->event.pressed) {
  114. layer_on(_RS);
  115. } else {
  116. layer_off(_RS);
  117. }
  118. update_tri_layer(_LW, _RS, _DL);
  119. return false;
  120. break;
  121. case KM_SHLK:
  122. register_code(KC_LSFT);
  123. break;
  124. case KM_RST:
  125. if (record->event.pressed) {
  126. key_timer = timer_read();
  127. } else {
  128. if (timer_elapsed(key_timer) >= 500) {
  129. clear_keyboard();
  130. backlight_toggle();
  131. _delay_ms(250);
  132. backlight_toggle();
  133. bootloader_jump();
  134. }
  135. }
  136. break;
  137. case KM_PPLR:
  138. if (record->event.pressed) {
  139. key_timer = timer_read();
  140. } else {
  141. if (timer_elapsed(key_timer) >= 250) {
  142. default_layer_set((1UL << _PP) | (1UL << _PPG));
  143. backlight_toggle();
  144. _delay_ms(100);
  145. backlight_toggle();
  146. } else {
  147. default_layer_set(1UL << _PP);
  148. }
  149. }
  150. break;
  151. case KM_NUM:
  152. layer_on(_NM);
  153. break;
  154. case KM_SLP:
  155. if (record->event.pressed) {
  156. _delay_ms(250);
  157. }
  158. break;
  159. }
  160. if (record->event.pressed
  161. && IS_LAYER_ON(_NM)
  162. && keymap_key_to_keycode(_NM, record->event.key) == KC_TRNS) {
  163. layer_off(_NM);
  164. }
  165. return true;
  166. }
  167. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  168. {
  169. return MACRO_NONE;
  170. }