spine动画融合与动画叠加
admin
2023-07-30 08:20:37
0

    

一.动画融合setMix

1.概述:两个动作之间的平滑过渡

spine动画融合与动画叠加

参数duration为需要多少时间从fromAnimation过渡到toAnimation,过渡时间为动画重叠时间。

下图为动作切换时的情况(setAnimation),左红线为切换动作时刻,两个红线之间为动作切换时间,这之间动画播放为A与B的混合,A和B所占的权重是不断变化的,从A占的权重从100到0,B占的权重从0到100。右红线之后为动作B完全播放。

spine动画融合与动画叠加

图1

下图是A动作后有B动作的情况(addAnimation)

spine动画融合与动画叠加

图2

下图为错误的示例

spine动画融合与动画叠加

图3

上图是错误,融合不是从A的切换时帧情况过渡到B的的第一帧,而是重叠过渡的。再说一遍,在动画的过渡过程中,A和B所占的权重是不断变化的,从A占的权重从100到0,B占的权重从0到100.下面的代码会证明这件事情

2.代码

  (1)源码:

spine动画融合与动画叠加

可以看到,如果有动作融合,会先spAnimation_apply(preAni)再spAnimation_mix(curAni, alpha)

spine动画融合与动画叠加

那么怎么证明经过这两个变换,动画的权重是由apha值分配的呢?以下面的TransLate平移变换为例

(2)推导,证明动画的权重由apha决定:

平移变换的源码如下:

spine动画融合与动画叠加

定义几个变量:

d1:preAni(之前动作)使原始骨骼x位置的改变值

d2:curAni(目前动作)使原始骨骼x位置的改变值

originX: Tpose中骨骼的x位置(原始位置)

红框中的代码,把+=换成=,代码变为

spine动画融合与动画叠加

等式右面的bone->x为spAnimation_apply(preAni)后的值,即d1 + originX;

又知d2 = [prevFrameX + (self->frames[frameIndex + TRANSLATE_FRAME_X] – prevFrameX)*] * percent;

bone->data->x 为 originX

所以:

bone->x = (originX +d2 -(d1 + originX))*alpha + (d1 + originX)

             = (d2-d1)*alpha + (d1 + originX)

             = originX + alpha * d2 + (1 - alpha)*d1

bone->x= originX + alpha * d2 + (1 - alpha)*d1

3.demo

官方的动画walk动作

spine动画融合与动画叠加

 

官方动画的jump动作

spine动画融合与动画叠加

不融合spine动画融合与动画叠加,动作切换时有明显的生硬效果

spine动画融合与动画叠加

 融合0.2s,walk快播放完了才跳起spine动画融合与动画叠加

spine动画融合与动画叠加

 

融合时间0.7s,spine动画融合与动画叠加walk刚开始,便切换成jump动作 

spine动画融合与动画叠加

 

二.动画叠加(trackIndex)

1.概述:

多层动画叠加,上层动作会覆盖(同一骨骼有动画,若上层骨骼没有动画,下层动画还是正常播放)下层动作

spine动画融合与动画叠加

trackIndex为动画的层数。

2.代码:

还是上图的代码,可以看到for循环中遍历了所有的tracks,后面的tracks会覆盖前面的动画。

3.demo:

官方的打***动画

spine动画融合与动画叠加

walk动作index为0,jump动作index为1,jump动作会覆盖walk动作。

spine动画融合与动画叠加

spine动画融合与动画叠加

walk动作index为1,jump动作index为0,walk动作会覆盖jump动作。

spine动画融合与动画叠加

spine动画融合与动画叠加

 walk和shoot的叠加,就是变走路边打***的效果

spine动画融合与动画叠加

spine动画融合与动画叠加

 备注:spine代码截取的是spine官方代码Version 2.3


相关内容

热门资讯

这位夸赞中国的女人,正在“大闹... 一个民调支持率极高的女人正在大闹德国,她就是选择党(AfD)党首爱丽丝·魏德尔。让欧洲建制派恐惧的是...
特朗普政府发布两项量子与密码安... 2026年6月22日,白宫发布《Ushering in the Next Frontier of Q...
原创 神... 三百多公里之上,一间比小户型客厅还局促的舱段里,一位女性和两位男性要抬头不见低头见地过日子。外界最容...
玩转昼夜交替科学实验 市科技馆... 7月4日市科技馆联合日报社小记者团,开展昼夜交替科学模型制作科普实践活动,帮助同学们在动手实操中了解...
靠谱大容量TF卡推荐:三星T7... Switch一代仍在发光发热,游戏阵容庞大、生态成熟,但32GB(OLED版64GB)的机身存储,早...
蒋方舟的学术不规范和论文造假有... 中国人民大学刚刚发布情况通报,公布了近日沸沸扬扬的“蒋方舟硕士论文涉嫌学术不端”事件调查和处理结果:...
四川绵竹接连发生3次四级以上地... 中国地震台网正式测定:今日23时30分在四川德阳市绵竹市(北纬31.58度,东经104.00度)发生...
大神Karpathy用Clau... 编辑|泽南、杨文 上班真是有毒啊。 连 Andrej Karpathy(安德烈・卡帕西)这样的 AI...
我国成功发射千帆极轨13组卫星 7月4日 据央视新闻 北京时间7月4日17时30分,我国在太原卫星发射中心使用长征六号改运载火箭,成...
业内首个AI-eSIM产业协同... 来源:人民邮电报 7月3日,在中国信息通信业发展高层论坛上,由中国移动发起的业内首个AI-eSIM产...