spine动画融合与动画叠加
spine动画融合与动画叠加
一.动画融合setMix
1.概述:两个动作之间的平滑过渡

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

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

图2
下图为错误的示例

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

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

那么怎么证明经过这两个变换,动画的权重是由apha值分配的呢?以下面的TransLate平移变换为例
(2)推导,证明动画的权重由apha决定:
平移变换的源码如下:

定义几个变量:
d1:preAni(之前动作)使原始骨骼x位置的改变值
d2:curAni(目前动作)使原始骨骼x位置的改变值
originX: Tpose中骨骼的x位置(原始位置)
红框中的代码,把+=换成=,代码变为

等式右面的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动作

官方动画的jump动作

不融合
,动作切换时有明显的生硬效果

融合0.2s,walk快播放完了才跳起

融合时间0.7s,
walk刚开始,便切换成jump动作

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

trackIndex为动画的层数。
2.代码:
还是上图的代码,可以看到for循环中遍历了所有的tracks,后面的tracks会覆盖前面的动画。
3.demo:
官方的打手枪动画

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


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


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


备注:spine代码截取的是spine官方代码Version 2.3
spine动画融合与动画叠加的更多相关文章
- Spine学习五- spine动画融合
在许多地方,都需要用到动画融合,unity的新版动画系统已经能够很方便的进行动画融合,那么使用spine的动画状态机的情况下,如何来进行动画融合呢? 官方有两种方案,一种是使用混合动作实现,另一种是使 ...
- AnimatorController动画融合树
通过Unity动画状态机,能帮我们轻松处理转换各个动画片断,达到想要的效果,但是如果仅仅是一个个动画的硬生生的切换,那么看起来就非常突然,而不真实了,在质量要求比较高的游戏中,特别是动作游戏,我们就不 ...
- jQuery animate方法开发极客标签Logo动画融合效果
在线演示 本地下载 jQuery的animate方法基础使用,演示如何生成一个jQuery animate方法开发极客标签Logo动画融合效果 相关代码录播:jQuery animate方法开发极客标 ...
- Unity---动画系统学习(6)---Avatar Mask动画融合、Layers动画分层、IK反向动力学
1. 介绍 Avatar Mask(动画融合) 前面我们一直介绍的都是动画混合,一般用于解决边跑边转弯的问题.而动画融合一般用于解决例如边跑边挥手的问题. 简单说就是让跑步去控制腿的骨骼,挥手控制手的 ...
- 7种炫酷HTML5 SVG液态水滴融合分解动画特效
这是一组使用HTML5 SVG过滤器制作的炫酷液态水滴融合分解动画特效.这些SVG动画特效使一些HTML元素.如菜单.分页button.APP.选择框等元素的过渡动画像几粒水滴一样融合分解.效果很的酷 ...
- View动画和属性动画
在应用中, 动画效果提升用户体验, 主要分为View动画和属性动画. View动画变换场景图片效果, 效果包括平移(translate), 缩放(scale), 旋转(rotate), 透明(alph ...
- Unity3D Mecanim 动画系统骨骼动画问题解决方法
http://7dot9.com/2014/08/16/unity3d-mecanim%E5%8A%A8%E7%94%BB%E7%B3%BB%E7%BB%9F%E9%AA%A8%E9%AA%BC%E5 ...
- 梅须逊雪三分白,雪却输梅一段香——CSS动画与JavaScript动画
CSS动画并不是绝对比JavaScript动画性能更优越,开源动画库Velocity.js等就展现了强劲的性能. 一.两者的主要区别 先开门见山的说说两者之间的区别. 1)CSS动画: 基于CSS的动 ...
- Android动画:模拟开关按钮点击打开动画(属性动画之平移动画)
在Android里面,一些炫酷的动画确实是很吸引人的地方,让然看了就赏心悦目,一个好看的动画可能会提高用户对软件的使用率.另外说到动画,在Android里面支持3种动画: 逐帧动画(Frame Ani ...
随机推荐
- php数组的使用
<?php echo "<h2>--------普通数组--------</h2>"; $arr1 = array(1,2,3,4); print_r ...
- JAVA基础知识(2)--关键字final的使用
/***Final关键字的使用*@author lihaiming*Email:912547587@qq.com*关键字Final可以修饰属性,方法,类*修饰属性的时候,final修饰的变量是一个常量 ...
- 那些"不务正业"的IT培训公司
前言 大四下期了,现在准备找一份Java开发的实习工作,于是在各大网站上投递简历-智联招聘.51job.拉勾网,慧眼识真金的我必然会把培训机构给过滤掉,对于重庆来说招聘实习的公司少之又少,然而是智联招 ...
- java学习笔记 --- 异常
异常 (1)程序出现的不正常的情况. (2)异常的体系 Throwable |--Error 错误,严重问题,我们不处理. · |--Exception 异常 |--R ...
- SQLServer中间接实现函数索引或者Hash索引
本文出处:http://www.cnblogs.com/wy123/p/6617700.html SQLServer中没有函数索引,在某些场景下查询的时候要根据字段的某一部分做查询或者经过某种计算之后 ...
- [Oracle]同义词(synonym)
(一)同义词的概念 同义词是数据库中表.视图.索引或其他模式对象的别名,与视图相似,同义词不占用实际的存储空间,在数据字典中只存同义词的定义. 在开发数据库时,应尽量避免直接引用表.视图或其他数据库对 ...
- JS中的异步以及事件轮询机制
一.JS为何是单线程的? JavaScript语言的一大特点就是单线程,也就是说,同一个时间只能做一件事.那么,为什么JavaScript不能有多个线程呢?这样能提高效率啊.(在JAVA和c#中的异步 ...
- PRINCE2认证
PRINCE是PRoject IN Controlled Environment(受控环境下的项目管理)的简称. PRINCE2描述了如何以一种逻辑性的.有组织的方法,按照明确的步骤对项目进行管理.它 ...
- Lvs工作原理
DR模式的工作过程: 当一个client发送一个WEB请求到VIP,LVS服务器根据VIP选择对应的real-server的Pool,根据算法,在Pool中选择一台Real-server,LVS在ha ...
- async/await的多线程问题
今天尝试把.net4.5新增的异步编程模型async/await加入自己的框架,因为从第一印象看,使用async/await的写法实在太方便了,以同步代码的方式写异步流程,写起来更顺畅,不容易打断思路 ...