aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Shields <dshields@bats.com>2017-06-02 11:10:22 +0100
committerDaniel Shields <dshields@bats.com>2017-06-06 13:09:55 +0100
commitad7a5bdc4f2527f47ca22885e5d0b689fb8d4518 (patch)
treea48ec9c4141cd41c54b27cedc8f04f267b84eba7
parent5e18e4ab48f12881a102f71265aa598163d1e34b (diff)
downloadqmk_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.h20
-rw-r--r--keyboards/planck/keymaps/dshields/keymap.c55
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
9enum planck_layers { DEF, LWR, RSE, FUN }; 9enum planck_layers { DEF, LWR, RSE, FUN };
10enum planck_keycodes { DYNAMIC_MACRO_RANGE = SAFE_RANGE }; 10enum planck_keycodes { DYNAMIC_MACRO_RANGE = SAFE_RANGE };
11enum tap_dance_keys { TD_SCLN }; 11enum 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
87void tap(uint16_t keycode) {
88 register_code16(keycode);
89 unregister_code16(keycode);
90};
91
92void 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
87qk_tap_dance_action_t tap_dance_actions[] = { 115qk_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
91bool process_record_user(uint16_t keycode, keyrecord_t *record) { 122bool process_record_user(uint16_t keycode, keyrecord_t *record) {