mirror of
https://github.com/bdunderscore/modular-avatar.git
synced 2024-12-29 18:55:06 +08:00
Preserve local transform when rebinding humanoid avatar (#1062)
* Preserve local transform when rebinding humanoid avatar * Check Animator.avatar * Restore all transforms
This commit is contained in:
parent
2148ab0bfc
commit
3bc090dc7d
@ -81,19 +81,7 @@ namespace nadena.dev.modular_avatar.core.editor.plugin
|
|||||||
FixupExpressionsMenuPass.FixupExpressionsMenu(maContext);
|
FixupExpressionsMenuPass.FixupExpressionsMenu(maContext);
|
||||||
});
|
});
|
||||||
#endif
|
#endif
|
||||||
seq.Run("Rebind humanoid avatar", ctx =>
|
seq.Run(RebindHumanoidAvatarPass.Instance);
|
||||||
{
|
|
||||||
// workaround problem with avatar matching
|
|
||||||
// https://github.com/bdunderscore/modular-avatar/issues/430
|
|
||||||
var animator = ctx.AvatarRootObject.GetComponent<Animator>();
|
|
||||||
if (animator)
|
|
||||||
{
|
|
||||||
var avatar = animator.avatar;
|
|
||||||
animator.avatar = null;
|
|
||||||
// ReSharper disable once Unity.InefficientPropertyAccess
|
|
||||||
animator.avatar = avatar;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
seq.Run("Purge ModularAvatar components", ctx =>
|
seq.Run("Purge ModularAvatar components", ctx =>
|
||||||
{
|
{
|
||||||
foreach (var component in ctx.AvatarRootTransform.GetComponentsInChildren<AvatarTagComponent>(true))
|
foreach (var component in ctx.AvatarRootTransform.GetComponentsInChildren<AvatarTagComponent>(true))
|
||||||
@ -253,6 +241,14 @@ namespace nadena.dev.modular_avatar.core.editor.plugin
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
class RebindHumanoidAvatarPass : MAPass<RebindHumanoidAvatarPass>
|
||||||
|
{
|
||||||
|
protected override void Execute(ndmf.BuildContext context)
|
||||||
|
{
|
||||||
|
new RebindHumanoidAvatar(context).Process();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
class GCGameObjectsPluginPass : MAPass<GCGameObjectsPluginPass>
|
class GCGameObjectsPluginPass : MAPass<GCGameObjectsPluginPass>
|
||||||
{
|
{
|
||||||
protected override void Execute(ndmf.BuildContext context)
|
protected override void Execute(ndmf.BuildContext context)
|
||||||
|
63
Editor/RebindHumanoidAvatar.cs
Normal file
63
Editor/RebindHumanoidAvatar.cs
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
using System.Linq;
|
||||||
|
using UnityEngine;
|
||||||
|
|
||||||
|
namespace nadena.dev.modular_avatar.core.editor.plugin
|
||||||
|
{
|
||||||
|
// workaround problem with avatar matching
|
||||||
|
// https://github.com/bdunderscore/modular-avatar/issues/430
|
||||||
|
internal class RebindHumanoidAvatar
|
||||||
|
{
|
||||||
|
private readonly ndmf.BuildContext _buildContext;
|
||||||
|
|
||||||
|
public RebindHumanoidAvatar(ndmf.BuildContext context)
|
||||||
|
{
|
||||||
|
_buildContext = context;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Process()
|
||||||
|
{
|
||||||
|
var avatarAnimator = _buildContext.AvatarRootObject.GetComponent<Animator>();
|
||||||
|
if (avatarAnimator == null || avatarAnimator.avatar == null) return;
|
||||||
|
|
||||||
|
var localTransformValues = _buildContext.AvatarRootObject
|
||||||
|
.GetComponentsInChildren<Transform>(true)
|
||||||
|
.ToDictionary((t) => t, LocalTransformValue.FromTransform);
|
||||||
|
|
||||||
|
var boundAvatar = avatarAnimator.avatar;
|
||||||
|
avatarAnimator.avatar = null;
|
||||||
|
// ReSharper disable once Unity.InefficientPropertyAccess
|
||||||
|
avatarAnimator.avatar = boundAvatar;
|
||||||
|
|
||||||
|
// resetting avatar also resets local transform value from avatar asset
|
||||||
|
// needs to restore them manually from pre-cache
|
||||||
|
// https://github.com/bdunderscore/modular-avatar/issues/1036
|
||||||
|
foreach (var (transform, preserved) in localTransformValues)
|
||||||
|
{
|
||||||
|
preserved.RestoreToTransform(transform);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct LocalTransformValue
|
||||||
|
{
|
||||||
|
Vector3 Position;
|
||||||
|
Quaternion Rotation;
|
||||||
|
Vector3 Scale;
|
||||||
|
|
||||||
|
internal static LocalTransformValue FromTransform(Transform t)
|
||||||
|
{
|
||||||
|
return new LocalTransformValue
|
||||||
|
{
|
||||||
|
Position = t.localPosition,
|
||||||
|
Rotation = t.localRotation,
|
||||||
|
Scale = t.localScale
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
internal readonly void RestoreToTransform(Transform t)
|
||||||
|
{
|
||||||
|
t.SetLocalPositionAndRotation(Position, Rotation);
|
||||||
|
t.localScale = Scale;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
11
Editor/RebindHumanoidAvatar.cs.meta
Normal file
11
Editor/RebindHumanoidAvatar.cs.meta
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
fileFormatVersion: 2
|
||||||
|
guid: 1f0b7a3de79e73a4f853218f26ed7077
|
||||||
|
MonoImporter:
|
||||||
|
externalObjects: {}
|
||||||
|
serializedVersion: 2
|
||||||
|
defaultReferences: []
|
||||||
|
executionOrder: 0
|
||||||
|
icon: {instanceID: 0}
|
||||||
|
userData:
|
||||||
|
assetBundleName:
|
||||||
|
assetBundleVariant:
|
Loading…
Reference in New Issue
Block a user