Revert "fix: remove unnecessory exit transitions for reactive components (#1161)" (#1248)

This reverts commit 9dfa0dae23. Those
transitions are needed when controlling the same object from multiple
parameters.

Closes: #1233
This commit is contained in:
bd_ 2024-10-02 19:03:44 -07:00 committed by GitHub
parent 36e035c8c7
commit 02204c272f
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -300,8 +300,7 @@ namespace nadena.dev.modular_avatar.core.editor
var transitionBuffer = new List<(AnimatorState, List<AnimatorStateTransition>)>(); var transitionBuffer = new List<(AnimatorState, List<AnimatorStateTransition>)>();
var entryTransitions = new List<AnimatorTransition>(); var entryTransitions = new List<AnimatorTransition>();
var initialStateTransitionList = new List<AnimatorStateTransition>(); transitionBuffer.Add((initialState, new List<AnimatorStateTransition>()));
transitionBuffer.Add((initialState, initialStateTransitionList));
foreach (var group in info.actionGroups.Skip(lastConstant)) foreach (var group in info.actionGroups.Skip(lastConstant))
{ {
@ -321,30 +320,33 @@ namespace nadena.dev.modular_avatar.core.editor
var conditions = GetTransitionConditions(asc, group); var conditions = GetTransitionConditions(asc, group);
if (!group.Inverted) foreach (var (st, transitions) in transitionBuffer)
{ {
var transition = new AnimatorStateTransition if (!group.Inverted)
{ {
isExit = true, var transition = new AnimatorStateTransition
hasExitTime = false,
duration = 0,
hasFixedDuration = true,
conditions = (AnimatorCondition[])conditions.Clone()
};
initialStateTransitionList.Add(transition);
}
else
{
foreach (var cond in conditions)
{
initialStateTransitionList.Add(new AnimatorStateTransition
{ {
isExit = true, isExit = true,
hasExitTime = false, hasExitTime = false,
duration = 0, duration = 0,
hasFixedDuration = true, hasFixedDuration = true,
conditions = new[] { InvertCondition(cond) } conditions = (AnimatorCondition[])conditions.Clone()
}); };
transitions.Add(transition);
}
else
{
foreach (var cond in conditions)
{
transitions.Add(new AnimatorStateTransition
{
isExit = true,
hasExitTime = false,
duration = 0,
hasFixedDuration = true,
conditions = new[] { InvertCondition(cond) }
});
}
} }
} }