mirror of
https://github.com/bdunderscore/modular-avatar.git
synced 2025-04-04 19:49:02 +08:00
chore: unify the process for get outfit's humanoid bones
This commit is contained in:
parent
b4b7a24a22
commit
6f39151317
@ -133,32 +133,7 @@ namespace nadena.dev.modular_avatar.core.editor
|
||||
outfitRoot = outfitRoot.parent;
|
||||
}
|
||||
|
||||
if (outfitAnimator != null)
|
||||
{
|
||||
var hipsCheck = outfitAnimator.GetBoneTransform(HumanBodyBones.Hips);
|
||||
if (hipsCheck != null && hipsCheck.parent == outfitRoot.transform)
|
||||
{
|
||||
// Sometimes broken rigs can have the hips as a direct child of the root, instead of having
|
||||
// an intermediate Armature object. We do not currently support this kind of rig, and so we'll
|
||||
// assume the outfit's humanoid rig is broken and move on to heuristic matching.
|
||||
outfitAnimator = null;
|
||||
} else if (hipsCheck == null) {
|
||||
outfitAnimator = null;
|
||||
}
|
||||
}
|
||||
|
||||
Dictionary<Transform, HumanBodyBones> humanoidBones = null;
|
||||
if (outfitAnimator != null)
|
||||
{
|
||||
humanoidBones = new Dictionary<Transform, HumanBodyBones>();
|
||||
foreach (HumanBodyBones boneIndex in Enum.GetValues(typeof(HumanBodyBones)))
|
||||
{
|
||||
var bone = boneIndex != HumanBodyBones.LastBone ? outfitAnimator.GetBoneTransform(boneIndex) : null;
|
||||
if (bone == null) continue;
|
||||
humanoidBones[bone] = boneIndex;
|
||||
}
|
||||
}
|
||||
|
||||
var humanoidBones = SetupOutfit.GetOutfitHumanoidBones(outfitRoot, outfitAnimator);
|
||||
HeuristicBoneMapper.RenameBonesByHeuristic(target, humanoidBones: humanoidBones, avatarAnimator: avatarAnimator);
|
||||
}
|
||||
}
|
||||
|
@ -158,32 +158,7 @@ namespace nadena.dev.modular_avatar.core.editor
|
||||
merge.InferPrefixSuffix();
|
||||
|
||||
var outfitAnimator = outfitRoot.GetComponent<Animator>();
|
||||
if (outfitAnimator != null)
|
||||
{
|
||||
var hipsCheck = outfitAnimator.isHuman ? outfitAnimator.GetBoneTransform(HumanBodyBones.Hips) : null;
|
||||
if (hipsCheck != null && hipsCheck.parent == outfitRoot.transform)
|
||||
{
|
||||
// Sometimes broken rigs can have the hips as a direct child of the root, instead of having
|
||||
// an intermediate Armature object. We do not currently support this kind of rig, and so we'll
|
||||
// assume the outfit's humanoid rig is broken and move on to heuristic matching.
|
||||
outfitAnimator = null;
|
||||
} else if (hipsCheck == null) {
|
||||
outfitAnimator = null;
|
||||
}
|
||||
}
|
||||
|
||||
Dictionary<Transform, HumanBodyBones> humanoidBones = null;
|
||||
if (outfitAnimator != null)
|
||||
{
|
||||
humanoidBones = new Dictionary<Transform, HumanBodyBones>();
|
||||
foreach (HumanBodyBones boneIndex in Enum.GetValues(typeof(HumanBodyBones)))
|
||||
{
|
||||
var bone = boneIndex != HumanBodyBones.LastBone ? outfitAnimator.GetBoneTransform(boneIndex) : null;
|
||||
if (bone == null) continue;
|
||||
humanoidBones[bone] = boneIndex;
|
||||
}
|
||||
}
|
||||
|
||||
var humanoidBones = GetOutfitHumanoidBones(outfitRoot.transform, outfitAnimator);
|
||||
var avatarAnimator = avatarRoot.GetComponent<Animator>();
|
||||
List<Transform> subRoots = new List<Transform>();
|
||||
HeuristicBoneMapper.RenameBonesByHeuristic(merge, skipped: subRoots, humanoidBones: humanoidBones, avatarAnimator: avatarAnimator);
|
||||
@ -257,6 +232,37 @@ namespace nadena.dev.modular_avatar.core.editor
|
||||
}
|
||||
}
|
||||
|
||||
internal static Dictionary<Transform, HumanBodyBones> GetOutfitHumanoidBones(Transform outfitRoot, Animator outfitAnimator)
|
||||
{
|
||||
if (outfitAnimator != null)
|
||||
{
|
||||
var hipsCheck = outfitAnimator.isHuman ? outfitAnimator.GetBoneTransform(HumanBodyBones.Hips) : null;
|
||||
if (hipsCheck != null && hipsCheck.parent == outfitRoot)
|
||||
{
|
||||
// Sometimes broken rigs can have the hips as a direct child of the root, instead of having
|
||||
// an intermediate Armature object. We do not currently support this kind of rig, and so we'll
|
||||
// assume the outfit's humanoid rig is broken and move on to heuristic matching.
|
||||
outfitAnimator = null;
|
||||
} else if (hipsCheck == null) {
|
||||
outfitAnimator = null;
|
||||
}
|
||||
}
|
||||
|
||||
Dictionary<Transform, HumanBodyBones> humanoidBones = null;
|
||||
if (outfitAnimator != null)
|
||||
{
|
||||
humanoidBones = new Dictionary<Transform, HumanBodyBones>();
|
||||
foreach (HumanBodyBones boneIndex in Enum.GetValues(typeof(HumanBodyBones)))
|
||||
{
|
||||
var bone = boneIndex != HumanBodyBones.LastBone ? outfitAnimator.GetBoneTransform(boneIndex) : null;
|
||||
if (bone == null) continue;
|
||||
humanoidBones[bone] = boneIndex;
|
||||
}
|
||||
}
|
||||
|
||||
return humanoidBones;
|
||||
}
|
||||
|
||||
private static void FixAPose(GameObject avatarRoot, Transform outfitArmature)
|
||||
{
|
||||
var mergeArmature = outfitArmature.GetComponent<ModularAvatarMergeArmature>();
|
||||
|
Loading…
x
Reference in New Issue
Block a user