fix: issues with Scale Adjuster on 2019 (#703)

Harmony patches were not being loaded for VRCSDK 3.4.x, causing some issues with component enabled state checkboxes being incorrect.

Additionally, we need to reset component states before assembly reload and scene save.
This commit is contained in:
bd_ 2024-02-26 01:56:43 -08:00 committed by GitHub
parent b96ed3113b
commit e06e83daba
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
5 changed files with 37 additions and 13 deletions

View File

@ -1,7 +1,9 @@
#region #region
using System;
using HarmonyLib; using HarmonyLib;
using UnityEditor; using UnityEditor;
using UnityEngine;
#endregion #endregion
@ -9,13 +11,29 @@ namespace nadena.dev.modular_avatar.core.editor.HarmonyPatches
{ {
internal class PatchLoader internal class PatchLoader
{ {
private static readonly Action<Harmony>[] patches = new Action<Harmony>[]
{
SnoopHeaderRendering.Patch1,
SnoopHeaderRendering.Patch2,
HideScaleAdjusterFromPrefabOverrideView.Patch
};
[InitializeOnLoadMethod] [InitializeOnLoadMethod]
static void ApplyPatches() static void ApplyPatches()
{ {
var harmony = new Harmony("nadena.dev.modular_avatar"); var harmony = new Harmony("nadena.dev.modular_avatar");
SnoopHeaderRendering.Patch(harmony); foreach (var patch in patches)
HideScaleAdjusterFromPrefabOverrideView.Patch(harmony); {
try
{
patch(harmony);
}
catch (Exception e)
{
Debug.LogException(e);
}
}
} }
} }
} }

View File

@ -16,7 +16,7 @@ namespace nadena.dev.modular_avatar.core.editor.HarmonyPatches
/// </summary> /// </summary>
internal class SnoopHeaderRendering internal class SnoopHeaderRendering
{ {
internal static void Patch(Harmony harmony) internal static void Patch1(Harmony harmony)
{ {
var t_orig = AccessTools.TypeByName("UnityEditor.UIElements.EditorElement"); var t_orig = AccessTools.TypeByName("UnityEditor.UIElements.EditorElement");
var m_orig = AccessTools.Method(t_orig, "HeaderOnGUI"); var m_orig = AccessTools.Method(t_orig, "HeaderOnGUI");
@ -24,10 +24,15 @@ namespace nadena.dev.modular_avatar.core.editor.HarmonyPatches
var m_prefix = AccessTools.Method(typeof(SnoopHeaderRendering), "Prefix"); var m_prefix = AccessTools.Method(typeof(SnoopHeaderRendering), "Prefix");
harmony.Patch(original: m_orig, prefix: new HarmonyMethod(m_prefix)); harmony.Patch(original: m_orig, prefix: new HarmonyMethod(m_prefix));
}
internal static void Patch2(Harmony harmony)
{
var t_GUIUtility = typeof(GUIUtility); var t_GUIUtility = typeof(GUIUtility);
var m_ProcessEvent = AccessTools.Method(t_GUIUtility, "ProcessEvent"); var m_ProcessEvent = AccessTools.Method(t_GUIUtility, "ProcessEvent");
var m_prefix = AccessTools.Method(typeof(SnoopHeaderRendering), "Prefix");
harmony.Patch(original: m_ProcessEvent, prefix: new HarmonyMethod(m_prefix)); harmony.Patch(original: m_ProcessEvent, prefix: new HarmonyMethod(m_prefix));
} }

View File

@ -1,6 +1,5 @@
{ {
"name": "nadena.dev.modular-avatar.harmony-patches", "name": "nadena.dev.modular-avatar.harmony-patches",
"rootNamespace": "",
"references": [ "references": [
"nadena.dev.modular-avatar.core", "nadena.dev.modular-avatar.core",
"nadena.dev.modular-avatar.core.editor", "nadena.dev.modular-avatar.core.editor",
@ -20,7 +19,7 @@
"versionDefines": [ "versionDefines": [
{ {
"name": "com.vrchat.base", "name": "com.vrchat.base",
"expression": "(3.4.999,)", "expression": "(3.3.99999,)",
"define": "VRCSDK_HAS_HARMONY" "define": "VRCSDK_HAS_HARMONY"
} }
], ],

View File

@ -18,13 +18,15 @@ namespace nadena.dev.modular_avatar.core
private static event Action OnClearAllOverrides; private static event Action OnClearAllOverrides;
private static int RecreateHierarchyIndexCount = 0; private static int RecreateHierarchyIndexCount = 0;
#if UNITY_EDITOR #if UNITY_EDITOR
[UnityEditor.InitializeOnLoadMethod] [UnityEditor.InitializeOnLoadMethod]
static void Setup() static void Setup()
{ {
UnityEditor.EditorApplication.hierarchyChanged += InvalidateAll; UnityEditor.EditorApplication.hierarchyChanged += InvalidateAll;
UnityEditor.AssemblyReloadEvents.beforeAssemblyReload += ClearAllOverrides;
UnityEditor.SceneManagement.EditorSceneManager.sceneSaving += (scene, path) => ClearAllOverrides();
} }
#endif #endif
internal static void InvalidateAll() internal static void InvalidateAll()
{ {
@ -40,7 +42,7 @@ namespace nadena.dev.modular_avatar.core
internal Dictionary<Transform, Transform> BoneMappings = new Dictionary<Transform, Transform>(); internal Dictionary<Transform, Transform> BoneMappings = new Dictionary<Transform, Transform>();
#if UNITY_EDITOR #if UNITY_EDITOR
private void OnValidate() private void OnValidate()
{ {
if (UnityEditor.PrefabUtility.IsPartOfPrefabAsset(this)) return; if (UnityEditor.PrefabUtility.IsPartOfPrefabAsset(this)) return;
@ -61,7 +63,7 @@ namespace nadena.dev.modular_avatar.core
} }
}; };
} }
#endif #endif
private Transform MapBone(Transform bone) private Transform MapBone(Transform bone)
{ {
@ -75,7 +77,7 @@ namespace nadena.dev.modular_avatar.core
ClearAllOverrides(); ClearAllOverrides();
} }
#if UNITY_EDITOR #if UNITY_EDITOR
private void Update() private void Update()
{ {
if (myRenderer == null) if (myRenderer == null)
@ -152,7 +154,7 @@ namespace nadena.dev.modular_avatar.core
// re-disabled; re-enabler it in delayCall in this case. // re-disabled; re-enabler it in delayCall in this case.
UnityEditor.EditorApplication.delayCall += ClearLocalOverride; UnityEditor.EditorApplication.delayCall += ClearLocalOverride;
} }
#endif #endif
private void ClearLocalOverride() private void ClearLocalOverride()
{ {

View File

@ -15,7 +15,7 @@
"com.unity.nuget.newtonsoft-json": "2.0.0" "com.unity.nuget.newtonsoft-json": "2.0.0"
}, },
"vpmDependencies": { "vpmDependencies": {
"com.vrchat.avatars": ">=3.2.0", "com.vrchat.avatars": ">=3.4.0",
"nadena.dev.ndmf": ">=1.3.5 <2.0.0-a" "nadena.dev.ndmf": ">=1.3.5 <2.0.0-a"
} }
} }