Fix quick access panel autohide/never not working

This commit is contained in:
Tyfon
2024-06-17 12:55:07 -07:00
parent da3ffc170d
commit ece63d9e1e
3 changed files with 58 additions and 18 deletions

View File

@@ -3,7 +3,6 @@ using EFT.InventoryLogic;
using EFT.UI;
using EFT.UI.DragAndDrop;
using HarmonyLib;
using System;
using System.Reflection;
using UnityEngine.EventSystems;

View File

@@ -1,33 +1,74 @@
using Aki.Reflection.Patching;
using Bsg.GameSettings;
using Comfort.Common;
using EFT.InputSystem;
using EFT.InventoryLogic;
using EFT.UI;
using EFT.UI.Settings;
using HarmonyLib;
using System.Reflection;
namespace UIFixes
{
public class FixWeaponBindsDisplayPatch : ModulePatch
public static class QuickAccessPanelPatches
{
protected override MethodBase GetTargetMethod()
public static void Enable()
{
return AccessTools.Method(R.ControlSettings.Type, "GetBoundItemNames");
new FixWeaponBindsDisplayPatch().Enable();
new FixVisibilityPatch().Enable();
}
[PatchPostfix]
public static void Postfix(object __instance, EBoundItem boundItem, ref string __result)
public class FixWeaponBindsDisplayPatch : ModulePatch
{
var instance = new R.ControlSettings(__instance);
switch(boundItem)
protected override MethodBase GetTargetMethod()
{
case EBoundItem.Item1:
__result = instance.GetKeyName(EGameKey.SecondaryWeapon);
break;
case EBoundItem.Item2:
__result = instance.GetKeyName(EGameKey.PrimaryWeaponFirst);
break;
case EBoundItem.Item3:
__result = instance.GetKeyName(EGameKey.PrimaryWeaponSecond);
break;
return AccessTools.Method(R.ControlSettings.Type, "GetBoundItemNames");
}
[PatchPostfix]
public static void Postfix(object __instance, EBoundItem boundItem, ref string __result)
{
var instance = new R.ControlSettings(__instance);
switch (boundItem)
{
case EBoundItem.Item1:
__result = instance.GetKeyName(EGameKey.SecondaryWeapon);
break;
case EBoundItem.Item2:
__result = instance.GetKeyName(EGameKey.PrimaryWeaponFirst);
break;
case EBoundItem.Item3:
__result = instance.GetKeyName(EGameKey.PrimaryWeaponSecond);
break;
}
}
}
public class FixVisibilityPatch : ModulePatch
{
protected override MethodBase GetTargetMethod()
{
return AccessTools.Method(typeof(InventoryScreenQuickAccessPanel), nameof(InventoryScreenQuickAccessPanel.method_4));
}
// BSGs implementation of this method is just straight up wrong, so reimplementing it
[PatchPrefix]
public static bool Prefix(InventoryScreenQuickAccessPanel __instance, bool visible)
{
GameSetting<EVisibilityMode> quickSlotsVisibility = Singleton<SharedGameSettingsClass>.Instance.Game.Settings.QuickSlotsVisibility;
bool disabled = __instance.IsDisabled;
if (visible && !disabled && quickSlotsVisibility != EVisibilityMode.Never)
{
__instance.AnimatedShow(quickSlotsVisibility == EVisibilityMode.Autohide);
}
else
{
__instance.AnimatedHide();
}
return false;
}
}
}

View File

@@ -16,7 +16,7 @@ namespace UIFixes
ConfirmDialogKeysPatches.Enable();
new FixMailRecieveAllPatch().Enable();
FixTooltipPatches.Enable();
new FixWeaponBindsDisplayPatch().Enable();
QuickAccessPanelPatches.Enable();
FocusFleaOfferNumberPatches.Enable();
HideoutSearchPatches.Enable();
HideoutLevelPatches.Enable();