1
0
mirror of https://github.com/mpv-player/mpv synced 2025-01-03 13:32:16 +00:00

input: don't reset time on each key repeat

Key repeats were skipped when playloop iterations took too long. Fix
this by using the total times for key repeat calculation, instead of the
time difference to the last key repeat event.
This commit is contained in:
wm4 2013-04-24 17:42:58 +02:00
parent 003a930285
commit 97be5ead14

View File

@ -1276,6 +1276,8 @@ static mp_cmd_t *check_autorepeat(struct input_ctx *ictx)
if (ictx->ar_rate > 0 && ictx->ar_state >= 0 && ictx->num_key_down > 0 if (ictx->ar_rate > 0 && ictx->ar_state >= 0 && ictx->num_key_down > 0
&& !(ictx->key_down[ictx->num_key_down - 1] & MP_NO_REPEAT_KEY)) { && !(ictx->key_down[ictx->num_key_down - 1] & MP_NO_REPEAT_KEY)) {
unsigned int t = GetTimer(); unsigned int t = GetTimer();
if (ictx->last_ar + 2000000 < t)
ictx->last_ar = t;
// First time : wait delay // First time : wait delay
if (ictx->ar_state == 0 if (ictx->ar_state == 0
&& (t - ictx->last_key_down) >= ictx->ar_delay * 1000) && (t - ictx->last_key_down) >= ictx->ar_delay * 1000)
@ -1288,12 +1290,12 @@ static mp_cmd_t *check_autorepeat(struct input_ctx *ictx)
return NULL; return NULL;
} }
ictx->ar_state = 1; ictx->ar_state = 1;
ictx->last_ar = t; ictx->last_ar = ictx->last_key_down + ictx->ar_delay * 1000;
return mp_cmd_clone(ictx->ar_cmd); return mp_cmd_clone(ictx->ar_cmd);
// Then send rate / sec event // Then send rate / sec event
} else if (ictx->ar_state == 1 } else if (ictx->ar_state == 1
&& (t - ictx->last_ar) >= 1000000 / ictx->ar_rate) { && (t - ictx->last_ar) >= 1000000 / ictx->ar_rate) {
ictx->last_ar = t; ictx->last_ar += 1000000 / ictx->ar_rate;
return mp_cmd_clone(ictx->ar_cmd); return mp_cmd_clone(ictx->ar_cmd);
} }
} }