braindead

This commit is contained in:
NotAKidoS 2023-03-17 00:13:46 -05:00
parent 453d8023c1
commit ea1e0da1ce
2 changed files with 107 additions and 108 deletions

View file

@ -4,10 +4,10 @@ using cohtml;
using HarmonyLib;
using UnityEngine;
namespace NAK.Melons.FuckMetrics
namespace NAK.Melons.FuckMetrics;
public static class FuckMetrics
{
public static class FuckMetrics
{
public enum SettingState
{
Always,
@ -75,16 +75,16 @@ namespace NAK.Melons.FuckMetrics
{
if (!FuckMetricsMod.EntryDisableCohtmlViewOnIdle.Value) return;
// Don't execute if menu is open
if (cohtmlView == null || menuOpenTraverse.GetValue<bool>()) return;
FuckMetricsMod.Logger.Msg(cohtmlView != null && !menuOpenTraverse.GetValue<bool>());
FuckMetricsMod.Logger.Msg(menuOpenTraverse.GetValue<bool>());
// Disable cohtmlView (opening should enable)
if (cohtmlView != null && !menuOpenTraverse.GetValue<bool>())
{
cohtmlView.enabled = false;
// Death
try
{
if (cohtmlView.m_UISystem != null) cohtmlView.View.Advance(cohtmlView.m_UISystem.Id, (double)Time.unscaledTime * 1000.0);
cohtmlView.View.Advance(cohtmlView.m_UISystem?.Id ?? 0, (double)Time.unscaledTime * 1000.0);
}
catch (Exception e)
{

View file

@ -3,10 +3,10 @@ using ABI_RC.Core.IO;
using cohtml;
using HarmonyLib;
namespace NAK.Melons.FuckMetrics.HarmonyPatches
namespace NAK.Melons.FuckMetrics.HarmonyPatches;
public static class CVR_MenuManagerPatches
{
public static class CVR_MenuManagerPatches
{
[HarmonyPostfix]
[HarmonyPatch(typeof(CVR_MenuManager), "ToggleQuickMenu", new Type[] { typeof(bool) })]
private static void Postfix_CVR_MenuManager_ToggleQuickMenu(bool show)
@ -14,10 +14,10 @@ namespace NAK.Melons.FuckMetrics.HarmonyPatches
FuckMetrics.ApplyMetricsSettings(show);
FuckMetrics.ApplyCoreUpdatesSettings(show);
}
}
}
public static class ViewManagerPatches
{
public static class ViewManagerPatches
{
[HarmonyPostfix]
[HarmonyPatch(typeof(ViewManager), "UiStateToggle", new Type[] { typeof(bool) })]
private static void Postfix_ViewManager_UiStateToggle(bool show)
@ -25,10 +25,10 @@ namespace NAK.Melons.FuckMetrics.HarmonyPatches
FuckMetrics.ApplyMetricsSettings(show);
FuckMetrics.ApplyCoreUpdatesSettings(show);
}
}
}
public static class CohtmlViewPatches
{
public static class CohtmlViewPatches
{
private static CohtmlView _quickMenuView;
private static CohtmlView _gameMenuView;
private static Traverse _quickMenuOpenTraverse;
@ -36,19 +36,19 @@ namespace NAK.Melons.FuckMetrics.HarmonyPatches
[HarmonyPostfix]
[HarmonyPatch(typeof(CVR_MenuManager), "Start")]
private static void Postfix_CVRMenuManager_Start(ref CohtmlView ___quickMenu)
private static void Postfix_CVRMenuManager_Start(ref CVR_MenuManager __instance, ref CohtmlView ___quickMenu)
{
_quickMenuView = ___quickMenu;
_quickMenuOpenTraverse = Traverse.Create<CVR_MenuManager>().Field("_quickMenuOpen");
_quickMenuOpenTraverse = Traverse.Create(__instance).Field("_quickMenuOpen");
SchedulerSystem.AddJob(() => FuckMetrics.CohtmlAdvanceView(_quickMenuView, _quickMenuOpenTraverse), 15f, 6f, -1);
}
[HarmonyPostfix]
[HarmonyPatch(typeof(ViewManager), "Start")]
private static void Postfix_ViewManager_Start(ref CohtmlView ___gameMenuView)
private static void Postfix_ViewManager_Start(ref ViewManager __instance, ref CohtmlView ___gameMenuView)
{
_gameMenuView = ___gameMenuView;
_gameMenuOpenTraverse = Traverse.Create<ViewManager>().Field("_gameMenuOpen");
_gameMenuOpenTraverse = Traverse.Create(__instance).Field("_gameMenuOpen");
SchedulerSystem.AddJob(() => FuckMetrics.CohtmlAdvanceView(_gameMenuView, _gameMenuOpenTraverse), 12f, 6f, -1);
}
@ -61,5 +61,4 @@ namespace NAK.Melons.FuckMetrics.HarmonyPatches
CVR_MenuManager.Instance.SendCoreUpdate();
}
}
}
}