making flowtap timer public so it can be used easily with combos (#25731)
This commit is contained in:
parent
6aade0ecdc
commit
8c93a33cd3
2 changed files with 17 additions and 0 deletions
|
|
@ -883,6 +883,13 @@ static bool flow_tap_key_if_within_term(keyrecord_t *record, uint16_t prev_time)
|
|||
return false;
|
||||
}
|
||||
|
||||
// Checks both flow_tap_expired flag and elapsed time to determine
|
||||
// if the key is within the flow tap term.
|
||||
bool within_flow_tap_term(uint16_t keycode, keyrecord_t *record) {
|
||||
uint16_t term = get_flow_tap_term(keycode, record, flow_tap_prev_keycode);
|
||||
return !flow_tap_expired && TIMER_DIFF_16(record->event.time, flow_tap_prev_time) <= term;
|
||||
}
|
||||
|
||||
// By default, enable Flow Tap for the keys in the main alphas area and Space.
|
||||
// This should work reasonably even if the layout is remapped on the host to an
|
||||
// alt layout or international layout (e.g. Dvorak or AZERTY), where these same
|
||||
|
|
|
|||
|
|
@ -169,6 +169,16 @@ uint16_t get_flow_tap_term(uint16_t keycode, keyrecord_t *record, uint16_t prev_
|
|||
|
||||
/** Updates the Flow Tap last key and timer. */
|
||||
void flow_tap_update_last_event(keyrecord_t *record);
|
||||
|
||||
/**
|
||||
* Checks if the pressed key is within the flow tap term.
|
||||
* Can be used to avoid triggering combos or other actions within the flow tap term.
|
||||
*
|
||||
* @param keycode The keycode of the pressed key.
|
||||
* @param record The keyrecord of the pressed key.
|
||||
* @return True if the pressed key is within the flow tap term; false otherwise.
|
||||
*/
|
||||
bool within_flow_tap_term(uint16_t keycode, keyrecord_t *record);
|
||||
#endif // FLOW_TAP_TERM
|
||||
|
||||
#ifdef DYNAMIC_TAPPING_TERM_ENABLE
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue