You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

146 lines
7.1 KiB

  1. #include QMK_KEYBOARD_H
  2. #define MY_ESC LT(1, KC_ESC)
  3. #define MY_ENT LT(1, KC_ENT)
  4. #define MY_APP LT(2, KC_APP)
  5. #define MY_LCA TD(TD_LCTL_ALT)
  6. #define MY_RCA TD(TD_RCTL_ALT)
  7. #define MY_LGA TD(TD_LGUI_ALT)
  8. #define MY_RGA TD(TD_RGUI_ALT)
  9. #define MY_LCG TD(TD_LCTL_GUI)
  10. #define MY_RCG TD(TD_RCTL_GUI)
  11. #define MY_LSH TD(TD_LSFT_HPR)
  12. #define MY_RSH TD(TD_RSFT_HPR)
  13. enum {
  14. TD_LCTL_ALT,
  15. TD_RCTL_ALT,
  16. TD_LGUI_ALT,
  17. TD_RGUI_ALT,
  18. TD_LCTL_GUI,
  19. TD_RCTL_GUI,
  20. TD_LSFT_HPR,
  21. TD_RSFT_HPR
  22. };
  23. const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
  24. LAYOUT_60_ansi(
  25. KC_GRV, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC,
  26. KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS,
  27. MY_ESC, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, MY_ENT,
  28. MY_LSH, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, MY_RSH,
  29. MY_LGA, MY_LCG, MY_LCA, KC_SPC, MY_RCA, MY_RCG, MY_APP, MY_RGA),
  30. LAYOUT_60_ansi(
  31. KC_TRNS, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, KC_DEL,
  32. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  33. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT, KC_TRNS, KC_TRNS, KC_TRNS,
  34. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  35. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  36. LAYOUT_60_ansi(
  37. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  38. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, QK_BOOT, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  39. KC_TRNS, KC_TRNS, KC_TRNS, DB_TOGG, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  40. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS,
  41. KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS, KC_TRNS),
  42. };
  43. enum {
  44. SINGLE_TAP = 1,
  45. SINGLE_HOLD = 2,
  46. DOUBLE_TAP = 3,
  47. DOUBLE_HOLD = 4,
  48. DOUBLE_SINGLE_TAP = 5,
  49. UNKNOWN_TAP = 6
  50. };
  51. typedef struct {
  52. bool is_press_action;
  53. int state;
  54. } tap;
  55. int cur_dance(tap_dance_state_t *state) {
  56. switch (state->count) {
  57. case 1:
  58. if (state->interrupted || state->pressed == 0) {
  59. return SINGLE_TAP;
  60. }
  61. return SINGLE_HOLD;
  62. case 2:
  63. if (state->interrupted) {
  64. return DOUBLE_SINGLE_TAP;
  65. }
  66. if (state->pressed) {
  67. return DOUBLE_HOLD;
  68. }
  69. return DOUBLE_TAP;
  70. }
  71. return UNKNOWN_TAP;
  72. }
  73. #define my_dance_combo(N, K0, REGFN, UNREGFN) my_dance_combo_expanded(N, K0, REGFN, UNREGFN)
  74. #define my_dance_combo_expanded(N, K0, REGFN, UNREGFN) \
  75. static tap N ## _state = { \
  76. .is_press_action = true, \
  77. .state = 0 \
  78. }; \
  79. \
  80. void N ## _finished(tap_dance_state_t *state, void *user_data) { \
  81. N ## _state.state = cur_dance(state); \
  82. switch (N ## _state.state) { \
  83. case SINGLE_TAP: case SINGLE_HOLD: \
  84. register_code(K0); \
  85. break; \
  86. case DOUBLE_TAP: case DOUBLE_SINGLE_TAP: case DOUBLE_HOLD: \
  87. register_code(K0); \
  88. REGFN; \
  89. break; \
  90. } \
  91. } \
  92. \
  93. void N ## _reset(tap_dance_state_t *state, void *user_data) { \
  94. switch (N ## _state.state) { \
  95. case SINGLE_TAP: case SINGLE_HOLD: \
  96. unregister_code(K0); \
  97. break; \
  98. case DOUBLE_TAP: case DOUBLE_SINGLE_TAP: case DOUBLE_HOLD: \
  99. UNREGFN; \
  100. unregister_code(K0); \
  101. break; \
  102. } \
  103. N ## _state.state = 0; \
  104. }
  105. #define my_dance_reg_code_1(K1) register_code(K1)
  106. #define my_dance_unreg_code_1(K1) unregister_code(K1)
  107. #define my_dance_combo_1(N, K0, K1) \
  108. my_dance_combo(N, K0, my_dance_reg_code_1(K1), my_dance_unreg_code_1(K1))
  109. #define my_dance_reg_code_3(K1, K2, K3) \
  110. do { register_code(K1); register_code(K2); register_code(K3); } while (0)
  111. #define my_dance_unreg_code_3(K1, K2, K3) \
  112. do { unregister_code(K3); unregister_code(K2); unregister_code(K1); } while (0)
  113. #define my_dance_combo_3(N, K0, K1, K2, K3) \
  114. my_dance_combo(N, K0, my_dance_reg_code_3(K1, K2, K3), my_dance_unreg_code_3(K1, K2, K3))
  115. my_dance_combo_1(lca, KC_LCTL, KC_LALT)
  116. my_dance_combo_1(rca, KC_RCTL, KC_RALT)
  117. my_dance_combo_1(lga, KC_LGUI, KC_LALT)
  118. my_dance_combo_1(rga, KC_RGUI, KC_RALT)
  119. my_dance_combo_1(lcg, KC_LCTL, KC_LGUI)
  120. my_dance_combo_1(rcg, KC_RCTL, KC_RGUI)
  121. my_dance_combo_3(lsh, KC_LSFT, KC_LCTL, KC_LALT, KC_LGUI)
  122. my_dance_combo_3(rsh, KC_RSFT, KC_RCTL, KC_RALT, KC_RGUI)
  123. tap_dance_action_t tap_dance_actions[] = {
  124. [TD_LCTL_ALT] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, lca_finished, lca_reset),
  125. [TD_RCTL_ALT] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, rca_finished, rca_reset),
  126. [TD_LGUI_ALT] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, lga_finished, lga_reset),
  127. [TD_RGUI_ALT] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, rga_finished, rga_reset),
  128. [TD_LCTL_GUI] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, lcg_finished, lcg_reset),
  129. [TD_RCTL_GUI] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, rcg_finished, rcg_reset),
  130. [TD_LSFT_HPR] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, lsh_finished, lsh_reset),
  131. [TD_RSFT_HPR] = ACTION_TAP_DANCE_FN_ADVANCED(NULL, rsh_finished, rsh_reset)
  132. };