From c4d9a70fc30c895ca035bf720c82806b6e15ff97 Mon Sep 17 00:00:00 2001 From: mjbudd77 Date: Mon, 28 Feb 2022 20:29:56 -0500 Subject: [PATCH] Bug fix for Qt GUI mac OSX command and control key mappings. --- src/drivers/Qt/keyscan.cpp | 46 ++++++++++++++++++++++++++++---------- 1 file changed, 34 insertions(+), 12 deletions(-) diff --git a/src/drivers/Qt/keyscan.cpp b/src/drivers/Qt/keyscan.cpp index dda7e146..5aa598f3 100644 --- a/src/drivers/Qt/keyscan.cpp +++ b/src/drivers/Qt/keyscan.cpp @@ -59,9 +59,9 @@ static uint32_t MetaKeyCodeR = VK_RWIN; #elif defined(__APPLE__) static uint32_t ShiftKeyCodeR = 0x003C; -static uint32_t CtrlKeyCodeR = 0x0036; +static uint32_t CtrlKeyCodeR = 0x003E; static uint32_t AltKeyCodeR = 0x003D; -static uint32_t MetaKeyCodeR = 0x003B; +static uint32_t MetaKeyCodeR = 0x0036; #else static uint32_t ShiftKeyCodeR = 0xffe2; @@ -143,16 +143,7 @@ SDL_Scancode convQtKey2SDLScanCode(Qt::Key q, uint32_t nativeVirtualKey) } break; case Key_Control: - if ( nativeVirtualKey == CtrlKeyCodeR ) - { - s = SDL_SCANCODE_RCTRL; - } - else - { - s = SDL_SCANCODE_LCTRL; - } - break; - case Key_Meta: + #ifdef __APPLE__ if ( nativeVirtualKey == MetaKeyCodeR ) { s = SDL_SCANCODE_RGUI; @@ -161,6 +152,37 @@ SDL_Scancode convQtKey2SDLScanCode(Qt::Key q, uint32_t nativeVirtualKey) { s = SDL_SCANCODE_LGUI; } + #else + if ( nativeVirtualKey == CtrlKeyCodeR ) + { + s = SDL_SCANCODE_RCTRL; + } + else + { + s = SDL_SCANCODE_LCTRL; + } + #endif + break; + case Key_Meta: + #ifdef __APPLE__ + if ( nativeVirtualKey == CtrlKeyCodeR ) + { + s = SDL_SCANCODE_RCTRL; + } + else + { + s = SDL_SCANCODE_LCTRL; + } + #else + if ( nativeVirtualKey == MetaKeyCodeR ) + { + s = SDL_SCANCODE_RGUI; + } + else + { + s = SDL_SCANCODE_LGUI; + } + #endif break; case Key_Alt: if ( nativeVirtualKey == AltKeyCodeR )