Slightly better state management
This commit is contained in:
parent
8d835a349c
commit
b9de510fa5
1 changed files with 6 additions and 4 deletions
|
@ -61,13 +61,15 @@ namespace SRMultiplayer.Patches
|
|||
[HarmonyPatch("Update")]
|
||||
class FIX_FPInput_Pause
|
||||
{
|
||||
private static bool prevAllowInput = false;
|
||||
private static bool initialAllowInput = false;
|
||||
|
||||
static void Prefix(vp_FPInput __instance)
|
||||
{
|
||||
prevAllowInput = __instance.m_AllowGameplayInput;
|
||||
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;
|
||||
}
|
||||
|
@ -79,7 +81,7 @@ namespace SRMultiplayer.Patches
|
|||
{
|
||||
// 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 = prevAllowInput;
|
||||
__instance.m_AllowGameplayInput = initialAllowInput;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue