From 6ea9ee563a97fcd642f88f4dfc9e28494e8a5d9e Mon Sep 17 00:00:00 2001 From: bruvzg <7645683+bruvzg@users.noreply.github.com> Date: Tue, 13 Oct 2020 19:05:05 +0300 Subject: [PATCH] [macOS, 3.2] Suppress momentum scrolling after key press or modifier change to prevent unexpected change of action. --- platform/osx/os_osx.mm | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/platform/osx/os_osx.mm b/platform/osx/os_osx.mm index 1f60ed59b350..7efa7d93847f 100644 --- a/platform/osx/os_osx.mm +++ b/platform/osx/os_osx.mm @@ -105,6 +105,7 @@ static void push_to_key_event_buffer(const OS_OSX::KeyEvent &p_event) { static int mouse_y = 0; static int button_mask = 0; static bool mouse_down_control = false; +static bool ignore_momentum_scroll = false; static Vector2 get_mouse_pos(NSPoint locationInWindow) { @@ -1179,6 +1180,8 @@ static int remapKey(unsigned int key, unsigned int state) { - (void)keyDown:(NSEvent *)event { + ignore_momentum_scroll = true; + // Ignore all input if IME input is in progress if (!imeInputEventInProgress) { NSString *characters = [event characters]; @@ -1219,6 +1222,8 @@ - (void)keyDown:(NSEvent *)event { - (void)flagsChanged:(NSEvent *)event { + ignore_momentum_scroll = true; + // Ignore all input if IME input is in progress if (!imeInputEventInProgress) { OS_OSX::KeyEvent ke; @@ -1359,6 +1364,13 @@ - (void)scrollWheel:(NSEvent *)event { deltaY *= 0.03; } + if ([event momentumPhase] != NSEventPhaseNone) { + if (ignore_momentum_scroll) { + return; + } + } else { + ignore_momentum_scroll = false; + } if ([event phase] != NSEventPhaseNone || [event momentumPhase] != NSEventPhaseNone) { sendPanEvent(deltaX, deltaY, [event modifierFlags]); } else {