@ -289,6 +289,9 @@ namespace MWInput
case A_GameMenu :
case A_GameMenu :
toggleMainMenu ( ) ;
toggleMainMenu ( ) ;
break ;
break ;
case A_OptionsMenu :
toggleOptionsMenu ( ) ;
break ;
case A_Screenshot :
case A_Screenshot :
screenshot ( ) ;
screenshot ( ) ;
break ;
break ;
@ -1042,19 +1045,29 @@ namespace MWInput
void InputManager : : toggleMainMenu ( )
void InputManager : : toggleMainMenu ( )
{
{
if ( MyGUI : : InputManager : : getInstance ( ) . isModalAny ( ) ) {
bool state = MWBase : : Environment : : get ( ) . getStateManager ( ) - > getState ( ) = = MWBase : : StateManager : : State_NoGame ;
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > exitCurrentModal ( ) ;
MWGui : : GuiMode mode = MWBase : : Environment : : get ( ) . getWindowManager ( ) - > getMode ( ) ;
if ( mode = = MWGui : : GM_Settings | | ( ! state & & mode = = MWGui : : GM_MainMenu ) )
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > popGuiMode ( ) ;
if ( state | | mode = = MWGui : : GM_MainMenu )
return ;
return ;
}
if ( ! MWBase : : Environment : : get ( ) . getWindowManager ( ) - > isGuiMode ( ) ) //No open GUIs, open up the MainMenu
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > pushGuiMode ( MWGui : : GM_MainMenu ) ;
{
}
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > pushGuiMode ( MWGui : : GM_MainMenu ) ;
}
void InputManager : : toggleOptionsMenu ( )
else //Close current GUI
{
MWGui : : GuiMode mode = MWBase : : Environment : : get ( ) . getWindowManager ( ) - > getMode ( ) ;
if ( mode = = MWGui : : GM_Settings )
{
{
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > exitCurrentGuiMode ( ) ;
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > popGuiMode ( ) ;
return ;
}
}
else if ( mode = = MWGui : : GM_MainMenu & & ! ( MWBase : : Environment : : get ( ) . getStateManager ( ) - > getState ( ) = = MWBase : : StateManager : : State_NoGame ) )
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > popGuiMode ( ) ;
MWBase : : Environment : : get ( ) . getWindowManager ( ) - > pushGuiMode ( MWGui : : GM_Settings ) ;
}
}
void InputManager : : quickLoad ( ) {
void InputManager : : quickLoad ( ) {
@ -1415,12 +1428,12 @@ namespace MWInput
defaultButtonBindings [ A_TogglePOV ] = SDL_CONTROLLER_BUTTON_RIGHTSTICK ;
defaultButtonBindings [ A_TogglePOV ] = SDL_CONTROLLER_BUTTON_RIGHTSTICK ;
defaultButtonBindings [ A_Inventory ] = SDL_CONTROLLER_BUTTON_B ;
defaultButtonBindings [ A_Inventory ] = SDL_CONTROLLER_BUTTON_B ;
defaultButtonBindings [ A_GameMenu ] = SDL_CONTROLLER_BUTTON_START ;
defaultButtonBindings [ A_GameMenu ] = SDL_CONTROLLER_BUTTON_START ;
defaultButtonBindings [ A_ QuickKey sMenu] = SDL_CONTROLLER_BUTTON_BACK ; // Ideally a new menu, A_QuickButtonsMenu should be implemented with only 4 quick keys.
defaultButtonBindings [ A_ Option sMenu] = SDL_CONTROLLER_BUTTON_BACK ;
defaultButtonBindings [ A_QuickSave ] = SDL_CONTROLLER_BUTTON_GUIDE ;
defaultButtonBindings [ A_QuickSave ] = SDL_CONTROLLER_BUTTON_GUIDE ;
defaultButtonBindings [ A_ QuickKey1 ] = SDL_CONTROLLER_BUTTON_DPAD_UP ;
defaultButtonBindings [ A_ MoveForward ] = SDL_CONTROLLER_BUTTON_DPAD_UP ;
defaultButtonBindings [ A_ QuickKey2 ] = SDL_CONTROLLER_BUTTON_DPAD_LEFT ;
defaultButtonBindings [ A_ MoveLeft ] = SDL_CONTROLLER_BUTTON_DPAD_LEFT ;
defaultButtonBindings [ A_ QuickKey3 ] = SDL_CONTROLLER_BUTTON_DPAD_DOWN ;
defaultButtonBindings [ A_ MoveBackward ] = SDL_CONTROLLER_BUTTON_DPAD_DOWN ;
defaultButtonBindings [ A_ QuickKey4 ] = SDL_CONTROLLER_BUTTON_DPAD_RIGHT ;
defaultButtonBindings [ A_ MoveRight ] = SDL_CONTROLLER_BUTTON_DPAD_RIGHT ;
std : : map < int , int > defaultAxisBindings ;
std : : map < int , int > defaultAxisBindings ;
defaultAxisBindings [ A_MoveForwardBackward ] = SDL_CONTROLLER_AXIS_LEFTY ;
defaultAxisBindings [ A_MoveForwardBackward ] = SDL_CONTROLLER_AXIS_LEFTY ;