Rip out OIS, fill the holes with SDL goodness. WIP.

actorid
Jordan Milne 12 years ago
parent e31cd1c805
commit 884d3ea4d8

@ -204,7 +204,7 @@ endif()
find_package(OGRE REQUIRED) find_package(OGRE REQUIRED)
find_package(MyGUI REQUIRED) find_package(MyGUI REQUIRED)
find_package(Boost REQUIRED COMPONENTS ${BOOST_COMPONENTS}) find_package(Boost REQUIRED COMPONENTS ${BOOST_COMPONENTS})
find_package(OIS REQUIRED) find_package(SDL2 REQUIRED)
find_package(OpenAL REQUIRED) find_package(OpenAL REQUIRED)
find_package(Bullet REQUIRED) find_package(Bullet REQUIRED)
IF(OGRE_STATIC) IF(OGRE_STATIC)
@ -218,7 +218,8 @@ ENDIF(OGRE_STATIC)
include_directories("." include_directories("."
${OGRE_INCLUDE_DIR} ${OGRE_INCLUDE_DIR}/Ogre ${OGRE_INCLUDE_DIR}/OGRE ${OGRE_PLUGIN_INCLUDE_DIRS} ${OGRE_INCLUDE_DIR} ${OGRE_INCLUDE_DIR}/Ogre ${OGRE_INCLUDE_DIR}/OGRE ${OGRE_PLUGIN_INCLUDE_DIRS}
${OGRE_Terrain_INCLUDE_DIR} ${OGRE_Terrain_INCLUDE_DIR}
${OIS_INCLUDE_DIRS} ${Boost_INCLUDE_DIR} ${SDL2_INCLUDE_DIR}
${Boost_INCLUDE_DIR}
${PLATFORM_INCLUDE_DIR} ${PLATFORM_INCLUDE_DIR}
${MYGUI_INCLUDE_DIRS} ${MYGUI_INCLUDE_DIRS}
${MYGUI_PLATFORM_INCLUDE_DIRS} ${MYGUI_PLATFORM_INCLUDE_DIRS}
@ -227,7 +228,7 @@ include_directories("."
${LIBDIR} ${LIBDIR}
) )
link_directories(${Boost_LIBRARY_DIRS} ${OGRE_LIB_DIR} ${MYGUI_LIB_DIR}) link_directories(${SDL2_LIBRARY_DIRS} ${Boost_LIBRARY_DIRS} ${OGRE_LIB_DIR} ${MYGUI_LIB_DIR})
if (APPLE) if (APPLE)
# List used Ogre plugins # List used Ogre plugins
@ -361,6 +362,7 @@ if(DPKG_PROGRAM)
SET(CPACK_DEBIAN_PACKAGE_NAME "openmw") SET(CPACK_DEBIAN_PACKAGE_NAME "openmw")
SET(CPACK_DEBIAN_PACKAGE_VERSION "${VERSION_STRING}") SET(CPACK_DEBIAN_PACKAGE_VERSION "${VERSION_STRING}")
SET(CPACK_PACKAGE_EXECUTABLES "openmw;OpenMW esmtool;Esmtool omwlauncher;OMWLauncher mwiniimporter;MWiniImporter") SET(CPACK_PACKAGE_EXECUTABLES "openmw;OpenMW esmtool;Esmtool omwlauncher;OMWLauncher mwiniimporter;MWiniImporter")
#TODO: should SDL2 be mentioned in here somewhere?
SET(CPACK_DEBIAN_PACKAGE_DEPENDS "libc6 (>= 2.11.2), libfreetype6 (>= 2.2.1), libgcc1 (>= 1:4.1.1), libmpg123-0 (>= 1.12.1), libois-1.3.0 (>= 1.3.0), libopenal1 (>= 1:1.12.854), libsndfile1 (>= 1.0.23), libstdc++6 (>= 4.4.5), libuuid1 (>= 2.17.2), libqtgui4 (>= 4.7.0)") SET(CPACK_DEBIAN_PACKAGE_DEPENDS "libc6 (>= 2.11.2), libfreetype6 (>= 2.2.1), libgcc1 (>= 1:4.1.1), libmpg123-0 (>= 1.12.1), libois-1.3.0 (>= 1.3.0), libopenal1 (>= 1:1.12.854), libsndfile1 (>= 1.0.23), libstdc++6 (>= 4.4.5), libuuid1 (>= 2.17.2), libqtgui4 (>= 4.7.0)")
SET(CPACK_DEBIAN_PACKAGE_SECTION "Games") SET(CPACK_DEBIAN_PACKAGE_SECTION "Games")

@ -20,7 +20,7 @@ add_openmw_dir (mwrender
) )
add_openmw_dir (mwinput add_openmw_dir (mwinput
inputmanagerimp inputmanagerimp sdlinputwrapper
) )
add_openmw_dir (mwgui add_openmw_dir (mwgui
@ -103,6 +103,7 @@ target_link_libraries(openmw
${SOUND_INPUT_LIBRARY} ${SOUND_INPUT_LIBRARY}
${BULLET_LIBRARIES} ${BULLET_LIBRARIES}
${MYGUI_LIBRARIES} ${MYGUI_LIBRARIES}
${SDL2_LIBRARY}
${MYGUI_PLATFORM_LIBRARIES} ${MYGUI_PLATFORM_LIBRARIES}
"shiny" "shiny"
"shiny.OgrePlatform" "shiny.OgrePlatform"

@ -9,8 +9,6 @@
#include <boost/lexical_cast.hpp> #include <boost/lexical_cast.hpp>
#include <OISInputManager.h>
#include <MyGUI_InputManager.h> #include <MyGUI_InputManager.h>
#include <MyGUI_RenderManager.h> #include <MyGUI_RenderManager.h>
#include <MyGUI_Widget.h> #include <MyGUI_Widget.h>
@ -25,6 +23,8 @@
#include "../mwbase/windowmanager.hpp" #include "../mwbase/windowmanager.hpp"
#include "../mwbase/soundmanager.hpp" #include "../mwbase/soundmanager.hpp"
using namespace ICS;
namespace MWInput namespace MWInput
{ {
InputManager::InputManager(OEngine::Render::OgreRenderer &ogre, InputManager::InputManager(OEngine::Render::OgreRenderer &ogre,
@ -59,14 +59,19 @@ namespace MWInput
window->getCustomAttribute("WINDOW", &windowHnd); window->getCustomAttribute("WINDOW", &windowHnd);
// Set non-exclusive mouse and keyboard input if the user requested
// it.
//TODO: re-enable this and make it work with SDL
/*
std::ostringstream windowHndStr; std::ostringstream windowHndStr;
OIS::ParamList pl; OIS::ParamList pl;
windowHndStr << windowHnd; windowHndStr << windowHnd;
pl.insert(std::make_pair(std::string("WINDOW"), windowHndStr.str())); pl.insert(std::make_pair(std::string("WINDOW"), windowHndStr.str()));
// Set non-exclusive mouse and keyboard input if the user requested
// it.
if (debug) if (debug)
{ {
#if defined OIS_WIN32_PLATFORM #if defined OIS_WIN32_PLATFORM
@ -89,6 +94,7 @@ namespace MWInput
std::string("true"))); std::string("true")));
#endif #endif
} }
*/
#if defined(__APPLE__) && !defined(__LP64__) #if defined(__APPLE__) && !defined(__LP64__)
// Give the application window focus to receive input events // Give the application window focus to receive input events
@ -97,23 +103,16 @@ namespace MWInput
SetFrontProcess(&psn); SetFrontProcess(&psn);
#endif #endif
mInputManager = OIS::InputManager::createInputSystem( pl ); mInputManager = new MWSDLInputWrapper(window);
mInputManager->setMouseEventCallback (this);
mInputManager->setKeyboardEventCallback (this);
// Create all devices std::string file = userFileExists ? userFile : "";
mKeyboard = static_cast<OIS::Keyboard*>(mInputManager->createInputObject mInputCtrl = new ICS::InputControlSystem(file, true, this, NULL, A_Last);
( OIS::OISKeyboard, true ));
mMouse = static_cast<OIS::Mouse*>(mInputManager->createInputObject
( OIS::OISMouse, true ));
mKeyboard->setEventCallback (this);
mMouse->setEventCallback (this);
adjustMouseRegion (window->getWidth(), window->getHeight()); adjustMouseRegion (window->getWidth(), window->getHeight());
MyGUI::InputManager::getInstance().injectMouseMove(mMouseX, mMouseY, mMouse->getMouseState ().Z.abs); MyGUI::InputManager::getInstance().injectMouseMove(mMouseX, mMouseY, 0);
std::string file = userFileExists ? userFile : "";
mInputCtrl = new ICS::InputControlSystem(file, true, this, NULL, A_Last);
loadKeyDefaults(); loadKeyDefaults();
@ -139,9 +138,7 @@ namespace MWInput
delete mInputCtrl; delete mInputCtrl;
mInputManager->destroyInputObject(mKeyboard); delete mInputManager;
mInputManager->destroyInputObject(mMouse);
OIS::InputManager::destroyInputSystem(mInputManager);
} }
void InputManager::channelChanged(ICS::Channel* channel, float currentValue, float previousValue) void InputManager::channelChanged(ICS::Channel* channel, float currentValue, float previousValue)
@ -240,8 +237,7 @@ namespace MWInput
void InputManager::update(float dt, bool loading) void InputManager::update(float dt, bool loading)
{ {
// Tell OIS to handle all input events // Tell OIS to handle all input events
mKeyboard->capture(); mInputManager->capture();
mMouse->capture();
// inject some fake mouse movement to force updating MyGUI's widget states // inject some fake mouse movement to force updating MyGUI's widget states
// this shouldn't do any harm since we're moving back to the original position afterwards // this shouldn't do any harm since we're moving back to the original position afterwards
@ -304,7 +300,7 @@ namespace MWInput
if (mControlSwitch["playerviewswitch"]) { if (mControlSwitch["playerviewswitch"]) {
// work around preview mode toggle when pressing Alt+Tab // work around preview mode toggle when pressing Alt+Tab
if (actionIsActive(A_TogglePOV) && !mKeyboard->isModifierDown (OIS::Keyboard::Alt)) { if (actionIsActive(A_TogglePOV) && !mInputManager->isModifierHeld(KMOD_ALT)) {
if (mPreviewPOVDelay <= 0.5 && if (mPreviewPOVDelay <= 0.5 &&
(mPreviewPOVDelay += dt) > 0.5) (mPreviewPOVDelay += dt) > 0.5)
{ {
@ -419,37 +415,38 @@ namespace MWInput
void InputManager::adjustMouseRegion(int width, int height) void InputManager::adjustMouseRegion(int width, int height)
{ {
const OIS::MouseState &ms = mMouse->getMouseState(); mInputCtrl->adjustMouseRegion(width, height);
ms.width = width;
ms.height = height;
} }
bool InputManager::keyPressed( const OIS::KeyEvent &arg ) bool InputManager::keyPressed( const SDL_KeyboardEvent &arg )
{ {
mInputCtrl->keyPressed (arg); mInputCtrl->keyPressed (arg);
unsigned int text = arg.text; unsigned int text = arg.keysym.unicode;
//TODO: Check if we need this with SDL
/*
#ifdef __APPLE__ // filter \016 symbol for F-keys on OS X #ifdef __APPLE__ // filter \016 symbol for F-keys on OS X
if ((arg.key >= OIS::KC_F1 && arg.key <= OIS::KC_F10) || if ((arg.key >= SDLK_F1 && arg.key <= SDLK_F10) ||
(arg.key >= OIS::KC_F11 && arg.key <= OIS::KC_F15)) { (arg.key >= SDLK_F11 && arg.key <= SDLK_F15)) {
text = 0; text = 0;
} }
#endif #endif
*/
MyGUI::InputManager::getInstance().injectKeyPress(MyGUI::KeyCode::Enum(arg.key), text); MyGUI::InputManager::getInstance().injectKeyPress(MyGUI::KeyCode::Enum(arg.keysym.sym), text);
return true; return true;
} }
bool InputManager::keyReleased( const OIS::KeyEvent &arg ) bool InputManager::keyReleased(const SDL_KeyboardEvent &arg )
{ {
mInputCtrl->keyReleased (arg); mInputCtrl->keyReleased (arg);
MyGUI::InputManager::getInstance().injectKeyRelease(MyGUI::KeyCode::Enum(arg.key)); MyGUI::InputManager::getInstance().injectKeyRelease(MyGUI::KeyCode::Enum(arg.keysym.sym));
return true; return true;
} }
bool InputManager::mousePressed( const OIS::MouseEvent &arg, OIS::MouseButtonID id ) bool InputManager::mousePressed( const SDL_MouseButtonEvent &arg, Uint8 id )
{ {
mInputCtrl->mousePressed (arg, id); mInputCtrl->mousePressed (arg, id);
@ -467,7 +464,7 @@ namespace MWInput
return true; return true;
} }
bool InputManager::mouseReleased( const OIS::MouseEvent &arg, OIS::MouseButtonID id ) bool InputManager::mouseReleased( const SDL_MouseButtonEvent &arg, Uint8 id )
{ {
mInputCtrl->mouseReleased (arg, id); mInputCtrl->mouseReleased (arg, id);
@ -476,7 +473,7 @@ namespace MWInput
return true; return true;
} }
bool InputManager::mouseMoved( const OIS::MouseEvent &arg ) bool InputManager::mouseMoved( const ICS::MWSDLMouseMotionEvent &arg )
{ {
mInputCtrl->mouseMoved (arg); mInputCtrl->mouseMoved (arg);
@ -488,11 +485,13 @@ namespace MWInput
// We keep track of our own mouse position, so that moving the mouse while in // We keep track of our own mouse position, so that moving the mouse while in
// game mode does not move the position of the GUI cursor // game mode does not move the position of the GUI cursor
mMouseX += float(arg.state.X.rel) * mUISensitivity; mMouseX += float(arg.xrel) * mUISensitivity;
mMouseY += float(arg.state.Y.rel) * mUISensitivity * mUIYMultiplier; mMouseY += float(arg.yrel) * mUISensitivity * mUIYMultiplier;
mMouseX = std::max(0.f, std::min(mMouseX, float(viewSize.width))); mMouseX = std::max(0.f, std::min(mMouseX, float(viewSize.width)));
mMouseY = std::max(0.f, std::min(mMouseY, float(viewSize.height))); mMouseY = std::max(0.f, std::min(mMouseY, float(viewSize.height)));
mMouseWheel = arg.state.Z.abs;
//there's no such thing as an absolute z position, so let's keep track of it ourselves
mMouseWheel += arg.zrel;
MyGUI::InputManager::getInstance().injectMouseMove( int(mMouseX), int(mMouseY), mMouseWheel); MyGUI::InputManager::getInstance().injectMouseMove( int(mMouseX), int(mMouseY), mMouseWheel);
} }
@ -501,8 +500,8 @@ namespace MWInput
{ {
resetIdleTime(); resetIdleTime();
float x = arg.state.X.rel * mCameraSensitivity * 0.2; float x = arg.xrel * mCameraSensitivity * 0.2;
float y = arg.state.Y.rel * mCameraSensitivity * 0.2 * (mInvertY ? -1 : 1) * mUIYMultiplier; float y = arg.yrel * mCameraSensitivity * 0.2 * (mInvertY ? -1 : 1) * mUIYMultiplier;
MWBase::World *world = MWBase::Environment::get().getWorld(); MWBase::World *world = MWBase::Environment::get().getWorld();
world->rotateObject(world->getPlayer().getPlayer(), -y, 0.f, x, true); world->rotateObject(world->getPlayer().getPlayer(), -y, 0.f, x, true);
@ -679,38 +678,38 @@ namespace MWInput
// across different versions of OpenMW (in the case where another input action is added) // across different versions of OpenMW (in the case where another input action is added)
std::map<int, int> defaultKeyBindings; std::map<int, int> defaultKeyBindings;
defaultKeyBindings[A_Activate] = OIS::KC_SPACE; defaultKeyBindings[A_Activate] = SDLK_SPACE;
defaultKeyBindings[A_MoveBackward] = OIS::KC_S; defaultKeyBindings[A_MoveBackward] = SDLK_s;
defaultKeyBindings[A_MoveForward] = OIS::KC_W; defaultKeyBindings[A_MoveForward] = SDLK_w;
defaultKeyBindings[A_MoveLeft] = OIS::KC_A; defaultKeyBindings[A_MoveLeft] = SDLK_a;
defaultKeyBindings[A_MoveRight] = OIS::KC_D; defaultKeyBindings[A_MoveRight] = SDLK_d;
defaultKeyBindings[A_ToggleWeapon] = OIS::KC_F; defaultKeyBindings[A_ToggleWeapon] = SDLK_f;
defaultKeyBindings[A_ToggleSpell] = OIS::KC_R; defaultKeyBindings[A_ToggleSpell] = SDLK_r;
defaultKeyBindings[A_QuickKeysMenu] = OIS::KC_F1; defaultKeyBindings[A_QuickKeysMenu] = SDLK_F1;
defaultKeyBindings[A_Console] = OIS::KC_F2; defaultKeyBindings[A_Console] = SDLK_F2;
defaultKeyBindings[A_Crouch] = OIS::KC_LCONTROL; defaultKeyBindings[A_Crouch] = SDLK_LCTRL;
defaultKeyBindings[A_AutoMove] = OIS::KC_Q; defaultKeyBindings[A_AutoMove] = SDLK_q;
defaultKeyBindings[A_Jump] = OIS::KC_E; defaultKeyBindings[A_Jump] = SDLK_e;
defaultKeyBindings[A_Journal] = OIS::KC_J; defaultKeyBindings[A_Journal] = SDLK_j;
defaultKeyBindings[A_Rest] = OIS::KC_T; defaultKeyBindings[A_Rest] = SDLK_t;
defaultKeyBindings[A_GameMenu] = OIS::KC_ESCAPE; defaultKeyBindings[A_GameMenu] = SDLK_ESCAPE;
defaultKeyBindings[A_TogglePOV] = OIS::KC_TAB; defaultKeyBindings[A_TogglePOV] = SDLK_TAB;
defaultKeyBindings[A_QuickKey1] = OIS::KC_1; defaultKeyBindings[A_QuickKey1] = SDLK_1;
defaultKeyBindings[A_QuickKey2] = OIS::KC_2; defaultKeyBindings[A_QuickKey2] = SDLK_2;
defaultKeyBindings[A_QuickKey3] = OIS::KC_3; defaultKeyBindings[A_QuickKey3] = SDLK_3;
defaultKeyBindings[A_QuickKey4] = OIS::KC_4; defaultKeyBindings[A_QuickKey4] = SDLK_4;
defaultKeyBindings[A_QuickKey5] = OIS::KC_5; defaultKeyBindings[A_QuickKey5] = SDLK_5;
defaultKeyBindings[A_QuickKey6] = OIS::KC_6; defaultKeyBindings[A_QuickKey6] = SDLK_6;
defaultKeyBindings[A_QuickKey7] = OIS::KC_7; defaultKeyBindings[A_QuickKey7] = SDLK_7;
defaultKeyBindings[A_QuickKey8] = OIS::KC_8; defaultKeyBindings[A_QuickKey8] = SDLK_8;
defaultKeyBindings[A_QuickKey9] = OIS::KC_9; defaultKeyBindings[A_QuickKey9] = SDLK_9;
defaultKeyBindings[A_QuickKey10] = OIS::KC_0; defaultKeyBindings[A_QuickKey10] = SDLK_0;
defaultKeyBindings[A_Screenshot] = OIS::KC_SYSRQ; defaultKeyBindings[A_Screenshot] = SDLK_SYSREQ;
defaultKeyBindings[A_ToggleHUD] = OIS::KC_F12; defaultKeyBindings[A_ToggleHUD] = SDLK_F12;
std::map<int, int> defaultMouseButtonBindings; std::map<int, int> defaultMouseButtonBindings;
defaultMouseButtonBindings[A_Inventory] = OIS::MB_Right; defaultMouseButtonBindings[A_Inventory] = SDL_BUTTON_RIGHT;
defaultMouseButtonBindings[A_Use] = OIS::MB_Left; defaultMouseButtonBindings[A_Use] = SDL_BUTTON_LEFT;
for (int i = 0; i < A_Last; ++i) for (int i = 0; i < A_Last; ++i)
{ {
@ -728,14 +727,14 @@ namespace MWInput
} }
if (!controlExists || force || if (!controlExists || force ||
( mInputCtrl->getKeyBinding (control, ICS::Control::INCREASE) == OIS::KC_UNASSIGNED ( mInputCtrl->getKeyBinding (control, ICS::Control::INCREASE) == SDLK_UNKNOWN
&& mInputCtrl->getMouseButtonBinding (control, ICS::Control::INCREASE) == ICS_MAX_DEVICE_BUTTONS && mInputCtrl->getMouseButtonBinding (control, ICS::Control::INCREASE) == ICS_MAX_DEVICE_BUTTONS
)) ))
{ {
clearAllBindings (control); clearAllBindings (control);
if (defaultKeyBindings.find(i) != defaultKeyBindings.end()) if (defaultKeyBindings.find(i) != defaultKeyBindings.end())
mInputCtrl->addKeyBinding(control, static_cast<OIS::KeyCode>(defaultKeyBindings[i]), ICS::Control::INCREASE); mInputCtrl->addKeyBinding(control, static_cast<SDL_Keycode>(defaultKeyBindings[i]), ICS::Control::INCREASE);
else if (defaultMouseButtonBindings.find(i) != defaultMouseButtonBindings.end()) else if (defaultMouseButtonBindings.find(i) != defaultMouseButtonBindings.end())
mInputCtrl->addMouseButtonBinding (control, defaultMouseButtonBindings[i], ICS::Control::INCREASE); mInputCtrl->addMouseButtonBinding (control, defaultMouseButtonBindings[i], ICS::Control::INCREASE);
} }
@ -786,7 +785,7 @@ namespace MWInput
ICS::Control* c = mInputCtrl->getChannel (action)->getAttachedControls ().front().control; ICS::Control* c = mInputCtrl->getChannel (action)->getAttachedControls ().front().control;
if (mInputCtrl->getKeyBinding (c, ICS::Control::INCREASE) != OIS::KC_UNASSIGNED) if (mInputCtrl->getKeyBinding (c, ICS::Control::INCREASE) != SDLK_UNKNOWN)
return mInputCtrl->keyCodeToString (mInputCtrl->getKeyBinding (c, ICS::Control::INCREASE)); return mInputCtrl->keyCodeToString (mInputCtrl->getKeyBinding (c, ICS::Control::INCREASE));
else if (mInputCtrl->getMouseButtonBinding (c, ICS::Control::INCREASE) != ICS_MAX_DEVICE_BUTTONS) else if (mInputCtrl->getMouseButtonBinding (c, ICS::Control::INCREASE) != ICS_MAX_DEVICE_BUTTONS)
return "#{sMouse} " + boost::lexical_cast<std::string>(mInputCtrl->getMouseButtonBinding (c, ICS::Control::INCREASE)); return "#{sMouse} " + boost::lexical_cast<std::string>(mInputCtrl->getMouseButtonBinding (c, ICS::Control::INCREASE));
@ -842,7 +841,7 @@ namespace MWInput
} }
void InputManager::keyBindingDetected(ICS::InputControlSystem* ICS, ICS::Control* control void InputManager::keyBindingDetected(ICS::InputControlSystem* ICS, ICS::Control* control
, OIS::KeyCode key, ICS::Control::ControlChangingDirection direction) , SDL_Keycode key, ICS::Control::ControlChangingDirection direction)
{ {
clearAllBindings(control); clearAllBindings(control);
ICS::DetectingBindingListener::keyBindingDetected (ICS, control, key, direction); ICS::DetectingBindingListener::keyBindingDetected (ICS, control, key, direction);
@ -892,7 +891,7 @@ namespace MWInput
void InputManager::clearAllBindings (ICS::Control* control) void InputManager::clearAllBindings (ICS::Control* control)
{ {
// right now we don't really need multiple bindings for the same action, so remove all others first // right now we don't really need multiple bindings for the same action, so remove all others first
if (mInputCtrl->getKeyBinding (control, ICS::Control::INCREASE) != OIS::KC_UNASSIGNED) if (mInputCtrl->getKeyBinding (control, ICS::Control::INCREASE) != SDLK_UNKNOWN)
mInputCtrl->removeKeyBinding (mInputCtrl->getKeyBinding (control, ICS::Control::INCREASE)); mInputCtrl->removeKeyBinding (mInputCtrl->getKeyBinding (control, ICS::Control::INCREASE));
if (mInputCtrl->getMouseButtonBinding (control, ICS::Control::INCREASE) != ICS_MAX_DEVICE_BUTTONS) if (mInputCtrl->getMouseButtonBinding (control, ICS::Control::INCREASE) != ICS_MAX_DEVICE_BUTTONS)
mInputCtrl->removeMouseButtonBinding (mInputCtrl->getMouseButtonBinding (control, ICS::Control::INCREASE)); mInputCtrl->removeMouseButtonBinding (mInputCtrl->getMouseButtonBinding (control, ICS::Control::INCREASE));

@ -6,6 +6,7 @@
#include <components/settings/settings.hpp> #include <components/settings/settings.hpp>
#include "../mwbase/inputmanager.hpp" #include "../mwbase/inputmanager.hpp"
#include "sdlinputwrapper.hpp"
namespace OEngine namespace OEngine
{ {
@ -35,18 +36,9 @@ namespace ICS
class InputControlSystem; class InputControlSystem;
} }
namespace OIS
{
class Keyboard;
class Mouse;
class InputManager;
}
#include <OISKeyboard.h>
#include <OISMouse.h>
#include <extern/oics/ICSChannelListener.h> #include <extern/oics/ICSChannelListener.h>
#include <extern/oics/ICSInputControlSystem.h> #include <extern/oics/ICSInputControlSystem.h>
#include <extern/oics/OISCompat.h>
namespace MWInput namespace MWInput
{ {
@ -54,7 +46,12 @@ namespace MWInput
/** /**
* @brief Class that handles all input and key bindings for OpenMW. * @brief Class that handles all input and key bindings for OpenMW.
*/ */
class InputManager : public MWBase::InputManager, public OIS::KeyListener, public OIS::MouseListener, public ICS::ChannelListener, public ICS::DetectingBindingListener class InputManager :
public MWBase::InputManager,
public ICS::MWSDLKeyListener,
public ICS::MWSDLMouseListener,
public ICS::ChannelListener,
public ICS::DetectingBindingListener
{ {
public: public:
InputManager(OEngine::Render::OgreRenderer &_ogre, InputManager(OEngine::Render::OgreRenderer &_ogre,
@ -85,12 +82,12 @@ namespace MWInput
virtual void resetToDefaultBindings(); virtual void resetToDefaultBindings();
public: public:
virtual bool keyPressed( const OIS::KeyEvent &arg ); virtual bool keyPressed(const SDL_KeyboardEvent &arg );
virtual bool keyReleased( const OIS::KeyEvent &arg ); virtual bool keyReleased( const SDL_KeyboardEvent &arg );
virtual bool mousePressed( const OIS::MouseEvent &arg, OIS::MouseButtonID id ); virtual bool mousePressed( const SDL_MouseButtonEvent &arg, Uint8 id );
virtual bool mouseReleased( const OIS::MouseEvent &arg, OIS::MouseButtonID id ); virtual bool mouseReleased( const SDL_MouseButtonEvent &arg, Uint8 id );
virtual bool mouseMoved( const OIS::MouseEvent &arg ); virtual bool mouseMoved( const ICS::MWSDLMouseMotionEvent &arg );
virtual void channelChanged(ICS::Channel* channel, float currentValue, float previousValue); virtual void channelChanged(ICS::Channel* channel, float currentValue, float previousValue);
@ -98,7 +95,7 @@ namespace MWInput
, ICS::InputControlSystem::NamedAxis axis, ICS::Control::ControlChangingDirection direction); , ICS::InputControlSystem::NamedAxis axis, ICS::Control::ControlChangingDirection direction);
virtual void keyBindingDetected(ICS::InputControlSystem* ICS, ICS::Control* control virtual void keyBindingDetected(ICS::InputControlSystem* ICS, ICS::Control* control
, OIS::KeyCode key, ICS::Control::ControlChangingDirection direction); , SDL_Keycode key, ICS::Control::ControlChangingDirection direction);
virtual void mouseButtonBindingDetected(ICS::InputControlSystem* ICS, ICS::Control* control virtual void mouseButtonBindingDetected(ICS::InputControlSystem* ICS, ICS::Control* control
, unsigned int button, ICS::Control::ControlChangingDirection direction); , unsigned int button, ICS::Control::ControlChangingDirection direction);
@ -125,9 +122,8 @@ namespace MWInput
ICS::InputControlSystem* mInputCtrl; ICS::InputControlSystem* mInputCtrl;
OIS::Keyboard* mKeyboard;
OIS::Mouse* mMouse; MWSDLInputWrapper* mInputManager;
OIS::InputManager* mInputManager;
std::string mUserFile; std::string mUserFile;

@ -0,0 +1,70 @@
#include "sdlinputwrapper.hpp"
#include <SDL2/SDL.h>
namespace MWInput
{
MWSDLInputWrapper::MWSDLInputWrapper(Ogre::RenderWindow *window) :
mWindow(window), mStarted(false), mSDLWindow(NULL)
{
_start();
}
MWSDLInputWrapper::~MWSDLInputWrapper()
{
SDL_DestroyWindow(mSDLWindow);
mSDLWindow = NULL;
SDL_Quit();
}
void MWSDLInputWrapper::capture()
{
_start();
SDL_Event evt;
while(SDL_PollEvent(&evt))
{
switch(evt.type)
{
case SDL_MOUSEMOTION:
mMouseListener->mouseMoved(ICS::MWSDLMouseMotionEvent(evt.motion));
break;
case SDL_MOUSEWHEEL:
mMouseListener->mouseMoved(ICS::MWSDLMouseMotionEvent(evt.wheel));
break;
case SDL_MOUSEBUTTONDOWN:
mMouseListener->mousePressed(evt.button, evt.button.button);
break;
case SDL_MOUSEBUTTONUP:
mMouseListener->mouseReleased(evt.button, evt.button.button);
break;
case SDL_KEYDOWN:
mKeyboardListener->keyPressed(evt.key);
break;
case SDL_KEYUP:
mKeyboardListener->keyReleased(evt.key);
break;
}
}
}
bool MWSDLInputWrapper::isModifierHeld(int mod)
{
return SDL_GetModState() & mod;
}
void MWSDLInputWrapper::_start()
{
Uint32 flags = SDL_INIT_VIDEO;
if(SDL_WasInit(flags) == 0)
{
//get the HWND from ogre's renderwindow
size_t windowHnd;
mWindow->getCustomAttribute("WINDOW", &windowHnd);
//just use that one for input
SDL_Init(flags);
mSDLWindow = SDL_CreateWindowFrom((void*)windowHnd);
}
}
}

@ -0,0 +1,35 @@
#ifndef _MWINPUT_SDLINPUTWRAPPER_H
#define _MWINPUT_SDLINPUTWRAPPER_H
#include "SDL2/SDL_events.h"
#include <extern/oics/OISCompat.h>
#include <OGRE/OgreRenderWindow.h>
namespace MWInput
{
class MWSDLInputWrapper
{
public:
MWSDLInputWrapper(Ogre::RenderWindow* window);
~MWSDLInputWrapper();
void setMouseEventCallback(ICS::MWSDLMouseListener* listen) { mMouseListener = listen; }
void setKeyboardEventCallback(ICS::MWSDLKeyListener* listen) { mKeyboardListener = listen; }
void capture();
bool isModifierHeld(int mod);
private:
ICS::MWSDLMouseListener* mMouseListener;
ICS::MWSDLKeyListener* mKeyboardListener;
Ogre::RenderWindow* mWindow;
SDL_Window* mSDLWindow;
bool mStarted;
void _start();
};
}
#endif

@ -0,0 +1,180 @@
# Locate SDL2 library
# This module defines
# SDL2_LIBRARY, the name of the library to link against
# SDL2_FOUND, if false, do not try to link to SDL2
# SDL2_INCLUDE_DIR, where to find SDL.h
#
# This module responds to the the flag:
# SDL2_BUILDING_LIBRARY
# If this is defined, then no SDL2_main will be linked in because
# only applications need main().
# Otherwise, it is assumed you are building an application and this
# module will attempt to locate and set the the proper link flags
# as part of the returned SDL2_LIBRARY variable.
#
# Don't forget to include SDL2main.h and SDL2main.m your project for the
# OS X framework based version. (Other versions link to -lSDL2main which
# this module will try to find on your behalf.) Also for OS X, this
# module will automatically add the -framework Cocoa on your behalf.
#
#
# Additional Note: If you see an empty SDL2_LIBRARY_TEMP in your configuration
# and no SDL2_LIBRARY, it means CMake did not find your SDL2 library
# (SDL2.dll, libsdl2.so, SDL2.framework, etc).
# Set SDL2_LIBRARY_TEMP to point to your SDL2 library, and configure again.
# Similarly, if you see an empty SDL2MAIN_LIBRARY, you should set this value
# as appropriate. These values are used to generate the final SDL2_LIBRARY
# variable, but when these values are unset, SDL2_LIBRARY does not get created.
#
#
# $SDL2DIR is an environment variable that would
# correspond to the ./configure --prefix=$SDL2DIR
# used in building SDL2.
# l.e.galup 9-20-02
#
# Modified by Eric Wing.
# Added code to assist with automated building by using environmental variables
# and providing a more controlled/consistent search behavior.
# Added new modifications to recognize OS X frameworks and
# additional Unix paths (FreeBSD, etc).
# Also corrected the header search path to follow "proper" SDL2 guidelines.
# Added a search for SDL2main which is needed by some platforms.
# Added a search for threads which is needed by some platforms.
# Added needed compile switches for MinGW.
#
# On OSX, this will prefer the Framework version (if found) over others.
# People will have to manually change the cache values of
# SDL2_LIBRARY to override this selection or set the CMake environment
# CMAKE_INCLUDE_PATH to modify the search paths.
#
# Note that the header path has changed from SDL2/SDL.h to just SDL.h
# This needed to change because "proper" SDL2 convention
# is #include "SDL.h", not <SDL2/SDL.h>. This is done for portability
# reasons because not all systems place things in SDL2/ (see FreeBSD).
#
# Ported by Johnny Patterson. This is a literal port for SDL2 of the FindSDL.cmake
# module with the minor edit of changing "SDL" to "SDL2" where necessary. This
# was not created for redistribution, and exists temporarily pending official
# SDL2 CMake modules.
#=============================================================================
# Copyright 2003-2009 Kitware, Inc.
#
# Distributed under the OSI-approved BSD License (the "License");
# see accompanying file Copyright.txt for details.
#
# This software is distributed WITHOUT ANY WARRANTY; without even the
# implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
# See the License for more information.
#=============================================================================
# (To distribute this file outside of CMake, substitute the full
# License text for the above reference.)
FIND_PATH(SDL2_INCLUDE_DIR SDL.h
HINTS
$ENV{SDL2DIR}
PATH_SUFFIXES include/SDL2 include
PATHS
~/Library/Frameworks
/Library/Frameworks
/usr/local/include/SDL2
/usr/include/SDL2
/sw # Fink
/opt/local # DarwinPorts
/opt/csw # Blastwave
/opt
)
#MESSAGE("SDL2_INCLUDE_DIR is ${SDL2_INCLUDE_DIR}")
FIND_LIBRARY(SDL2_LIBRARY_TEMP
NAMES SDL2
HINTS
$ENV{SDL2DIR}
PATH_SUFFIXES lib64 lib
PATHS
/sw
/opt/local
/opt/csw
/opt
)
#MESSAGE("SDL2_LIBRARY_TEMP is ${SDL2_LIBRARY_TEMP}")
IF(NOT SDL2_BUILDING_LIBRARY)
IF(NOT ${SDL2_INCLUDE_DIR} MATCHES ".framework")
# Non-OS X framework versions expect you to also dynamically link to
# SDL2main. This is mainly for Windows and OS X. Other (Unix) platforms
# seem to provide SDL2main for compatibility even though they don't
# necessarily need it.
FIND_LIBRARY(SDL2MAIN_LIBRARY
NAMES SDL2main
HINTS
$ENV{SDL2DIR}
PATH_SUFFIXES lib64 lib
PATHS
/sw
/opt/local
/opt/csw
/opt
)
ENDIF(NOT ${SDL2_INCLUDE_DIR} MATCHES ".framework")
ENDIF(NOT SDL2_BUILDING_LIBRARY)
# SDL2 may require threads on your system.
# The Apple build may not need an explicit flag because one of the
# frameworks may already provide it.
# But for non-OSX systems, I will use the CMake Threads package.
IF(NOT APPLE)
FIND_PACKAGE(Threads)
ENDIF(NOT APPLE)
# MinGW needs an additional library, mwindows
# It's total link flags should look like -lmingw32 -lSDL2main -lSDL2 -lmwindows
# (Actually on second look, I think it only needs one of the m* libraries.)
IF(MINGW)
SET(MINGW32_LIBRARY mingw32 CACHE STRING "mwindows for MinGW")
ENDIF(MINGW)
SET(SDL2_FOUND "NO")
IF(SDL2_LIBRARY_TEMP)
# For SDL2main
IF(NOT SDL2_BUILDING_LIBRARY)
IF(SDL2MAIN_LIBRARY)
SET(SDL2_LIBRARY_TEMP ${SDL2MAIN_LIBRARY} ${SDL2_LIBRARY_TEMP})
ENDIF(SDL2MAIN_LIBRARY)
ENDIF(NOT SDL2_BUILDING_LIBRARY)
# For OS X, SDL2 uses Cocoa as a backend so it must link to Cocoa.
# CMake doesn't display the -framework Cocoa string in the UI even
# though it actually is there if I modify a pre-used variable.
# I think it has something to do with the CACHE STRING.
# So I use a temporary variable until the end so I can set the
# "real" variable in one-shot.
IF(APPLE)
SET(SDL2_LIBRARY_TEMP ${SDL2_LIBRARY_TEMP} "-framework Cocoa")
ENDIF(APPLE)
# For threads, as mentioned Apple doesn't need this.
# In fact, there seems to be a problem if I used the Threads package
# and try using this line, so I'm just skipping it entirely for OS X.
IF(NOT APPLE)
SET(SDL2_LIBRARY_TEMP ${SDL2_LIBRARY_TEMP} ${CMAKE_THREAD_LIBS_INIT})
ENDIF(NOT APPLE)
# For MinGW library
IF(MINGW)
SET(SDL2_LIBRARY_TEMP ${MINGW32_LIBRARY} ${SDL2_LIBRARY_TEMP})
ENDIF(MINGW)
# Set the final string here so the GUI reflects the final state.
SET(SDL2_LIBRARY ${SDL2_LIBRARY_TEMP} CACHE STRING "Where the SDL2 Library can be found")
# Set the temp variable to INTERNAL so it is not seen in the CMake GUI
SET(SDL2_LIBRARY_TEMP "${SDL2_LIBRARY_TEMP}" CACHE INTERNAL "")
SET(SDL2_FOUND "YES")
ENDIF(SDL2_LIBRARY_TEMP)
INCLUDE(FindPackageHandleStandardArgs)
FIND_PACKAGE_HANDLE_STANDARD_ARGS(SDL2
REQUIRED_VARS SDL2_LIBRARY SDL2_INCLUDE_DIR)

@ -9,6 +9,7 @@ set(OICS_SOURCE_FILES
ICSInputControlSystem_keyboard.cpp ICSInputControlSystem_keyboard.cpp
ICSInputControlSystem_mouse.cpp ICSInputControlSystem_mouse.cpp
ICSInputControlSystem_joystick.cpp ICSInputControlSystem_joystick.cpp
OISCompat.h
tinyxml.cpp tinyxml.cpp
tinyxmlparser.cpp tinyxmlparser.cpp
tinyxmlerror.cpp tinyxmlerror.cpp

@ -41,7 +41,7 @@ namespace ICS
this->mActive = active; this->mActive = active;
this->fillOISKeysMap(); this->fillSDLKeysMap();
ICS_LOG("Channel count = " + ToString<size_t>(channelCount) ); ICS_LOG("Channel count = " + ToString<size_t>(channelCount) );
for(size_t i=0;i<channelCount;i++) for(size_t i=0;i<channelCount;i++)
@ -429,7 +429,7 @@ namespace ICS
control.SetAttribute( "axisBindable", "false" ); control.SetAttribute( "axisBindable", "false" );
} }
if(getKeyBinding(*o, Control/*::ControlChangingDirection*/::INCREASE) != OIS::KC_UNASSIGNED) if(getKeyBinding(*o, Control/*::ControlChangingDirection*/::INCREASE) != SDLK_UNKNOWN)
{ {
TiXmlElement keyBinder( "KeyBinder" ); TiXmlElement keyBinder( "KeyBinder" );
@ -439,7 +439,7 @@ namespace ICS
control.InsertEndChild(keyBinder); control.InsertEndChild(keyBinder);
} }
if(getKeyBinding(*o, Control/*::ControlChangingDirection*/::DECREASE) != OIS::KC_UNASSIGNED) if(getKeyBinding(*o, Control/*::ControlChangingDirection*/::DECREASE) != SDLK_UNKNOWN)
{ {
TiXmlElement keyBinder( "KeyBinder" ); TiXmlElement keyBinder( "KeyBinder" );
@ -503,15 +503,15 @@ namespace ICS
TiXmlElement binder( "MouseButtonBinder" ); TiXmlElement binder( "MouseButtonBinder" );
unsigned int button = getMouseButtonBinding(*o, Control/*::ControlChangingDirection*/::INCREASE); unsigned int button = getMouseButtonBinding(*o, Control/*::ControlChangingDirection*/::INCREASE);
if(button == OIS::/*MouseButtonID::*/MB_Left) if(button == SDL_BUTTON_LEFT)
{ {
binder.SetAttribute( "button", "LEFT" ); binder.SetAttribute( "button", "LEFT" );
} }
else if(button == OIS::/*MouseButtonID::*/MB_Middle) else if(button == SDL_BUTTON_MIDDLE)
{ {
binder.SetAttribute( "button", "MIDDLE" ); binder.SetAttribute( "button", "MIDDLE" );
} }
else if(button == OIS::/*MouseButtonID::*/MB_Right) else if(button == SDL_BUTTON_RIGHT)
{ {
binder.SetAttribute( "button", "RIGHT" ); binder.SetAttribute( "button", "RIGHT" );
} }
@ -529,15 +529,15 @@ namespace ICS
TiXmlElement binder( "MouseButtonBinder" ); TiXmlElement binder( "MouseButtonBinder" );
unsigned int button = getMouseButtonBinding(*o, Control/*::ControlChangingDirection*/::DECREASE); unsigned int button = getMouseButtonBinding(*o, Control/*::ControlChangingDirection*/::DECREASE);
if(button == OIS::/*MouseButtonID::*/MB_Left) if(button == SDL_BUTTON_LEFT)
{ {
binder.SetAttribute( "button", "LEFT" ); binder.SetAttribute( "button", "LEFT" );
} }
else if(button == OIS::/*MouseButtonID::*/MB_Middle) else if(button == SDL_BUTTON_MIDDLE)
{ {
binder.SetAttribute( "button", "MIDDLE" ); binder.SetAttribute( "button", "MIDDLE" );
} }
else if(button == OIS::/*MouseButtonID::*/MB_Right) else if(button == SDL_BUTTON_RIGHT)
{ {
binder.SetAttribute( "button", "RIGHT" ); binder.SetAttribute( "button", "RIGHT" );
} }
@ -801,129 +801,132 @@ namespace ICS
mDetectingBindingControl = NULL; mDetectingBindingControl = NULL;
} }
void InputControlSystem::fillOISKeysMap() void InputControlSystem::fillSDLKeysMap()
{ {
mKeys["UNASSIGNED"]= OIS::KC_UNASSIGNED; mKeys["UNASSIGNED"]= SDLK_UNKNOWN;
mKeys["ESCAPE"]= OIS::KC_ESCAPE; mKeys["ESCAPE"]= SDLK_ESCAPE;
mKeys["1"]= OIS::KC_1; mKeys["1"]= SDLK_1;
mKeys["2"]= OIS::KC_2; mKeys["2"]= SDLK_2;
mKeys["3"]= OIS::KC_3; mKeys["3"]= SDLK_3;
mKeys["4"]= OIS::KC_4; mKeys["4"]= SDLK_4;
mKeys["5"]= OIS::KC_5; mKeys["5"]= SDLK_5;
mKeys["6"]= OIS::KC_6; mKeys["6"]= SDLK_6;
mKeys["7"]= OIS::KC_7; mKeys["7"]= SDLK_7;
mKeys["8"]= OIS::KC_8; mKeys["8"]= SDLK_8;
mKeys["9"]= OIS::KC_9; mKeys["9"]= SDLK_9;
mKeys["0"]= OIS::KC_0; mKeys["0"]= SDLK_0;
mKeys["MINUS"]= OIS::KC_MINUS; mKeys["MINUS"]= SDLK_MINUS;
mKeys["EQUALS"]= OIS::KC_EQUALS; mKeys["EQUALS"]= SDLK_EQUALS;
mKeys["BACK"]= OIS::KC_BACK; mKeys["BACK"]= SDLK_BACKSPACE;
mKeys["TAB"]= OIS::KC_TAB; mKeys["TAB"]= SDLK_TAB;
mKeys["Q"]= OIS::KC_Q; mKeys["Q"]= SDLK_q;
mKeys["W"]= OIS::KC_W; mKeys["W"]= SDLK_w;
mKeys["E"]= OIS::KC_E; mKeys["E"]= SDLK_e;
mKeys["R"]= OIS::KC_R; mKeys["R"]= SDLK_r;
mKeys["T"]= OIS::KC_T; mKeys["T"]= SDLK_t;
mKeys["Y"]= OIS::KC_Y; mKeys["Y"]= SDLK_y;
mKeys["U"]= OIS::KC_U; mKeys["U"]= SDLK_u;
mKeys["I"]= OIS::KC_I; mKeys["I"]= SDLK_i;
mKeys["O"]= OIS::KC_O; mKeys["O"]= SDLK_o;
mKeys["P"]= OIS::KC_P; mKeys["P"]= SDLK_p;
mKeys["LBRACKET"]= OIS::KC_LBRACKET; mKeys["LBRACKET"]= SDLK_LEFTBRACKET;
mKeys["RBRACKET"]= OIS::KC_RBRACKET; mKeys["RBRACKET"]= SDLK_RIGHTBRACKET;
mKeys["RETURN"]= OIS::KC_RETURN; mKeys["RETURN"]= SDLK_RETURN;
mKeys["LCONTROL"]= OIS::KC_LCONTROL; mKeys["LCONTROL"]= SDLK_LCTRL;
mKeys["A"]= OIS::KC_A; mKeys["A"]= SDLK_a;
mKeys["S"]= OIS::KC_S; mKeys["S"]= SDLK_s;
mKeys["D"]= OIS::KC_D; mKeys["D"]= SDLK_d;
mKeys["F"]= OIS::KC_F; mKeys["F"]= SDLK_f;
mKeys["G"]= OIS::KC_G; mKeys["G"]= SDLK_g;
mKeys["H"]= OIS::KC_H; mKeys["H"]= SDLK_h;
mKeys["J"]= OIS::KC_J; mKeys["J"]= SDLK_j;
mKeys["K"]= OIS::KC_K; mKeys["K"]= SDLK_k;
mKeys["L"]= OIS::KC_L; mKeys["L"]= SDLK_l;
mKeys["SEMICOLON"]= OIS::KC_SEMICOLON; mKeys["SEMICOLON"]= SDLK_SEMICOLON;
mKeys["APOSTROPHE"]= OIS::KC_APOSTROPHE; mKeys["APOSTROPHE"]= SDLK_QUOTE;
mKeys["GRAVE"]= OIS::KC_GRAVE; mKeys["GRAVE"]= SDLK_BACKQUOTE;
mKeys["LSHIFT"]= OIS::KC_LSHIFT; mKeys["LSHIFT"]= SDLK_LSHIFT;
mKeys["BACKSLASH"]= OIS::KC_BACKSLASH; mKeys["BACKSLASH"]= SDLK_BACKSLASH;
mKeys["Z"]= OIS::KC_Z; mKeys["Z"]= SDLK_z;
mKeys["X"]= OIS::KC_X; mKeys["X"]= SDLK_x;
mKeys["C"]= OIS::KC_C; mKeys["C"]= SDLK_c;
mKeys["V"]= OIS::KC_V; mKeys["V"]= SDLK_v;
mKeys["B"]= OIS::KC_B; mKeys["B"]= SDLK_b;
mKeys["N"]= OIS::KC_N; mKeys["N"]= SDLK_n;
mKeys["M"]= OIS::KC_M; mKeys["M"]= SDLK_m;
mKeys["COMMA"]= OIS::KC_COMMA; mKeys["COMMA"]= SDLK_COMMA;
mKeys["PERIOD"]= OIS::KC_PERIOD; mKeys["PERIOD"]= SDLK_PERIOD;
mKeys["SLASH"]= OIS::KC_SLASH; mKeys["SLASH"]= SDLK_SLASH;
mKeys["RSHIFT"]= OIS::KC_RSHIFT; mKeys["RSHIFT"]= SDLK_RSHIFT;
mKeys["MULTIPLY"]= OIS::KC_MULTIPLY; mKeys["MULTIPLY"]= SDLK_ASTERISK;
mKeys["LMENU"]= OIS::KC_LMENU; mKeys["LMENU"]= SDLK_LALT;
mKeys["SPACE"]= OIS::KC_SPACE; mKeys["SPACE"]= SDLK_SPACE;
mKeys["CAPITAL"]= OIS::KC_CAPITAL; mKeys["CAPITAL"]= SDLK_CAPSLOCK;
mKeys["F1"]= OIS::KC_F1; mKeys["F1"]= SDLK_F1;
mKeys["F2"]= OIS::KC_F2; mKeys["F2"]= SDLK_F2;
mKeys["F3"]= OIS::KC_F3; mKeys["F3"]= SDLK_F3;
mKeys["F4"]= OIS::KC_F4; mKeys["F4"]= SDLK_F4;
mKeys["F5"]= OIS::KC_F5; mKeys["F5"]= SDLK_F5;
mKeys["F6"]= OIS::KC_F6; mKeys["F6"]= SDLK_F6;
mKeys["F7"]= OIS::KC_F7; mKeys["F7"]= SDLK_F7;
mKeys["F8"]= OIS::KC_F8; mKeys["F8"]= SDLK_F8;
mKeys["F9"]= OIS::KC_F9; mKeys["F9"]= SDLK_F9;
mKeys["F10"]= OIS::KC_F10; mKeys["F10"]= SDLK_F10;
mKeys["F11"]= OIS::KC_F11; mKeys["F11"]= SDLK_F11;
mKeys["F12"]= OIS::KC_F12; mKeys["F12"]= SDLK_F12;
mKeys["NUMLOCK"]= OIS::KC_NUMLOCK; mKeys["NUMLOCK"]= SDLK_NUMLOCKCLEAR;
mKeys["SCROLL"]= OIS::KC_SCROLL; mKeys["SCROLL"]= SDLK_SCROLLLOCK;
mKeys["NUMPAD7"]= OIS::KC_NUMPAD7; mKeys["NUMPAD7"]= SDLK_KP_7;
mKeys["NUMPAD8"]= OIS::KC_NUMPAD8; mKeys["NUMPAD8"]= SDLK_KP_8;
mKeys["NUMPAD9"]= OIS::KC_NUMPAD9; mKeys["NUMPAD9"]= SDLK_KP_9;
mKeys["SUBTRACT"]= OIS::KC_SUBTRACT; mKeys["SUBTRACT"]= SDLK_KP_MINUS;
mKeys["NUMPAD4"]= OIS::KC_NUMPAD4; mKeys["NUMPAD4"]= SDLK_KP_4;
mKeys["NUMPAD5"]= OIS::KC_NUMPAD5; mKeys["NUMPAD5"]= SDLK_KP_5;
mKeys["NUMPAD6"]= OIS::KC_NUMPAD6; mKeys["NUMPAD6"]= SDLK_KP_6;
mKeys["ADD"]= OIS::KC_ADD; mKeys["ADD"]= SDLK_KP_PLUS;
mKeys["NUMPAD1"]= OIS::KC_NUMPAD1; mKeys["NUMPAD1"]= SDLK_KP_1;
mKeys["NUMPAD2"]= OIS::KC_NUMPAD2; mKeys["NUMPAD2"]= SDLK_KP_2;
mKeys["NUMPAD3"]= OIS::KC_NUMPAD3; mKeys["NUMPAD3"]= SDLK_KP_3;
mKeys["NUMPAD0"]= OIS::KC_NUMPAD0; mKeys["NUMPAD0"]= SDLK_KP_0;
mKeys["DECIMAL"]= OIS::KC_DECIMAL; mKeys["DECIMAL"]= SDLK_KP_DECIMAL;
mKeys["RCONTROL"]= OIS::KC_RCONTROL; mKeys["RCONTROL"]= SDLK_RCTRL;
mKeys["DIVIDE"]= OIS::KC_DIVIDE; mKeys["DIVIDE"]= SDLK_SLASH;
mKeys["SYSRQ"]= OIS::KC_SYSRQ; mKeys["SYSRQ"]= SDLK_SYSREQ;
mKeys["RMENU"]= OIS::KC_RMENU; mKeys["RMENU"]= SDLK_RALT;
mKeys["PAUSE"]= OIS::KC_PAUSE; mKeys["PAUSE"]= SDLK_PAUSE;
mKeys["HOME"]= OIS::KC_HOME; mKeys["HOME"]= SDLK_HOME;
mKeys["UP"]= OIS::KC_UP; mKeys["UP"]= SDLK_UP;
mKeys["PGUP"]= OIS::KC_PGUP; mKeys["PGUP"]= SDLK_PAGEUP;
mKeys["LEFT"]= OIS::KC_LEFT; mKeys["LEFT"]= SDLK_LEFT;
mKeys["RIGHT"]= OIS::KC_RIGHT; mKeys["RIGHT"]= SDLK_RIGHT;
mKeys["END"]= OIS::KC_END; mKeys["END"]= SDLK_END;
mKeys["DOWN"]= OIS::KC_DOWN; mKeys["DOWN"]= SDLK_DOWN;
mKeys["PGDOWN"]= OIS::KC_PGDOWN; mKeys["PGDOWN"]= SDLK_PAGEDOWN;
mKeys["INSERT"]= OIS::KC_INSERT; mKeys["INSERT"]= SDLK_INSERT;
mKeys["DELETE"]= OIS::KC_DELETE; mKeys["DELETE"]= SDLK_DELETE;
mKeys["LWIN"]= OIS::KC_LWIN;
mKeys["RWIN"]= OIS::KC_RWIN; mKeys["NUMPADENTER"]= SDLK_KP_ENTER;
mKeys["APPS"]= OIS::KC_APPS;
for(std::map<std::string, SDL_Keycode>::iterator it = mKeys.begin()
mKeys["NUMPADENTER"]= OIS::KC_NUMPADENTER;
for(std::map<std::string, OIS::KeyCode>::iterator it = mKeys.begin()
; it != mKeys.end() ; it++) ; it != mKeys.end() ; it++)
{ {
mKeyCodes[ it->second ] = it->first; mKeyCodes[ it->second ] = it->first;
} }
} }
std::string InputControlSystem::keyCodeToString(OIS::KeyCode key) std::string InputControlSystem::keyCodeToString(SDL_Keycode key)
{ {
return mKeyCodes[key]; return mKeyCodes[key];
} }
OIS::KeyCode InputControlSystem::stringToKeyCode(std::string key) SDL_Keycode InputControlSystem::stringToKeyCode(std::string key)
{ {
return mKeys[key]; return mKeys[key];
} }
void InputControlSystem::adjustMouseRegion(Uint16 width, Uint16 height)
{
mClientWidth = width;
mClientHeight = height;
}
} }

@ -32,6 +32,8 @@ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
#include "ICSControl.h" #include "ICSControl.h"
#include "ICSChannel.h" #include "ICSChannel.h"
#include "OISCompat.h"
#define ICS_LOG(text) if(mLog) mLog->logMessage( ("ICS: " + std::string(text)).c_str() ); #define ICS_LOG(text) if(mLog) mLog->logMessage( ("ICS: " + std::string(text)).c_str() );
#define ICS_MAX_JOYSTICK_AXIS 16 #define ICS_MAX_JOYSTICK_AXIS 16
#define ICS_MOUSE_BINDING_MARGIN 30 #define ICS_MOUSE_BINDING_MARGIN 30
@ -48,9 +50,9 @@ namespace ICS
}; };
class DllExport InputControlSystem : class DllExport InputControlSystem :
public OIS::MouseListener, public MWSDLMouseListener,
public OIS::KeyListener, public MWSDLKeyListener,
public OIS::JoyStickListener public MWSDLJoyStickListener
{ {
public: public:
@ -100,29 +102,30 @@ namespace ICS
JoystickIDList& getJoystickIdList(){ return mJoystickIDList; }; JoystickIDList& getJoystickIdList(){ return mJoystickIDList; };
// MouseListener // MouseListener
bool mouseMoved(const OIS::MouseEvent &evt); bool mouseMoved(const MWSDLMouseMotionEvent &evt);
bool mousePressed(const OIS::MouseEvent &evt, OIS::MouseButtonID); bool mousePressed(const SDL_MouseButtonEvent &evt, Uint8);
bool mouseReleased(const OIS::MouseEvent &evt, OIS::MouseButtonID); bool mouseReleased(const SDL_MouseButtonEvent &evt, Uint8);
// KeyListener // KeyListener
bool keyPressed(const OIS::KeyEvent &evt); bool keyPressed(const SDL_KeyboardEvent &evt);
bool keyReleased(const OIS::KeyEvent &evt); bool keyReleased(const SDL_KeyboardEvent &evt);
// JoyStickListener // JoyStickListener
bool buttonPressed(const OIS::JoyStickEvent &evt, int button); bool buttonPressed(const SDL_JoyButtonEvent &evt, int button);
bool buttonReleased(const OIS::JoyStickEvent &evt, int button); bool buttonReleased(const SDL_JoyButtonEvent &evt, int button);
bool axisMoved(const OIS::JoyStickEvent &evt, int axis); bool axisMoved(const SDL_JoyAxisEvent &evt, int axis);
bool povMoved(const OIS::JoyStickEvent &evt, int index); bool povMoved(const SDL_JoyHatEvent &evt, int index);
bool sliderMoved(const OIS::JoyStickEvent &evt, int index); //TODO: does this have an SDL equivalent?
//bool sliderMoved(const OIS::JoyStickEvent &evt, int index);
void addKeyBinding(Control* control, OIS::KeyCode key, Control::ControlChangingDirection direction);
void addKeyBinding(Control* control, SDL_Keycode key, Control::ControlChangingDirection direction);
void addMouseAxisBinding(Control* control, NamedAxis axis, Control::ControlChangingDirection direction); void addMouseAxisBinding(Control* control, NamedAxis axis, Control::ControlChangingDirection direction);
void addMouseButtonBinding(Control* control, unsigned int button, Control::ControlChangingDirection direction); void addMouseButtonBinding(Control* control, unsigned int button, Control::ControlChangingDirection direction);
void addJoystickAxisBinding(Control* control, int deviceId, int axis, Control::ControlChangingDirection direction); void addJoystickAxisBinding(Control* control, int deviceId, int axis, Control::ControlChangingDirection direction);
void addJoystickButtonBinding(Control* control, int deviceId, unsigned int button, Control::ControlChangingDirection direction); void addJoystickButtonBinding(Control* control, int deviceId, unsigned int button, Control::ControlChangingDirection direction);
void addJoystickPOVBinding(Control* control, int deviceId, int index, POVAxis axis, Control::ControlChangingDirection direction); void addJoystickPOVBinding(Control* control, int deviceId, int index, POVAxis axis, Control::ControlChangingDirection direction);
void addJoystickSliderBinding(Control* control, int deviceId, int index, Control::ControlChangingDirection direction); void addJoystickSliderBinding(Control* control, int deviceId, int index, Control::ControlChangingDirection direction);
void removeKeyBinding(OIS::KeyCode key); void removeKeyBinding(SDL_Keycode key);
void removeMouseAxisBinding(NamedAxis axis); void removeMouseAxisBinding(NamedAxis axis);
void removeMouseButtonBinding(unsigned int button); void removeMouseButtonBinding(unsigned int button);
void removeJoystickAxisBinding(int deviceId, int axis); void removeJoystickAxisBinding(int deviceId, int axis);
@ -130,7 +133,7 @@ namespace ICS
void removeJoystickPOVBinding(int deviceId, int index, POVAxis axis); void removeJoystickPOVBinding(int deviceId, int index, POVAxis axis);
void removeJoystickSliderBinding(int deviceId, int index); void removeJoystickSliderBinding(int deviceId, int index);
OIS::KeyCode getKeyBinding(Control* control, ICS::Control::ControlChangingDirection direction); SDL_Keycode getKeyBinding(Control* control, ICS::Control::ControlChangingDirection direction);
NamedAxis getMouseAxisBinding(Control* control, ICS::Control::ControlChangingDirection direction); NamedAxis getMouseAxisBinding(Control* control, ICS::Control::ControlChangingDirection direction);
unsigned int getMouseButtonBinding(Control* control, ICS::Control::ControlChangingDirection direction); unsigned int getMouseButtonBinding(Control* control, ICS::Control::ControlChangingDirection direction);
int getJoystickAxisBinding(Control* control, int deviceId, ICS::Control::ControlChangingDirection direction); int getJoystickAxisBinding(Control* control, int deviceId, ICS::Control::ControlChangingDirection direction);
@ -138,14 +141,16 @@ namespace ICS
POVBindingPair getJoystickPOVBinding(Control* control, int deviceId, ICS::Control::ControlChangingDirection direction); POVBindingPair getJoystickPOVBinding(Control* control, int deviceId, ICS::Control::ControlChangingDirection direction);
int getJoystickSliderBinding(Control* control, int deviceId, ICS::Control::ControlChangingDirection direction); int getJoystickSliderBinding(Control* control, int deviceId, ICS::Control::ControlChangingDirection direction);
std::string keyCodeToString(OIS::KeyCode key); std::string keyCodeToString(SDL_Keycode key);
OIS::KeyCode stringToKeyCode(std::string key); SDL_Keycode stringToKeyCode(std::string key);
void enableDetectingBindingState(Control* control, Control::ControlChangingDirection direction); void enableDetectingBindingState(Control* control, Control::ControlChangingDirection direction);
void cancelDetectingBindingState(); void cancelDetectingBindingState();
bool save(std::string fileName = ""); bool save(std::string fileName = "");
void adjustMouseRegion (Uint16 width, Uint16 height);
protected: protected:
void loadKeyBinders(TiXmlElement* xmlControlNode); void loadKeyBinders(TiXmlElement* xmlControlNode);
@ -180,7 +185,7 @@ namespace ICS
std::string mFileName; std::string mFileName;
typedef std::map<OIS::KeyCode, ControlKeyBinderItem> ControlsKeyBinderMapType; // <KeyCode, [direction, control]> typedef std::map<SDL_Keycode, ControlKeyBinderItem> ControlsKeyBinderMapType; // <KeyCode, [direction, control]>
typedef std::map<int, ControlAxisBinderItem> ControlsAxisBinderMapType; // <axis, [direction, control]> typedef std::map<int, ControlAxisBinderItem> ControlsAxisBinderMapType; // <axis, [direction, control]>
typedef std::map<int, ControlButtonBinderItem> ControlsButtonBinderMapType; // <button, [direction, control]> typedef std::map<int, ControlButtonBinderItem> ControlsButtonBinderMapType; // <button, [direction, control]>
typedef std::map<int, ControlPOVBinderItem> ControlsPOVBinderMapType; // <index, [direction, control]> typedef std::map<int, ControlPOVBinderItem> ControlsPOVBinderMapType; // <index, [direction, control]>
@ -202,8 +207,8 @@ namespace ICS
std::vector<Channel *> mChannels; std::vector<Channel *> mChannels;
ControlsKeyBinderMapType mControlsKeyBinderMap; ControlsKeyBinderMapType mControlsKeyBinderMap;
std::map<std::string, OIS::KeyCode> mKeys; std::map<std::string, SDL_Keycode> mKeys;
std::map<OIS::KeyCode, std::string> mKeyCodes; std::map<SDL_Keycode, std::string> mKeyCodes;
bool mActive; bool mActive;
InputControlSystemLog* mLog; InputControlSystemLog* mLog;
@ -221,14 +226,17 @@ namespace ICS
private: private:
void fillOISKeysMap(); void fillSDLKeysMap();
Uint16 mClientWidth;
Uint16 mClientHeight;
}; };
class DllExport DetectingBindingListener class DllExport DetectingBindingListener
{ {
public: public:
virtual void keyBindingDetected(InputControlSystem* ICS, Control* control virtual void keyBindingDetected(InputControlSystem* ICS, Control* control
, OIS::KeyCode key, Control::ControlChangingDirection direction); , SDL_Keycode key, Control::ControlChangingDirection direction);
virtual void mouseAxisBindingDetected(InputControlSystem* ICS, Control* control virtual void mouseAxisBindingDetected(InputControlSystem* ICS, Control* control
, InputControlSystem::NamedAxis axis, Control::ControlChangingDirection direction); , InputControlSystem::NamedAxis axis, Control::ControlChangingDirection direction);

@ -26,6 +26,9 @@ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
#include "ICSInputControlSystem.h" #include "ICSInputControlSystem.h"
#define SDL_JOY_AXIS_MIN -32768
#define SDL_JOY_AXIS_MAX 32767
namespace ICS namespace ICS
{ {
// load xml // load xml
@ -315,16 +318,16 @@ namespace ICS
} }
// joyStick listeners // joyStick listeners
bool InputControlSystem::buttonPressed(const OIS::JoyStickEvent &evt, int button) bool InputControlSystem::buttonPressed(const SDL_JoyButtonEvent &evt, int button)
{ {
if(mActive) if(mActive)
{ {
if(!mDetectingBindingControl) if(!mDetectingBindingControl)
{ {
if(mControlsJoystickButtonBinderMap.find(evt.device->getID()) != mControlsJoystickButtonBinderMap.end()) if(mControlsJoystickButtonBinderMap.find(evt.which) != mControlsJoystickButtonBinderMap.end())
{ {
ControlsButtonBinderMapType::const_iterator it = mControlsJoystickButtonBinderMap[evt.device->getID()].find(button); ControlsButtonBinderMapType::const_iterator it = mControlsJoystickButtonBinderMap[evt.which].find(button);
if(it != mControlsJoystickButtonBinderMap[evt.device->getID()].end()) if(it != mControlsJoystickButtonBinderMap[evt.which].end())
{ {
it->second.control->setIgnoreAutoReverse(false); it->second.control->setIgnoreAutoReverse(false);
if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop()) if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop())
@ -348,21 +351,21 @@ namespace ICS
else if(mDetectingBindingListener) else if(mDetectingBindingListener)
{ {
mDetectingBindingListener->joystickButtonBindingDetected(this, mDetectingBindingListener->joystickButtonBindingDetected(this,
mDetectingBindingControl, evt.device->getID(), button, mDetectingBindingDirection); mDetectingBindingControl, evt.which, button, mDetectingBindingDirection);
} }
} }
return true; return true;
} }
bool InputControlSystem::buttonReleased(const OIS::JoyStickEvent &evt, int button) bool InputControlSystem::buttonReleased(const SDL_JoyButtonEvent &evt, int button)
{ {
if(mActive) if(mActive)
{ {
if(mControlsJoystickButtonBinderMap.find(evt.device->getID()) != mControlsJoystickButtonBinderMap.end()) if(mControlsJoystickButtonBinderMap.find(evt.which) != mControlsJoystickButtonBinderMap.end())
{ {
ControlsButtonBinderMapType::const_iterator it = mControlsJoystickButtonBinderMap[evt.device->getID()].find(button); ControlsButtonBinderMapType::const_iterator it = mControlsJoystickButtonBinderMap[evt.which].find(button);
if(it != mControlsJoystickButtonBinderMap[evt.device->getID()].end()) if(it != mControlsJoystickButtonBinderMap[evt.which].end())
{ {
it->second.control->setChangingDirection(Control::STOP); it->second.control->setChangingDirection(Control::STOP);
} }
@ -371,31 +374,29 @@ namespace ICS
return true; return true;
} }
bool InputControlSystem::axisMoved(const OIS::JoyStickEvent &evt, int axis) bool InputControlSystem::axisMoved(const SDL_JoyAxisEvent &evt, int axis)
{ {
if(mActive) if(mActive)
{ {
if(!mDetectingBindingControl) if(!mDetectingBindingControl)
{ {
if(mControlsJoystickAxisBinderMap.find(evt.device->getID()) != mControlsJoystickAxisBinderMap.end()) if(mControlsJoystickAxisBinderMap.find(evt.which) != mControlsJoystickAxisBinderMap.end())
{ {
ControlAxisBinderItem joystickBinderItem = mControlsJoystickAxisBinderMap[ evt.device->getID() ][ axis ]; // joystic axis start at 0 index ControlAxisBinderItem joystickBinderItem = mControlsJoystickAxisBinderMap[ evt.which ][ axis ]; // joystic axis start at 0 index
Control* ctrl = joystickBinderItem.control; Control* ctrl = joystickBinderItem.control;
if(ctrl) if(ctrl)
{ {
ctrl->setIgnoreAutoReverse(true); ctrl->setIgnoreAutoReverse(true);
float axisRange = SDL_JOY_AXIS_MAX - SDL_JOY_AXIS_MAX;
float valDisplaced = (float)(evt.value - SDL_JOY_AXIS_MIN);
if(joystickBinderItem.direction == Control::INCREASE) if(joystickBinderItem.direction == Control::INCREASE)
{ {
float axisRange = OIS::JoyStick::MAX_AXIS - OIS::JoyStick::MIN_AXIS;
float valDisplaced = (float)( evt.state.mAxes[axis].abs - OIS::JoyStick::MIN_AXIS);
ctrl->setValue( valDisplaced / axisRange ); ctrl->setValue( valDisplaced / axisRange );
} }
else if(joystickBinderItem.direction == Control::DECREASE) else if(joystickBinderItem.direction == Control::DECREASE)
{ {
float axisRange = OIS::JoyStick::MAX_AXIS - OIS::JoyStick::MIN_AXIS;
float valDisplaced = (float)(evt.state.mAxes[axis].abs - OIS::JoyStick::MIN_AXIS);
ctrl->setValue( 1 - ( valDisplaced / axisRange ) ); ctrl->setValue( 1 - ( valDisplaced / axisRange ) );
} }
} }
@ -403,15 +404,15 @@ namespace ICS
} }
else if(mDetectingBindingListener) else if(mDetectingBindingListener)
{ {
//ControlAxisBinderItem joystickBinderItem = mControlsJoystickAxisBinderMap[ evt.device->getID() ][ axis ]; // joystic axis start at 0 index //ControlAxisBinderItem joystickBinderItem = mControlsJoystickAxisBinderMap[ evt.which ][ axis ]; // joystic axis start at 0 index
//Control* ctrl = joystickBinderItem.control; //Control* ctrl = joystickBinderItem.control;
//if(ctrl && ctrl->isAxisBindable()) //if(ctrl && ctrl->isAxisBindable())
if(mDetectingBindingControl && mDetectingBindingControl->isAxisBindable()) if(mDetectingBindingControl && mDetectingBindingControl->isAxisBindable())
{ {
if( abs( evt.state.mAxes[axis].abs ) > ICS_JOYSTICK_AXIS_BINDING_MARGIN) if( abs( evt.value ) > ICS_JOYSTICK_AXIS_BINDING_MARGIN)
{ {
mDetectingBindingListener->joystickAxisBindingDetected(this, mDetectingBindingListener->joystickAxisBindingDetected(this,
mDetectingBindingControl, evt.device->getID(), axis, mDetectingBindingDirection); mDetectingBindingControl, evt.which, axis, mDetectingBindingDirection);
} }
} }
} }
@ -420,20 +421,21 @@ namespace ICS
return true; return true;
} }
bool InputControlSystem::povMoved(const OIS::JoyStickEvent &evt, int index) //Here be dragons, apparently
bool InputControlSystem::povMoved(const SDL_JoyHatEvent &evt, int index)
{ {
if(mActive) if(mActive)
{ {
if(!mDetectingBindingControl) if(!mDetectingBindingControl)
{ {
if(mControlsJoystickPOVBinderMap.find(evt.device->getID()) != mControlsJoystickPOVBinderMap.end()) if(mControlsJoystickPOVBinderMap.find(evt.which) != mControlsJoystickPOVBinderMap.end())
{ {
std::map<int, ControlsPOVBinderMapType>::const_iterator i = mControlsJoystickPOVBinderMap[ evt.device->getID() ].find(index); std::map<int, ControlsPOVBinderMapType>::const_iterator i = mControlsJoystickPOVBinderMap[ evt.which ].find(index);
if(i != mControlsJoystickPOVBinderMap[ evt.device->getID() ].end()) if(i != mControlsJoystickPOVBinderMap[ evt.which ].end())
{ {
if(evt.state.mPOV[index].direction != OIS::Pov::West if(evt.value != SDL_HAT_LEFT
&& evt.state.mPOV[index].direction != OIS::Pov::East && evt.value != SDL_HAT_RIGHT
&& evt.state.mPOV[index].direction != OIS::Pov::Centered) && evt.value != SDL_HAT_CENTERED)
{ {
ControlsPOVBinderMapType::const_iterator it = i->second.find( /*POVAxis::*/NorthSouth ); ControlsPOVBinderMapType::const_iterator it = i->second.find( /*POVAxis::*/NorthSouth );
if(it != i->second.end()) if(it != i->second.end())
@ -441,9 +443,9 @@ namespace ICS
it->second.control->setIgnoreAutoReverse(false); it->second.control->setIgnoreAutoReverse(false);
if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop()) if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop())
{ {
if(evt.state.mPOV[index].direction == OIS::Pov::North if(evt.value == SDL_HAT_UP
|| evt.state.mPOV[index].direction == OIS::Pov::NorthWest || evt.value == SDL_HAT_LEFTUP
|| evt.state.mPOV[index].direction == OIS::Pov::NorthEast) || evt.value == SDL_HAT_RIGHTUP)
{ {
it->second.control->setChangingDirection(it->second.direction); it->second.control->setChangingDirection(it->second.direction);
} }
@ -466,9 +468,9 @@ namespace ICS
} }
} }
if(evt.state.mPOV[index].direction != OIS::Pov::North if(evt.value != SDL_HAT_UP
&& evt.state.mPOV[index].direction != OIS::Pov::South && evt.value != SDL_HAT_DOWN
&& evt.state.mPOV[index].direction != OIS::Pov::Centered) && evt.value != SDL_HAT_CENTERED)
{ {
ControlsPOVBinderMapType::const_iterator it = i->second.find( /*POVAxis::*/EastWest ); ControlsPOVBinderMapType::const_iterator it = i->second.find( /*POVAxis::*/EastWest );
if(it != i->second.end()) if(it != i->second.end())
@ -476,9 +478,9 @@ namespace ICS
it->second.control->setIgnoreAutoReverse(false); it->second.control->setIgnoreAutoReverse(false);
if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop()) if(!it->second.control->getAutoChangeDirectionOnLimitsAfterStop())
{ {
if(evt.state.mPOV[index].direction == OIS::Pov::East if(evt.value == SDL_HAT_RIGHT
|| evt.state.mPOV[index].direction == OIS::Pov::NorthEast || evt.value == SDL_HAT_RIGHTUP
|| evt.state.mPOV[index].direction == OIS::Pov::SouthEast) || evt.value == SDL_HAT_RIGHTDOWN)
{ {
it->second.control->setChangingDirection(it->second.direction); it->second.control->setChangingDirection(it->second.direction);
} }
@ -501,7 +503,7 @@ namespace ICS
} }
} }
if(evt.state.mPOV[index].direction == OIS::Pov::Centered) if(evt.value == SDL_HAT_CENTERED)
{ {
ControlsPOVBinderMapType::const_iterator it = i->second.find( /*POVAxis::*/NorthSouth ); ControlsPOVBinderMapType::const_iterator it = i->second.find( /*POVAxis::*/NorthSouth );
if(it != i->second.end()) if(it != i->second.end())
@ -522,20 +524,20 @@ namespace ICS
{ {
if(mDetectingBindingControl && mDetectingBindingControl->isAxisBindable()) if(mDetectingBindingControl && mDetectingBindingControl->isAxisBindable())
{ {
if(evt.state.mPOV[index].direction == OIS::Pov::West if(evt.value == SDL_HAT_LEFT
|| evt.state.mPOV[index].direction == OIS::Pov::East || evt.value == SDL_HAT_RIGHT
|| evt.state.mPOV[index].direction == OIS::Pov::North || evt.value == SDL_HAT_UP
|| evt.state.mPOV[index].direction == OIS::Pov::South) || evt.value == SDL_HAT_DOWN)
{ {
POVAxis povAxis = NorthSouth; POVAxis povAxis = NorthSouth;
if(evt.state.mPOV[index].direction == OIS::Pov::West if(evt.value == SDL_HAT_LEFT
|| evt.state.mPOV[index].direction == OIS::Pov::East) || evt.value == SDL_HAT_RIGHT)
{ {
povAxis = EastWest; povAxis = EastWest;
} }
mDetectingBindingListener->joystickPOVBindingDetected(this, mDetectingBindingListener->joystickPOVBindingDetected(this,
mDetectingBindingControl, evt.device->getID(), index, povAxis, mDetectingBindingDirection); mDetectingBindingControl, evt.which, index, povAxis, mDetectingBindingDirection);
} }
} }
} }
@ -544,6 +546,8 @@ namespace ICS
return true; return true;
} }
//TODO: does this have an SDL equivalent?
/*
bool InputControlSystem::sliderMoved(const OIS::JoyStickEvent &evt, int index) bool InputControlSystem::sliderMoved(const OIS::JoyStickEvent &evt, int index)
{ {
if(mActive) if(mActive)
@ -576,10 +580,6 @@ namespace ICS
} }
else if(mDetectingBindingListener) else if(mDetectingBindingListener)
{ {
/*ControlSliderBinderItem joystickBinderItem = mControlsJoystickSliderBinderMap[ evt.device->getID() ][ index ];
Control* ctrl = joystickBinderItem.control;
if(ctrl && ctrl->isAxisBindable())
{*/
if(mDetectingBindingControl && mDetectingBindingControl->isAxisBindable()) if(mDetectingBindingControl && mDetectingBindingControl->isAxisBindable())
{ {
if( abs( evt.state.mSliders[index].abX ) > ICS_JOYSTICK_SLIDER_BINDING_MARGIN) if( abs( evt.state.mSliders[index].abX ) > ICS_JOYSTICK_SLIDER_BINDING_MARGIN)
@ -593,6 +593,7 @@ namespace ICS
return true; return true;
} }
*/
// joystick auto bindings // joystick auto bindings
void DetectingBindingListener::joystickAxisBindingDetected(InputControlSystem* ICS, Control* control void DetectingBindingListener::joystickAxisBindingDetected(InputControlSystem* ICS, Control* control

@ -49,7 +49,7 @@ namespace ICS
} }
} }
void InputControlSystem::addKeyBinding(Control* control, OIS::KeyCode key, Control::ControlChangingDirection direction) void InputControlSystem::addKeyBinding(Control* control, SDL_Keycode key, Control::ControlChangingDirection direction)
{ {
ICS_LOG("\tAdding KeyBinder [key=" ICS_LOG("\tAdding KeyBinder [key="
+ keyCodeToString(key) + ", direction=" + keyCodeToString(key) + ", direction="
@ -61,7 +61,7 @@ namespace ICS
mControlsKeyBinderMap[ key ] = controlKeyBinderItem; mControlsKeyBinderMap[ key ] = controlKeyBinderItem;
} }
void InputControlSystem::removeKeyBinding(OIS::KeyCode key) void InputControlSystem::removeKeyBinding(SDL_Keycode key)
{ {
ControlsKeyBinderMapType::iterator it = mControlsKeyBinderMap.find(key); ControlsKeyBinderMapType::iterator it = mControlsKeyBinderMap.find(key);
if(it != mControlsKeyBinderMap.end()) if(it != mControlsKeyBinderMap.end())
@ -70,7 +70,7 @@ namespace ICS
} }
} }
OIS::KeyCode InputControlSystem::getKeyBinding(Control* control SDL_Keycode InputControlSystem::getKeyBinding(Control* control
, ICS::Control::ControlChangingDirection direction) , ICS::Control::ControlChangingDirection direction)
{ {
ControlsKeyBinderMapType::iterator it = mControlsKeyBinderMap.begin(); ControlsKeyBinderMapType::iterator it = mControlsKeyBinderMap.begin();
@ -83,15 +83,15 @@ namespace ICS
it++; it++;
} }
return OIS::KC_UNASSIGNED; return SDLK_UNKNOWN;
} }
bool InputControlSystem::keyPressed(const OIS::KeyEvent &evt) bool InputControlSystem::keyPressed(const SDL_KeyboardEvent &evt)
{ {
if(mActive) if(mActive)
{ {
if(!mDetectingBindingControl) if(!mDetectingBindingControl)
{ {
ControlsKeyBinderMapType::const_iterator it = mControlsKeyBinderMap.find(evt.key); ControlsKeyBinderMapType::const_iterator it = mControlsKeyBinderMap.find(evt.keysym.sym);
if(it != mControlsKeyBinderMap.end()) if(it != mControlsKeyBinderMap.end())
{ {
it->second.control->setIgnoreAutoReverse(false); it->second.control->setIgnoreAutoReverse(false);
@ -115,18 +115,18 @@ namespace ICS
else if(mDetectingBindingListener) else if(mDetectingBindingListener)
{ {
mDetectingBindingListener->keyBindingDetected(this, mDetectingBindingListener->keyBindingDetected(this,
mDetectingBindingControl, evt.key, mDetectingBindingDirection); mDetectingBindingControl, evt.keysym.sym, mDetectingBindingDirection);
} }
} }
return true; return true;
} }
bool InputControlSystem::keyReleased(const OIS::KeyEvent &evt) bool InputControlSystem::keyReleased(const SDL_KeyboardEvent &evt)
{ {
if(mActive) if(mActive)
{ {
ControlsKeyBinderMapType::const_iterator it = mControlsKeyBinderMap.find(evt.key); ControlsKeyBinderMapType::const_iterator it = mControlsKeyBinderMap.find(evt.keysym.sym);
if(it != mControlsKeyBinderMap.end()) if(it != mControlsKeyBinderMap.end())
{ {
it->second.control->setChangingDirection(Control::STOP); it->second.control->setChangingDirection(Control::STOP);
@ -137,14 +137,14 @@ namespace ICS
} }
void DetectingBindingListener::keyBindingDetected(InputControlSystem* ICS, Control* control void DetectingBindingListener::keyBindingDetected(InputControlSystem* ICS, Control* control
, OIS::KeyCode key, Control::ControlChangingDirection direction) , SDL_Keycode key, Control::ControlChangingDirection direction)
{ {
// if the key is used by another control, remove it // if the key is used by another control, remove it
ICS->removeKeyBinding(key); ICS->removeKeyBinding(key);
// if the control has a key assigned, remove it // if the control has a key assigned, remove it
OIS::KeyCode oldKey = ICS->getKeyBinding(control, direction); SDL_Keycode oldKey = ICS->getKeyBinding(control, direction);
if(oldKey != OIS::KC_UNASSIGNED) if(oldKey != SDLK_UNKNOWN)
{ {
ICS->removeKeyBinding(oldKey); ICS->removeKeyBinding(oldKey);
} }

@ -78,15 +78,15 @@ namespace ICS
int button = 0; int button = 0;
if(std::string(xmlMouseButtonBinder->Attribute("button")) == "LEFT") if(std::string(xmlMouseButtonBinder->Attribute("button")) == "LEFT")
{ {
button = OIS::/*MouseButtonID::*/MB_Left; button = SDL_BUTTON_LEFT;
} }
else if(std::string(xmlMouseButtonBinder->Attribute("button")) == "RIGHT") else if(std::string(xmlMouseButtonBinder->Attribute("button")) == "RIGHT")
{ {
button = OIS::/*MouseButtonID::*/MB_Right; button = SDL_BUTTON_RIGHT;
} }
else if(std::string(xmlMouseButtonBinder->Attribute("button")) == "MIDDLE") else if(std::string(xmlMouseButtonBinder->Attribute("button")) == "MIDDLE")
{ {
button = OIS::/*MouseButtonID::*/MB_Middle; button = SDL_BUTTON_MIDDLE;
} }
else else
{ {
@ -219,39 +219,39 @@ namespace ICS
} }
// mouse Listeners // mouse Listeners
bool InputControlSystem::mouseMoved(const OIS::MouseEvent &evt) bool InputControlSystem::mouseMoved(const MWSDLMouseMotionEvent& evt)
{ {
if(mActive) if(mActive)
{ {
if(!mDetectingBindingControl) if(!mDetectingBindingControl)
{ {
if(mXmouseAxisBinded && evt.state.X.rel) if(mXmouseAxisBinded && evt.xrel)
{ {
ControlAxisBinderItem mouseBinderItem = mControlsMouseAxisBinderMap[ /*NamedAxis::*/X ]; ControlAxisBinderItem mouseBinderItem = mControlsMouseAxisBinderMap[ /*NamedAxis::*/X ];
Control* ctrl = mouseBinderItem.control; Control* ctrl = mouseBinderItem.control;
ctrl->setIgnoreAutoReverse(true); ctrl->setIgnoreAutoReverse(true);
if(mouseBinderItem.direction == Control::INCREASE) if(mouseBinderItem.direction == Control::INCREASE)
{ {
ctrl->setValue( float( (evt.state.X.abs) / float(evt.state.width) ) ); ctrl->setValue( float( (evt.x) / float(mClientWidth) ) );
} }
else if(mouseBinderItem.direction == Control::DECREASE) else if(mouseBinderItem.direction == Control::DECREASE)
{ {
ctrl->setValue( 1 - float( evt.state.X.abs / float(evt.state.width) ) ); ctrl->setValue( 1 - float( evt.x / float(mClientWidth) ) );
} }
} }
if(mYmouseAxisBinded && evt.state.Y.rel) if(mYmouseAxisBinded && evt.yrel)
{ {
ControlAxisBinderItem mouseBinderItem = mControlsMouseAxisBinderMap[ /*NamedAxis::*/Y ]; ControlAxisBinderItem mouseBinderItem = mControlsMouseAxisBinderMap[ /*NamedAxis::*/Y ];
Control* ctrl = mouseBinderItem.control; Control* ctrl = mouseBinderItem.control;
ctrl->setIgnoreAutoReverse(true); ctrl->setIgnoreAutoReverse(true);
if(mouseBinderItem.direction == Control::INCREASE) if(mouseBinderItem.direction == Control::INCREASE)
{ {
ctrl->setValue( float( (evt.state.Y.abs) / float(evt.state.height) ) ); ctrl->setValue( float( (evt.y) / float(mClientHeight) ) );
} }
else if(mouseBinderItem.direction == Control::DECREASE) else if(mouseBinderItem.direction == Control::DECREASE)
{ {
ctrl->setValue( 1 - float( evt.state.Y.abs / float(evt.state.height) ) ); ctrl->setValue( 1 - float( evt.y / float(mClientHeight) ) );
} }
} }
@ -282,9 +282,9 @@ namespace ICS
mMouseAxisBindingInitialValues[2] = 0; mMouseAxisBindingInitialValues[2] = 0;
} }
mMouseAxisBindingInitialValues[0] += evt.state.X.rel; mMouseAxisBindingInitialValues[0] += evt.xrel;
mMouseAxisBindingInitialValues[1] += evt.state.Y.rel; mMouseAxisBindingInitialValues[1] += evt.yrel;
mMouseAxisBindingInitialValues[2] += evt.state.Z.rel; mMouseAxisBindingInitialValues[2] += evt.zrel;
if( abs(mMouseAxisBindingInitialValues[0]) > ICS_MOUSE_BINDING_MARGIN ) if( abs(mMouseAxisBindingInitialValues[0]) > ICS_MOUSE_BINDING_MARGIN )
{ {
@ -308,7 +308,7 @@ namespace ICS
return true; return true;
} }
bool InputControlSystem::mousePressed(const OIS::MouseEvent &evt, OIS::MouseButtonID btn) bool InputControlSystem::mousePressed(const SDL_MouseButtonEvent &evt, Uint8 btn)
{ {
if(mActive) if(mActive)
{ {
@ -345,7 +345,7 @@ namespace ICS
return true; return true;
} }
bool InputControlSystem::mouseReleased(const OIS::MouseEvent &evt, OIS::MouseButtonID btn) bool InputControlSystem::mouseReleased(const SDL_MouseButtonEvent &evt, Uint8 btn)
{ {
if(mActive) if(mActive)
{ {

@ -39,11 +39,11 @@ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
#include "tinyxml.h" #include "tinyxml.h"
#include <OIS.h> #include "SDL2/SDL_input.h"
#include <OISMouse.h> #include "SDL2/SDL_keyboard.h"
#include <OISKeyboard.h> #include "SDL2/SDL_mouse.h"
#include <OISJoyStick.h> #include "SDL2/SDL_joystick.h"
#include <OISInputManager.h> #include "SDL2/SDL_events.h"
/// Define the dll export qualifier if compiling for Windows /// Define the dll export qualifier if compiling for Windows
@ -65,8 +65,8 @@ SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
/// Version defines /// Version defines
#define ICS_VERSION_MAJOR 0 #define ICS_VERSION_MAJOR 0
#define ICS_VERSION_MINOR 3 #define ICS_VERSION_MINOR 4
#define ICS_VERSION_PATCH 1 #define ICS_VERSION_PATCH 0
#define ICS_MAX_DEVICE_BUTTONS 30 #define ICS_MAX_DEVICE_BUTTONS 30

@ -0,0 +1,90 @@
#ifndef _OIS_SDL_COMPAT_H
#define _OIS_SDL_COMPAT_H
#include <SDL2/SDL_events.h>
#include <SDL2/SDL_types.h>
//TODO: Remove this. Right now we want to remain as close to OIS as possible
//So we can easily test the SDL backend
////////////
// Events //
////////////
namespace ICS {
/** Extended mouse event struct where we treat the wheel like an axis, like everyone expects */
struct MWSDLMouseMotionEvent : SDL_MouseMotionEvent {
Sint16 zrel;
MWSDLMouseMotionEvent()
{
x = 0;
y = 0;
xrel = 0;
yrel = 0;
state = 0;
zrel = 0;
}
MWSDLMouseMotionEvent( const SDL_MouseMotionEvent& evt) :
MWSDLMouseMotionEvent()
{
x = evt.x;
y = evt.y;
xrel = evt.xrel;
yrel = evt.yrel;
state = evt.state;
}
MWSDLMouseMotionEvent (const SDL_MouseWheelEvent& evt) :
MWSDLMouseMotionEvent()
{
zrel = evt.y;
}
};
///////////////
// Listeners //
///////////////
class MWSDLMouseListener
{
public:
virtual ~MWSDLMouseListener() {}
virtual bool mouseMoved( const MWSDLMouseMotionEvent &arg ) = 0;
virtual bool mousePressed( const SDL_MouseButtonEvent &arg, Uint8 id ) = 0;
virtual bool mouseReleased( const SDL_MouseButtonEvent &arg, Uint8 id ) = 0;
};
class MWSDLKeyListener
{
public:
virtual ~MWSDLKeyListener() {}
virtual bool keyPressed(const SDL_KeyboardEvent &arg) = 0;
virtual bool keyReleased(const SDL_KeyboardEvent &arg) = 0;
};
class MWSDLJoyStickListener
{
public:
virtual ~MWSDLJoyStickListener() {}
/** @remarks Joystick button down event */
virtual bool buttonPressed( const SDL_JoyButtonEvent &evt, int button ) = 0;
/** @remarks Joystick button up event */
virtual bool buttonReleased( const SDL_JoyButtonEvent &evt, int button ) = 0;
/** @remarks Joystick axis moved event */
virtual bool axisMoved( const SDL_JoyAxisEvent &arg, int axis ) = 0;
//-- Not so common control events, so are not required --//
//! Joystick Event, and povID
virtual bool povMoved( const SDL_JoyHatEvent &arg, int index) {return true;}
};
}
#endif
Loading…
Cancel
Save