Merge pull request #9 from DrParanoia/bugfix/fix_map_input
Fixed Controller/Keyboard Inputs not working when a Map is open
This commit is contained in:
commit
3f7dee3142
1 changed files with 41 additions and 1 deletions
|
@ -48,7 +48,7 @@ namespace SRMultiplayer.Patches
|
||||||
|
|
||||||
if (Globals.PauseState == PauseState.Pause)
|
if (Globals.PauseState == PauseState.Pause)
|
||||||
{
|
{
|
||||||
__instance.actions.Enabled = false;
|
__instance.actions.Enabled = true;
|
||||||
__instance.pauseActions.Enabled = true;
|
__instance.pauseActions.Enabled = true;
|
||||||
__instance.engageActions.Enabled = false;
|
__instance.engageActions.Enabled = false;
|
||||||
return false;
|
return false;
|
||||||
|
@ -57,6 +57,46 @@ namespace SRMultiplayer.Patches
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[HarmonyPatch(typeof(MapUI))]
|
||||||
|
[HarmonyPatch("OpenMap")]
|
||||||
|
class FIX_MapUI_OpenMap
|
||||||
|
{
|
||||||
|
static void Postfix(MapUI __instance)
|
||||||
|
{
|
||||||
|
// Fix input mode not refreshing after dying
|
||||||
|
SRInput.instance.SetInputMode(SRInput.InputMode.PAUSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[HarmonyPatch(typeof(vp_FPInput))]
|
||||||
|
[HarmonyPatch("Update")]
|
||||||
|
class FIX_FPInput_Pause
|
||||||
|
{
|
||||||
|
private static bool initialAllowInput = false;
|
||||||
|
|
||||||
|
static void Prefix(vp_FPInput __instance)
|
||||||
|
{
|
||||||
|
if (Globals.IsMultiplayer && Globals.PauseState == PauseState.Pause)
|
||||||
|
{
|
||||||
|
// Save the initial state of the input
|
||||||
|
initialAllowInput = __instance.m_AllowGameplayInput;
|
||||||
|
|
||||||
|
// Disable input so that we don't move when "paused"
|
||||||
|
__instance.m_AllowGameplayInput = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void Postfix(vp_FPInput __instance)
|
||||||
|
{
|
||||||
|
if (Globals.IsMultiplayer && Globals.PauseState == PauseState.Pause)
|
||||||
|
{
|
||||||
|
// Restore any initial value after we've blocked the input
|
||||||
|
// since I have no idea if it should have been initially disabled
|
||||||
|
__instance.m_AllowGameplayInput = initialAllowInput;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
[HarmonyPatch(typeof(PauseMenu))]
|
[HarmonyPatch(typeof(PauseMenu))]
|
||||||
[HarmonyPatch("Update")]
|
[HarmonyPatch("Update")]
|
||||||
class FIX_PauseMenu_Update
|
class FIX_PauseMenu_Update
|
||||||
|
|
Loading…
Reference in a new issue