diff --git a/modules/juce_gui_basics/native/juce_linux_Windowing.cpp b/modules/juce_gui_basics/native/juce_linux_Windowing.cpp index 604fc0ce19..b4639660c0 100644 --- a/modules/juce_gui_basics/native/juce_linux_Windowing.cpp +++ b/modules/juce_gui_basics/native/juce_linux_Windowing.cpp @@ -982,6 +982,11 @@ public: //xxx todo! } + StringArray getAvailableRenderingEngines() override + { + return StringArray ("Software Renderer"); + } + void setMinimised (bool shouldBeMinimised) override { if (shouldBeMinimised) @@ -1328,6 +1333,42 @@ public: } } + static int getKeyCodeFromKeySym (KeySym sym) + { + switch (sym) + { + case XK_KP_Divide: return XK_slash; break; + case XK_KP_Multiply: return XK_asterisk; break; + case XK_KP_Subtract: return XK_hyphen; break; + case XK_KP_Add: return XK_plus; break; + case XK_KP_Enter: return XK_Return; break; + + case XK_KP_0: return XK_0; break; + case XK_KP_1: return XK_1; break; + case XK_KP_2: return XK_2; break; + case XK_KP_3: return XK_3; break; + case XK_KP_4: return XK_4; break; + case XK_KP_5: return XK_5; break; + case XK_KP_6: return XK_6; break; + case XK_KP_7: return XK_7; break; + case XK_KP_8: return XK_8; break; + case XK_KP_9: return XK_9; break; + + case XK_KP_Insert: return XK_Insert; break; + case XK_KP_Delete: return XK_Delete; break; + case XK_KP_End: return XK_End; break; + case XK_KP_Down: return XK_Down; break; + case XK_KP_Page_Down: return XK_Page_Down; break; + case XK_KP_Left: return XK_Left; break; + case XK_KP_Right: return XK_Right; break; + case XK_KP_Home: return XK_Home; break; + case XK_KP_Up: return XK_Up; break; + case XK_KP_Page_Up: return XK_Page_Up; break; + + default: break; + } + } + void handleKeyPressEvent (XKeyEvent& keyEvent) { char utf8 [64] = { 0 }; @@ -1361,26 +1402,37 @@ public: { switch (sym) // Translate keypad { + case XK_KP_Add: keyCode = XK_plus; break; + case XK_KP_Subtract: keyCode = XK_hyphen; break; case XK_KP_Divide: keyCode = XK_slash; break; case XK_KP_Multiply: keyCode = XK_asterisk; break; - case XK_KP_Subtract: keyCode = XK_hyphen; break; - case XK_KP_Add: keyCode = XK_plus; break; case XK_KP_Enter: keyCode = XK_Return; break; - case XK_KP_Decimal: keyCode = Keys::numLock ? XK_period : XK_Delete; break; - case XK_KP_0: keyCode = Keys::numLock ? XK_0 : XK_Insert; break; - case XK_KP_1: keyCode = Keys::numLock ? XK_1 : XK_End; break; - case XK_KP_2: keyCode = Keys::numLock ? XK_2 : XK_Down; break; - case XK_KP_3: keyCode = Keys::numLock ? XK_3 : XK_Page_Down; break; - case XK_KP_4: keyCode = Keys::numLock ? XK_4 : XK_Left; break; + case XK_KP_Insert: keyCode = XK_Insert; break; + case XK_KP_Delete: keyCode = XK_Delete; break; + case XK_KP_Left: keyCode = XK_Left; break; + case XK_KP_Right: keyCode = XK_Right; break; + case XK_KP_Up: keyCode = XK_Up; break; + case XK_KP_Down: keyCode = XK_Down; break; + case XK_KP_Home: keyCode = XK_Home; break; + case XK_KP_End: keyCode = XK_End; break; + case XK_KP_Page_Down: keyCode = XK_Page_Down; break; + case XK_KP_Page_Up: keyCode = XK_Page_Up; break; + + case XK_KP_0: keyCode = XK_0; break; + case XK_KP_1: keyCode = XK_1; break; + case XK_KP_2: keyCode = XK_2; break; + case XK_KP_3: keyCode = XK_3; break; + case XK_KP_4: keyCode = XK_4; break; case XK_KP_5: keyCode = XK_5; break; - case XK_KP_6: keyCode = Keys::numLock ? XK_6 : XK_Right; break; - case XK_KP_7: keyCode = Keys::numLock ? XK_7 : XK_Home; break; - case XK_KP_8: keyCode = Keys::numLock ? XK_8 : XK_Up; break; - case XK_KP_9: keyCode = Keys::numLock ? XK_9 : XK_Page_Up; break; + case XK_KP_6: keyCode = XK_6; break; + case XK_KP_7: keyCode = XK_7; break; + case XK_KP_8: keyCode = XK_8; break; + case XK_KP_9: keyCode = XK_9; break; + default: break; } - switch (sym) + switch (keyCode) { case XK_Left: case XK_Right: @@ -1393,7 +1445,7 @@ public: case XK_Delete: case XK_Insert: keyPressed = true; - keyCode = (sym & 0xff) | Keys::extendedKeyModifier; + keyCode = (keyCode & 0xff) | Keys::extendedKeyModifier; break; case XK_Tab: