custom_tap_dance.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. #include "custom_tap_dance.h"
  2. #include "custom_keycodes.h"
  3. #include "timer_utils.h"
  4. #ifdef TAP_DANCE_ENABLE
  5. //Tap Dance Definitions
  6. qk_tap_dance_action_t tap_dance_actions[] = {
  7. [COMM_QUOT] = ACTION_TAP_DANCE_DOUBLE(KC_COMM, KC_QUOT),
  8. [BACKSPACE] = ACTION_TAP_DANCE_DOUBLE (KC_BSPACE, LCTL(KC_BSPACE)),
  9. [DELETE] = ACTION_TAP_DANCE_DOUBLE (KC_DELETE, LCTL(KC_DELETE)),
  10. [DOT] = ACTION_TAP_DANCE_DOUBLE (KC_DOT, KC_GRAVE)
  11. };
  12. #else
  13. static uint16_t td_keycode;
  14. static uint16_t td_timer;
  15. const uint16_t PROGMEM td_keymaps[TD_MAX - TD_MIN][2] = {
  16. [TD_COMM - TD_MIN] = { KC_COMM, KC_QUOT },
  17. [TD_BSPC - TD_MIN] = { KC_BSPACE, LCTL(KC_BSPACE) },
  18. [TD_DEL - TD_MIN] = { KC_DELETE, LCTL(KC_DELETE) },
  19. [TD_DOT - TD_MIN] = { KC_DOT, KC_GRAVE }
  20. };
  21. void run_tap_dance_double(uint8_t i)
  22. {
  23. tap_code16(pgm_read_word(&td_keymaps[td_keycode - TD_MIN][i]));
  24. td_keycode = KC_TRANSPARENT;
  25. td_timer = timer_read() + TAPPING_TERM;
  26. }
  27. bool process_tap_dance_double(uint16_t keycode, keyrecord_t *record)
  28. {
  29. if (TD_MIN <= keycode && keycode < TD_MAX)
  30. {
  31. if (record->event.pressed)
  32. {
  33. if (td_keycode != keycode || timer_expired(td_timer))
  34. {
  35. td_keycode = keycode;
  36. td_timer = timer_read() + TAPPING_TERM;
  37. }
  38. else
  39. run_tap_dance_double(1);
  40. }
  41. return false;
  42. }
  43. if (td_keycode != KC_TRANSPARENT)
  44. run_tap_dance_double(0);
  45. return true;
  46. }
  47. void matrix_scan_user(void)
  48. {
  49. if (td_keycode != KC_TRANSPARENT && timer_expired(td_timer))
  50. run_tap_dance_double(0);
  51. }
  52. #endif