diff options
| author | Daniel Shields <dshields@bats.com> | 2017-06-02 11:10:22 +0100 |
|---|---|---|
| committer | Daniel Shields <dshields@bats.com> | 2017-06-06 13:09:55 +0100 |
| commit | ad7a5bdc4f2527f47ca22885e5d0b689fb8d4518 (patch) | |
| tree | a48ec9c4141cd41c54b27cedc8f04f267b84eba7 | |
| parent | 5e18e4ab48f12881a102f71265aa598163d1e34b (diff) | |
| download | qmk_firmware-ad7a5bdc4f2527f47ca22885e5d0b689fb8d4518.tar.gz qmk_firmware-ad7a5bdc4f2527f47ca22885e5d0b689fb8d4518.zip | |
Additional tap dance keys/functions for planck/keymap/dshields
| -rw-r--r-- | keyboards/planck/keymaps/dshields/config.h | 20 | ||||
| -rw-r--r-- | keyboards/planck/keymaps/dshields/keymap.c | 55 |
2 files changed, 63 insertions, 12 deletions
diff --git a/keyboards/planck/keymaps/dshields/config.h b/keyboards/planck/keymaps/dshields/config.h index 8fa078cd9..5f2810287 100644 --- a/keyboards/planck/keymaps/dshields/config.h +++ b/keyboards/planck/keymaps/dshields/config.h | |||
| @@ -16,17 +16,37 @@ | |||
| 16 | #define MOUSEKEY_MAX_SPEED 7 | 16 | #define MOUSEKEY_MAX_SPEED 7 |
| 17 | #define MOUSEKEY_WHEEL_DELAY 0 | 17 | #define MOUSEKEY_WHEEL_DELAY 0 |
| 18 | 18 | ||
| 19 | // dynamic macro keys | ||
| 19 | #define DM_PLAY DYN_MACRO_PLAY1 | 20 | #define DM_PLAY DYN_MACRO_PLAY1 |
| 20 | #define DM_STRT DYN_REC_START1 | 21 | #define DM_STRT DYN_REC_START1 |
| 21 | #define DM_STOP DYN_REC_STOP | 22 | #define DM_STOP DYN_REC_STOP |
| 22 | 23 | ||
| 24 | // one-shot layer keys | ||
| 23 | #define OSL_RSE OSL(RSE) | 25 | #define OSL_RSE OSL(RSE) |
| 24 | #define OSL_LWR OSL(LWR) | 26 | #define OSL_LWR OSL(LWR) |
| 25 | #define OSL_FUN OSL(FUN) | 27 | #define OSL_FUN OSL(FUN) |
| 26 | 28 | ||
| 29 | // one-shot modifier keys | ||
| 27 | #define OSM_CTL OSM(MOD_LCTL) | 30 | #define OSM_CTL OSM(MOD_LCTL) |
| 28 | #define OSM_ALT OSM(MOD_LALT) | 31 | #define OSM_ALT OSM(MOD_LALT) |
| 29 | #define OSM_SFT OSM(MOD_LSFT) | 32 | #define OSM_SFT OSM(MOD_LSFT) |
| 30 | 33 | ||
| 34 | // tap dance keys | ||
| 35 | #define TD_SCLN TD(TDK_SCLN) | ||
| 36 | #define TD_COMM TD(TDK_COMM) | ||
| 37 | #define TD_DOT TD(TDK_DOT) | ||
| 38 | #define TD_SLSH TD(TDK_SLSH) | ||
| 39 | |||
| 40 | #define ACTION_TAP_DANCE_FN_KEYCODE(user_fn, kc) { \ | ||
| 41 | .fn = { NULL, user_fn, NULL }, \ | ||
| 42 | .user_data = (void *)&((qk_tap_dance_pair_t) { kc, 0 }) \ | ||
| 43 | } | ||
| 44 | |||
| 45 | #define ACTION_TAP_DANCE_FN_KEYCODE2(user_fn, kc1, kc2) { \ | ||
| 46 | .fn = { NULL, user_fn, NULL }, \ | ||
| 47 | .user_data = (void *)&((qk_tap_dance_pair_t) { kc1, kc2 }) \ | ||
| 48 | } | ||
| 49 | |||
| 50 | |||
| 31 | #endif | 51 | #endif |
| 32 | 52 | ||
diff --git a/keyboards/planck/keymaps/dshields/keymap.c b/keyboards/planck/keymaps/dshields/keymap.c index ed7621c77..09bdc3e40 100644 --- a/keyboards/planck/keymaps/dshields/keymap.c +++ b/keyboards/planck/keymaps/dshields/keymap.c | |||
| @@ -8,7 +8,7 @@ extern keymap_config_t keymap_config; | |||
| 8 | 8 | ||
| 9 | enum planck_layers { DEF, LWR, RSE, FUN }; | 9 | enum planck_layers { DEF, LWR, RSE, FUN }; |
| 10 | enum planck_keycodes { DYNAMIC_MACRO_RANGE = SAFE_RANGE }; | 10 | enum planck_keycodes { DYNAMIC_MACRO_RANGE = SAFE_RANGE }; |
| 11 | enum tap_dance_keys { TD_SCLN }; | 11 | enum tap_dance_keys { TDK_SCLN, TDK_COMM, TDK_DOT, TDK_SLSH }; |
| 12 | 12 | ||
| 13 | #include "dynamic_macro.h" | 13 | #include "dynamic_macro.h" |
| 14 | 14 | ||
| @@ -26,8 +26,8 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 26 | */ | 26 | */ |
| 27 | [DEF] = { | 27 | [DEF] = { |
| 28 | {KC_Q, KC_W, KC_E, KC_R, KC_T, KC_ESC, KC_BSPC, KC_Y, KC_U, KC_I, KC_O, KC_P}, | 28 | {KC_Q, KC_W, KC_E, KC_R, KC_T, KC_ESC, KC_BSPC, KC_Y, KC_U, KC_I, KC_O, KC_P}, |
| 29 | {KC_A, KC_S, KC_D, KC_F, KC_G, KC_TAB, KC_ENT, KC_H, KC_J, KC_K, KC_L, TD(TD_SCLN)}, | 29 | {KC_A, KC_S, KC_D, KC_F, KC_G, KC_TAB, KC_ENT, KC_H, KC_J, KC_K, KC_L, TD_SCLN}, |
| 30 | {KC_Z, KC_X, KC_C, KC_V, KC_B, OSM_SFT, DM_PLAY, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH}, | 30 | {KC_Z, KC_X, KC_C, KC_V, KC_B, OSM_SFT, DM_PLAY, KC_N, KC_M, TD_COMM, TD_DOT, TD_SLSH}, |
| 31 | {OSM_CTL, KC_LGUI, OSM_ALT, OSL_FUN, OSL_LWR, KC_SPC, KC_SPC, OSL_RSE, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT} | 31 | {OSM_CTL, KC_LGUI, OSM_ALT, OSL_FUN, OSL_LWR, KC_SPC, KC_SPC, OSL_RSE, KC_LEFT, KC_DOWN, KC_UP, KC_RGHT} |
| 32 | }, | 32 | }, |
| 33 | /* Lower | 33 | /* Lower |
| @@ -42,10 +42,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 42 | * `-----------------------------------------------------------------------------------' | 42 | * `-----------------------------------------------------------------------------------' |
| 43 | */ | 43 | */ |
| 44 | [LWR] = { | 44 | [LWR] = { |
| 45 | {KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, _______, _______, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN}, | 45 | {KC_EXLM, KC_AT, KC_HASH, KC_DLR, KC_PERC, _______, _______, KC_CIRC, KC_AMPR, KC_ASTR, KC_LPRN, KC_RPRN}, |
| 46 | {S(KC_GRV), _______, _______, _______, _______, _______, _______, KC_UNDS, KC_PLUS, _______, S(KC_LBRC), S(KC_RBRC)}, | 46 | {KC_TILD, _______, _______, _______, _______, _______, _______, KC_UNDS, KC_PLUS, _______, KC_LCBR, KC_RCBR}, |
| 47 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, S(KC_QUOT), S(KC_BSLS)}, | 47 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_DQUO, KC_PIPE}, |
| 48 | {_______, _______, _______, _______, _______, _______, _______, _______, KC_HOME, KC_PGDN, KC_PGUP, KC_END} | 48 | {_______, _______, _______, _______, _______, _______, _______, _______, KC_HOME, KC_PGDN, KC_PGUP, KC_END} |
| 49 | }, | 49 | }, |
| 50 | /* Raise | 50 | /* Raise |
| 51 | * ,-----------------------------------------------------------------------------------. | 51 | * ,-----------------------------------------------------------------------------------. |
| @@ -59,10 +59,10 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 59 | * `-----------------------------------------------------------------------------------' | 59 | * `-----------------------------------------------------------------------------------' |
| 60 | */ | 60 | */ |
| 61 | [RSE] = { | 61 | [RSE] = { |
| 62 | {KC_1, KC_2, KC_3, KC_4, KC_5, _______, _______, KC_6, KC_7, KC_8, KC_9, KC_0}, | 62 | {KC_1, KC_2, KC_3, KC_4, KC_5, _______, _______, KC_6, KC_7, KC_8, KC_9, KC_0}, |
| 63 | {KC_GRV, _______, _______, _______, _______, _______, _______, KC_MINS, KC_EQL, _______, KC_LBRC, KC_RBRC}, | 63 | {KC_GRV, _______, _______, _______, _______, _______, _______, KC_MINS, KC_EQL, _______, KC_LBRC, KC_RBRC}, |
| 64 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_QUOT, KC_BSLS}, | 64 | {_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_QUOT, KC_BSLS}, |
| 65 | {_______, _______, _______, _______, _______, _______, _______, _______, KC_HOME, KC_PGDN, KC_PGUP, KC_END} | 65 | {_______, _______, _______, _______, _______, _______, _______, _______, KC_HOME, KC_PGDN, KC_PGUP, KC_END} |
| 66 | }, | 66 | }, |
| 67 | /* Function | 67 | /* Function |
| 68 | * ,-----------------------------------------------------------------------------------. | 68 | * ,-----------------------------------------------------------------------------------. |
| @@ -84,8 +84,39 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = { | |||
| 84 | 84 | ||
| 85 | }; | 85 | }; |
| 86 | 86 | ||
| 87 | void tap(uint16_t keycode) { | ||
| 88 | register_code16(keycode); | ||
| 89 | unregister_code16(keycode); | ||
| 90 | }; | ||
| 91 | |||
| 92 | void tap_dance_triple(qk_tap_dance_state_t *state, void *user_data) { | ||
| 93 | qk_tap_dance_pair_t *pair = (qk_tap_dance_pair_t *)user_data; | ||
| 94 | uint16_t keycode = pair->kc1; | ||
| 95 | |||
| 96 | switch(state->count) { | ||
| 97 | case 2: | ||
| 98 | register_code(KC_LSFT); | ||
| 99 | tap(keycode); | ||
| 100 | unregister_code(KC_LSFT); | ||
| 101 | break; | ||
| 102 | case 3: | ||
| 103 | if (pair->kc2) { | ||
| 104 | keycode = pair->kc2; | ||
| 105 | } | ||
| 106 | tap(keycode); | ||
| 107 | tap(keycode); | ||
| 108 | break; | ||
| 109 | default: | ||
| 110 | tap(keycode); | ||
| 111 | break; | ||
| 112 | } | ||
| 113 | } | ||
| 114 | |||
| 87 | qk_tap_dance_action_t tap_dance_actions[] = { | 115 | qk_tap_dance_action_t tap_dance_actions[] = { |
| 88 | [TD_SCLN] = ACTION_TAP_DANCE_DOUBLE(KC_SCLN, S(KC_SCLN)) // once for semi-colon, twice for colon | 116 | [TDK_SCLN] = ACTION_TAP_DANCE_FN_KEYCODE2(tap_dance_triple, KC_SCLN, KC_COLN), |
| 117 | [TDK_COMM] = ACTION_TAP_DANCE_FN_KEYCODE (tap_dance_triple, KC_COMM), | ||
| 118 | [TDK_DOT] = ACTION_TAP_DANCE_FN_KEYCODE (tap_dance_triple, KC_DOT), | ||
| 119 | [TDK_SLSH] = ACTION_TAP_DANCE_FN_KEYCODE (tap_dance_triple, KC_SLSH) | ||
| 89 | }; | 120 | }; |
| 90 | 121 | ||
| 91 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { | 122 | bool process_record_user(uint16_t keycode, keyrecord_t *record) { |
