|
|
@ -27,8 +27,10 @@ namespace MWInput
|
|
|
|
|
|
|
|
|
|
|
|
MWSDLInputWrapper::~MWSDLInputWrapper()
|
|
|
|
MWSDLInputWrapper::~MWSDLInputWrapper()
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
if(mSDLWindow != NULL)
|
|
|
|
SDL_DestroyWindow(mSDLWindow);
|
|
|
|
SDL_DestroyWindow(mSDLWindow);
|
|
|
|
mSDLWindow = NULL;
|
|
|
|
mSDLWindow = NULL;
|
|
|
|
|
|
|
|
SDL_StopTextInput();
|
|
|
|
SDL_Quit();
|
|
|
|
SDL_Quit();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -52,6 +54,8 @@ namespace MWInput
|
|
|
|
if(mSDLWindow == NULL)
|
|
|
|
if(mSDLWindow == NULL)
|
|
|
|
return false;
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
SDL_StartTextInput();
|
|
|
|
|
|
|
|
|
|
|
|
#if OGRE_PLATFORM == OGRE_PLATFORM_LINUX
|
|
|
|
#if OGRE_PLATFORM == OGRE_PLATFORM_LINUX
|
|
|
|
//linux-specific event-handling fixups
|
|
|
|
//linux-specific event-handling fixups
|
|
|
|
SDL_SysWMinfo wm_info;
|
|
|
|
SDL_SysWMinfo wm_info;
|
|
|
@ -119,7 +123,7 @@ namespace MWInput
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case SDL_KEYDOWN:
|
|
|
|
case SDL_KEYDOWN:
|
|
|
|
mKeyboardListener->keyPressed(evt.key);
|
|
|
|
_handleKeyPress(evt.key);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case SDL_KEYUP:
|
|
|
|
case SDL_KEYUP:
|
|
|
|
mKeyboardListener->keyReleased(evt.key);
|
|
|
|
mKeyboardListener->keyReleased(evt.key);
|
|
|
@ -228,4 +232,23 @@ namespace MWInput
|
|
|
|
warpMouse(width / 2, height / 2);
|
|
|
|
warpMouse(width / 2, height / 2);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void MWSDLInputWrapper::_handleKeyPress(SDL_KeyboardEvent &evt)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
//SDL keyboard events are followed by the actual text those keys would generate
|
|
|
|
|
|
|
|
//to account for languages that require multiple keystrokes to produce a key.
|
|
|
|
|
|
|
|
//Look for an event immediately following ours, assuming each key produces exactly
|
|
|
|
|
|
|
|
//one character.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//TODO: This won't work for multibyte characters, but MyGUI is the only consumer
|
|
|
|
|
|
|
|
//of these, does it even support multibyte characters?
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
SDL_Event text_evts[1];
|
|
|
|
|
|
|
|
if(SDL_PeepEvents(text_evts, 1, SDL_GETEVENT, SDL_TEXTINPUT, SDL_TEXTINPUT) != 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
evt.keysym.unicode = text_evts[0].text.text[0];
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mKeyboardListener->keyPressed(evt);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|