]> git.donarmstrong.com Git - qmk_firmware.git/commitdiff
Added per case tapping term, updated FF-nikchi keymap.
authorNick Choi <iinikchi@gmail.com>
Thu, 25 May 2017 04:41:00 +0000 (00:41 -0400)
committerNick Choi <iinikchi@gmail.com>
Thu, 25 May 2017 04:41:00 +0000 (00:41 -0400)
keyboards/frosty_flake/keymaps/nikchi/config.h
keyboards/frosty_flake/keymaps/nikchi/keymap.c
quantum/process_keycode/process_tap_dance.c
quantum/process_keycode/process_tap_dance.h

index 31fcefefaed68f31b811f50d5e4fcadcf34a02a8..45825781dff872db66b5f517aead66d25875716e 100644 (file)
@@ -3,7 +3,7 @@
 
 #include "../../config.h"
 
-#define TAPPING_TERM 800
+#define TAPPING_TERM 200
 #define LEADER_TIMEOUT 400
 
 #define DISABLE_SPACE_CADET_ROLLOVER
index afb5197cad9d0653f9b5499902edb59df5a32a0b..3cfe0ede408cf47e2639229dfbd753a178cfa293 100644 (file)
@@ -77,10 +77,10 @@ enum quick {
 qk_tap_dance_action_t tap_dance_actions[] = {
   // Tap once for CTRL, twice for Caps Lock
   [TD_CTCPS]  = ACTION_TAP_DANCE_DOUBLE(KC_LCTL, KC_CAPS),
-  [EMOJIS] = ACTION_TAP_DANCE_FN_ADVANCED(cycleEmojis, NULL, NULL),
-  [ANIMAL] = ACTION_TAP_DANCE_FN_ADVANCED(cycleAnimals, NULL, NULL),
-  [HAND] = ACTION_TAP_DANCE_FN_ADVANCED(cycleHands, NULL, NULL),
-  [MEMES] = ACTION_TAP_DANCE_FN_ADVANCED(cycleMemes, NULL, NULL)
+  [EMOJIS] = ACTION_TAP_DANCE_FN_ADVANCED(cycleEmojis, NULL, NULL, 800),
+  [ANIMAL] = ACTION_TAP_DANCE_FN_ADVANCED(cycleAnimals, NULL, NULL, 800),
+  [HAND] = ACTION_TAP_DANCE_FN_ADVANCED(cycleHands, NULL, NULL, 800),
+  [MEMES] = ACTION_TAP_DANCE_FN_ADVANCED(cycleMemes, NULL, NULL, 800)
 // Other declarations would go here, separated by commas, if you have them
 };
 
index b807ec3c30820e2e32a83c63a6d95d9419e2551d..e58b6f2dfe7ad862e4dd787386c95f240f86813e 100644 (file)
@@ -130,11 +130,17 @@ bool process_tap_dance(uint16_t keycode, keyrecord_t *record) {
 void matrix_scan_tap_dance () {
   if (highest_td == -1)
     return;
+  int tap_user_defined;
 
 for (int i = 0; i <= highest_td; i++) {
     qk_tap_dance_action_t *action = &tap_dance_actions[i];
-
-    if (action->state.count && timer_elapsed (action->state.timer) > TAPPING_TERM) {
+    if(action->user_data != NULL ) {
+      tap_user_defined = (int)action->user_data;
+    }
+    else{
+      tap_user_defined = TAPPING_TERM;
+    }
+    if (action->state.count && timer_elapsed (action->state.timer) > tap_user_defined) {
       process_tap_dance_action_on_dance_finished (action);
       reset_tap_dance (&action->state);
     }
index 330809f83a9ebd822c01af9b8dbce1026c49a35d..95d51f480650133e0ee4f71ffe4bc21956acae14 100644 (file)
@@ -63,9 +63,9 @@ typedef struct
     .user_data = NULL, \
   }
 
-#define ACTION_TAP_DANCE_FN_ADVANCED(user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_dance_reset) { \
+#define ACTION_TAP_DANCE_FN_ADVANCED(user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_dance_reset, tap_specific_tapping_term) { \
     .fn = { user_fn_on_each_tap, user_fn_on_dance_finished, user_fn_on_dance_reset }, \
-    .user_data = NULL, \
+    .user_data = (void *)(tap_specific_tapping_term), \
   }
 
 extern qk_tap_dance_action_t tap_dance_actions[];