made some keyboard keys always usable in menus (like arrows) when bindings don't use them
git-svn-id: svn+ssh://svn.code.sf.net/p/supertuxkart/code/main/branches/irrlicht@3559 178a84e3-b1eb-0310-8ba1-8eac791a3b58
This commit is contained in:
parent
1a47cc900f
commit
4972f247be
@ -186,9 +186,27 @@ void InputManager::input(Input::InputType type, int deviceID, int btnID, int axi
|
|||||||
int player;
|
int player;
|
||||||
PlayerAction action;
|
PlayerAction action;
|
||||||
|
|
||||||
const bool action_found = m_device_manager->mapInputToPlayerAndAction( type, deviceID, btnID, axisDirection, value, &player, &action );
|
bool action_found = m_device_manager->mapInputToPlayerAndAction( type, deviceID, btnID, axisDirection, value, &player, &action );
|
||||||
|
|
||||||
|
|
||||||
|
// in menus, some keyboard keys are standard
|
||||||
|
if(!StateManager::isGameState() && type == Input::IT_KEYBOARD && m_mode == MENU)
|
||||||
|
{
|
||||||
|
action = PA_FIRST;
|
||||||
|
|
||||||
|
if(btnID == KEY_UP) action = PA_ACCEL;
|
||||||
|
else if(btnID == KEY_DOWN) action = PA_BRAKE;
|
||||||
|
else if(btnID == KEY_LEFT) action = PA_LEFT;
|
||||||
|
else if(btnID == KEY_RIGHT) action = PA_RIGHT;
|
||||||
|
else if(btnID == KEY_SPACE) action = PA_FIRE;
|
||||||
|
|
||||||
|
if(action != PA_FIRST)
|
||||||
|
{
|
||||||
|
action_found = true;
|
||||||
|
player = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Act different in input sensing mode.
|
// Act different in input sensing mode.
|
||||||
if (m_mode >= INPUT_SENSE_PREFER_AXIS &&
|
if (m_mode >= INPUT_SENSE_PREFER_AXIS &&
|
||||||
m_mode <= INPUT_SENSE_PREFER_BUTTON)
|
m_mode <= INPUT_SENSE_PREFER_BUTTON)
|
||||||
@ -239,7 +257,9 @@ void InputManager::input(Input::InputType type, int deviceID, int btnID, int axi
|
|||||||
else if (action_found)
|
else if (action_found)
|
||||||
{
|
{
|
||||||
if(StateManager::isGameState())
|
if(StateManager::isGameState())
|
||||||
|
{
|
||||||
RaceManager::getWorld()->getLocalPlayerKart(player)->action(action, abs(value));
|
RaceManager::getWorld()->getLocalPlayerKart(player)->action(action, abs(value));
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// reset timer when released
|
// reset timer when released
|
||||||
|
Loading…
Reference in New Issue
Block a user