mirror of
https://github.com/bdunderscore/modular-avatar.git
synced 2025-01-19 21:00:08 +08:00
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:
parent
b96ed3113b
commit
e06e83daba
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
|
@ -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()
|
||||||
{
|
{
|
||||||
|
@ -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"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user