Friggin' Windows remaps alphabetic keys based on keyboard layout.
We try to figure out what the actual layout independent values are. --HG-- extra : convert_revision : svn%3Ac70aab31-4412-0410-b14c-859654838e24/trunk%402723
This commit is contained in:
parent
69b676ff9d
commit
1a34de2773
3 changed files with 49 additions and 17 deletions
|
@ -54,17 +54,12 @@ RemapVKEY(WPARAM wParam, LPARAM lParam)
|
|||
We try to provide USB scancodes, so undo this mapping.
|
||||
*/
|
||||
if (wParam >= 'A' && wParam <= 'Z') {
|
||||
/* Alphabetic scancodes for PC keyboards */
|
||||
static BYTE scancodes[26] = {
|
||||
30, 48, 46, 32, 18, 33, 34, 35, 23, 36, 37, 38, 50, 49, 24,
|
||||
25, 16, 19, 31, 20, 22, 47, 17, 45, 21, 44
|
||||
};
|
||||
BYTE scancode = (lParam >> 16) & 0xFF;
|
||||
int i;
|
||||
|
||||
if (scancode != scancodes[wParam - 'A']) {
|
||||
for (i = 0; i < SDL_arraysize(scancodes); ++i) {
|
||||
if (scancode == scancodes[i]) {
|
||||
if (scancode != alpha_scancodes[wParam - 'A']) {
|
||||
for (i = 0; i < SDL_arraysize(alpha_scancodes); ++i) {
|
||||
if (scancode == alpha_scancodes[i]) {
|
||||
wParam = 'A' + i;
|
||||
break;
|
||||
}
|
||||
|
@ -448,6 +443,12 @@ WIN_WindowProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
|
|||
}
|
||||
return (0);
|
||||
|
||||
case WM_INPUTLANGCHANGE:
|
||||
{
|
||||
WIN_UpdateKeymap(data->videodata->keyboard);
|
||||
}
|
||||
return (1);
|
||||
|
||||
case WM_GETMINMAXINFO:
|
||||
{
|
||||
MINMAXINFO *info;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue