mirror of
https://github.com/bdunderscore/modular-avatar.git
synced 2025-01-01 20:25:07 +08:00
fix: multiple animation generation bugs in shape changer (#867)
This commit is contained in:
parent
66f3e7075c
commit
14897926bb
@ -303,13 +303,13 @@ namespace nadena.dev.modular_avatar.core.editor
|
||||
},
|
||||
new ChildMotion()
|
||||
{
|
||||
motion = delTree,
|
||||
motion = AnimResult(info.ShapeKey, 100),
|
||||
timeScale = 1,
|
||||
threshold = 0.6f
|
||||
},
|
||||
new ChildMotion()
|
||||
{
|
||||
motion = delTree,
|
||||
motion = AnimResult(info.ShapeKey, 100),
|
||||
timeScale = 1,
|
||||
threshold = 1
|
||||
},
|
||||
@ -366,6 +366,8 @@ namespace nadena.dev.modular_avatar.core.editor
|
||||
childMotions.Add(initMotion);
|
||||
paramNames.Add(MergeBlendTreePass.ALWAYS_ONE);
|
||||
initialValues[MergeBlendTreePass.ALWAYS_ONE] = 1;
|
||||
initialValues[setParam] = 0;
|
||||
initialValues[delParam] = 0;
|
||||
|
||||
foreach (var group in groups)
|
||||
{
|
||||
@ -455,19 +457,16 @@ namespace nadena.dev.modular_avatar.core.editor
|
||||
var paramList = animController.parameters.ToList();
|
||||
var paramSet = paramList.Select(p => p.name).ToHashSet();
|
||||
|
||||
foreach (var paramName in FindParams(bt))
|
||||
{
|
||||
if (!paramSet.Contains(paramName))
|
||||
foreach (var paramName in initialValues.Keys.Except(paramSet))
|
||||
{
|
||||
paramList.Add(new AnimatorControllerParameter()
|
||||
{
|
||||
name = paramName,
|
||||
type = AnimatorControllerParameterType.Float,
|
||||
defaultFloat = 0, // TODO
|
||||
defaultFloat = initialValues[paramName], // TODO
|
||||
});
|
||||
paramSet.Add(paramName);
|
||||
}
|
||||
}
|
||||
|
||||
animController.parameters = paramList.ToArray();
|
||||
|
||||
@ -558,7 +557,11 @@ namespace nadena.dev.modular_avatar.core.editor
|
||||
shapeKeys[key] = info;
|
||||
|
||||
// Add initial state
|
||||
info.setObjects.Add(new ActionGroupKey(asc, key, null, shape));
|
||||
var agk = new ActionGroupKey(asc, key, null, shape);
|
||||
agk.IsDelete = false;
|
||||
agk.InitiallyActive = true;
|
||||
agk.Value = renderer.GetBlendShapeWeight(shapeId);
|
||||
info.setObjects.Add(agk);
|
||||
}
|
||||
|
||||
var action = new ActionGroupKey(asc, key, changer.gameObject, shape);
|
||||
|
Loading…
Reference in New Issue
Block a user