keymap.c 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  1. #include "roadkit.h"
  2. #include "action_layer.h"
  3. #include "eeconfig.h"
  4. extern keymap_config_t keymap_config;
  5. // Each layer gets a name for readability, which is then used in the keymap matrix below.
  6. // The underscores don't mean anything - you can have a layer called STUFF or any other name.
  7. // Layer names don't all need to be of the same length, obviously, and you can also skip them
  8. // entirely and just use numbers.
  9. #define _NP 0
  10. #define _L1 1
  11. #define _L2 2
  12. #define _L3 3
  13. // Macro name shortcuts
  14. #define NUMPAD M(_NP)
  15. #define LAYER1 M(_L1)
  16. #define LAYER2 M(_L2)
  17. #define LAYER3 M(_L3)
  18. // Fillers to make layering more clear
  19. #define _______ KC_TRNS
  20. #define XXXXXXX KC_NO
  21. void matrix_init_user(void) {
  22. backlight_level(4);
  23. }
  24. //Tap Dance Declarations
  25. enum {
  26. TD_EQUAL_NP = 0,
  27. TD_KP_PLUS_L1,
  28. TD_DOT_L2,
  29. TD_0_L3
  30. };
  31. //Tap Dance Definitions
  32. //TD equal to turn on layer NP
  33. void _td_equal_tg_finished (qk_tap_dance_state_t *state, void *user_data) {
  34. if (state->count == 1) {
  35. register_code(KC_EQUAL);
  36. } else if (state->count == 2) {
  37. backlight_set(3);
  38. layer_on(_NP);
  39. layer_off(_L1);
  40. layer_off(_L2);
  41. layer_off(_L3);
  42. }
  43. }
  44. void _td_equal_tg_reset (qk_tap_dance_state_t *state, void *user_data) {
  45. if (state->count == 1) {
  46. unregister_code(KC_EQUAL);
  47. }
  48. }
  49. //TD kp plus to toggle layer 1
  50. void _td_kp_plus_tg_finished (qk_tap_dance_state_t *state, void *user_data) {
  51. if (state->count == 1) {
  52. register_code(KC_KP_PLUS);
  53. } else if (state->count == 2) {
  54. // layer_invert(_L1);
  55. backlight_set(2);
  56. layer_on(_L1);
  57. layer_off(_L2);
  58. layer_off(_L3);
  59. }
  60. }
  61. void _td_kp_plus_tg_reset (qk_tap_dance_state_t *state, void *user_data) {
  62. if (state->count == 1) {
  63. unregister_code(KC_KP_PLUS);
  64. }
  65. }
  66. //TD dot to toggle layer 2
  67. void _td_dot_tg_finished (qk_tap_dance_state_t *state, void *user_data) {
  68. if (state->count == 1) {
  69. register_code(KC_DOT);
  70. } else if (state->count == 2) {
  71. backlight_set(1);
  72. layer_on(_L2);
  73. layer_off(_L1);
  74. layer_off(_L3);
  75. }
  76. }
  77. void _td_dot_tg_reset (qk_tap_dance_state_t *state, void *user_data) {
  78. if (state->count == 1) {
  79. unregister_code(KC_DOT);
  80. }
  81. }
  82. //TD 0 to toggle layer 3
  83. void _td_0_tg_finished (qk_tap_dance_state_t *state, void *user_data) {
  84. if (state->count == 1) {
  85. register_code(KC_0);
  86. } else if (state->count == 2) {
  87. backlight_set(0);
  88. layer_on(_L3);
  89. layer_off(_L1);
  90. layer_off(_L2);
  91. }
  92. }
  93. void _td_0_tg_reset (qk_tap_dance_state_t *state, void *user_data) {
  94. if (state->count == 1) {
  95. unregister_code(KC_0);
  96. }
  97. }
  98. //TD Actions
  99. qk_tap_dance_action_t tap_dance_actions[] = {
  100. [TD_EQUAL_NP] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, _td_equal_tg_finished, _td_equal_tg_reset),
  101. [TD_KP_PLUS_L1] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, _td_kp_plus_tg_finished, _td_kp_plus_tg_reset),
  102. [TD_DOT_L2] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, _td_dot_tg_finished, _td_dot_tg_reset),
  103. [TD_0_L3] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, _td_0_tg_finished, _td_0_tg_reset)
  104. };
  105. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  106. /* Numberpad
  107. * ,-----------------------.
  108. * | 7 | 8 | 9 | / |
  109. * |-----`-----`-----`-----|
  110. * | 4 | 5 | 6 | * |
  111. * |-----`-----`-----`-----|
  112. * | 1 | 2 | 3 | - |
  113. * |-----`-----`-----`-----|
  114. * | 0 | . | + | = |
  115. * `-----`-----`-----`-----'
  116. * Tapdances:
  117. * | L3 | L2 | L1 | NP |
  118. * `-----`-----`-----`-----'
  119. */
  120. [_NP] = /* Numpad */
  121. LAYOUT_ortho_4x4(KC_7, KC_8, KC_9, KC_SLASH, \
  122. KC_4, KC_5, KC_6, KC_KP_ASTERISK, \
  123. KC_1, KC_2, KC_3, KC_MINUS, \
  124. TD(TD_0_L3), TD(TD_DOT_L2), TD(TD_KP_PLUS_L1), TD(TD_EQUAL_NP)),
  125. /* L1
  126. * ,-----------------------.
  127. * | Esc |Bksp |Home |PgUp |
  128. * |-----`-----`-----`-----|
  129. * | Tab | Up | End |PgDn |
  130. * |-----`-----`-----`-----|
  131. * |Left |Down |Right|Enter|
  132. * |-----`-----`-----`-----|
  133. * | 0 | . | + | = |
  134. * `-----`-----`-----`-----'
  135. */
  136. [_L1] = /* LAYER 1 */
  137. LAYOUT_ortho_4x4(KC_ESCAPE, KC_BSPACE, KC_HOME, KC_PGUP, \
  138. KC_TAB, KC_UP, KC_END, KC_PGDOWN, \
  139. KC_LEFT, KC_DOWN, KC_RIGHT, KC_KP_ENTER, \
  140. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  141. /* L2
  142. * ,-----------------------.
  143. * |Sleep|LClik|RClik|VolUp|
  144. * |-----`-----`-----`-----|
  145. * |AltF4| F11 |WinTb|VolDn|
  146. * |-----`-----`-----`-----|
  147. * |PrvTk|Play |NxtTk|Mute |
  148. * |-----`-----`-----`-----|
  149. * | 0 | . | + | = |
  150. * `-----`-----`-----`-----'
  151. */
  152. [_L2] = /* LAYER 2 */
  153. LAYOUT_ortho_4x4(KC_SYSTEM_SLEEP, KC_MS_BTN1, KC_MS_BTN2, KC_AUDIO_VOL_UP, \
  154. LALT(KC_F4), KC_F11, LGUI(KC_TAB), KC_AUDIO_VOL_DOWN, \
  155. KC_MEDIA_PREV_TRACK, KC_MEDIA_PLAY_PAUSE, KC_MEDIA_NEXT_TRACK, KC_AUDIO_MUTE, \
  156. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  157. /* L3 needs cut, copy, paste, undo, again (redo), find, calc, www back, www forward, F5
  158. * ,-----------------------.
  159. * |WBack|WHome|WFor | F5 |
  160. * |-----`-----`-----`-----|
  161. * |Calc |Undo |Redo |WSrch|
  162. * |-----`-----`-----`-----|
  163. * | Cut |Copy |Paste|Find |
  164. * |-----`-----`-----`-----|
  165. * | 0 | . | + | = |
  166. * `-----`-----`-----`-----'
  167. */
  168. [_L3] = /* LAYER 3 */
  169. LAYOUT_ortho_4x4(KC_WWW_BACK, KC_WWW_HOME, KC_WWW_FORWARD, KC_F5, \
  170. KC_CALCULATOR, LCTL(KC_Z), LCTL(KC_Y), KC_WWW_SEARCH, \
  171. LCTL(KC_X), LCTL(KC_C), LCTL(KC_V), LCTL(KC_F), \
  172. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  173. };
  174. const uint16_t PROGMEM fn_actions[] = {
  175. };
  176. void persistent_default_layer_set(uint16_t default_layer) {
  177. eeconfig_update_default_layer(default_layer);
  178. default_layer_set(default_layer);
  179. }
  180. const macro_t *action_get_macro(keyrecord_t *record, uint8_t id, uint8_t opt)
  181. {
  182. switch(id) {
  183. case _L3:
  184. if (record->event.pressed) {
  185. persistent_default_layer_set(1UL<<_L3);
  186. }
  187. break;
  188. case _L2:
  189. if (record->event.pressed) {
  190. persistent_default_layer_set(1UL<<_L2);
  191. }
  192. break;
  193. case _L1:
  194. if (record->event.pressed) {
  195. persistent_default_layer_set(1UL<<_L1);
  196. }
  197. break;
  198. case _NP:
  199. if (record->event.pressed) {
  200. persistent_default_layer_set(1UL<<_NP);
  201. }
  202. break;
  203. }
  204. return MACRO_NONE;
  205. };