From c111b29fbbfbf8e5571bef120ae8d41cd7b37777 Mon Sep 17 00:00:00 2001 From: bd_ Date: Mon, 22 Apr 2024 10:26:11 +0900 Subject: [PATCH] fix: modular avatar parameters is super slow (#834) --- Editor/ParamsUsage/ParamsUsageEditor.cs | 35 +++++++++++++++---------- 1 file changed, 21 insertions(+), 14 deletions(-) diff --git a/Editor/ParamsUsage/ParamsUsageEditor.cs b/Editor/ParamsUsage/ParamsUsageEditor.cs index 7f1649be..3d255963 100644 --- a/Editor/ParamsUsage/ParamsUsageEditor.cs +++ b/Editor/ParamsUsage/ParamsUsageEditor.cs @@ -36,23 +36,19 @@ namespace nadena.dev.modular_avatar.core.editor } } - private void OnEnable() +#if UNITY_2022_1_OR_NEWER + private bool _delayPending = false; + + private void DelayRecalculate() { - #if UNITY_2022_1_OR_NEWER - ObjectChangeEvents.changesPublished += OnChangesPublished; - #endif + _delayPending = false; Recalculate(); } - -#if UNITY_2022_1_OR_NEWER + private void OnChangesPublished(ref ObjectChangeEventStream stream) { - Recalculate(); - } - - private void OnDisable() - { - ObjectChangeEvents.changesPublished -= OnChangesPublished; + if (!_delayPending) EditorApplication.delayCall += DelayRecalculate; + _delayPending = true; } #endif @@ -65,7 +61,18 @@ namespace nadena.dev.modular_avatar.core.editor _legendContainer = _root.Q("Legend"); _usageBoxContainer = _root.Q("UsageBox"); - Recalculate(); +#if UNITY_2022_1_OR_NEWER + _root.RegisterCallback(_evt => + { + ObjectChangeEvents.changesPublished += OnChangesPublished; + Recalculate(); + }); + + _root.RegisterCallback(_evt => + { + ObjectChangeEvents.changesPublished -= OnChangesPublished; + }); +#endif return _root; } @@ -101,7 +108,7 @@ namespace nadena.dev.modular_avatar.core.editor private void Recalculate() { if (_root == null || !_visible) return; - + var ctx = serializedObject.context as GameObject; if (ctx == null) return;