cocos2dx骨骼动画Armature源码剖析(一)


Posted in Javascript onSeptember 08, 2015

cocos2dx从编辑器(cocostudio或flash插件dragonBones)得到xml或json数据,调用类似如下所示代码就可以展示出动画效果

ArmatureDataManager::getInstance()->addArmatureFileInfoAsync(
  "armature/Dragon.png", "armature/Dragon.plist", "armature/Dragon.xml",
   this, schedule_selector(TestAsynchronousLoading::dataLoaded));
Armature *armature = nullptr;
armature = Armature::create("Dragon");
armature->getAnimation()->playWithIndex(1);
addChild(armature);

那么调用内部是怎么实现的呢?

Armature::create和armature->getAnimation()->playWithIndex都实现了些什么呢?这几篇文章将从源码上分析Armature。

本文是Armature分析的第一篇,将从整体上对cocos2dx里的骨骼动画进行分析。涉及到内容如下:

什么是骨骼动画

编辑器导出数据格式概览

源码概述

什么是骨骼动画

游戏中的动画大体可以分成下面三种:

帧动画

补间动画(Tween)

骨骼蒙皮动画

帧动画

这个是最基本的动画,也是下面两个动画的基础,一帧展示一张图,cocos2dx Action中Animate就是帧动画。优点是实现简单,缺点是浪费资源(一帧一张图,可对比下面两种动画)。

补间动画

flash中补间动画用的比较多,不需要一帧一张图,只需起始状态和结束状态,中间的状态可以进行根据差值与经过时间计算出来。优点是节省资源,美术人员比较熟悉。

骨骼蒙皮动画

骨骼动画可以认为是补间动画的一种扩展,让动画的各个部分之间产生关联结构(骨骼),之后把图绑定到骨骼上。缺点是程序实现较复杂,其优点较补间动画有下面两点(其他优点暂时没有发现):

1.导出配置数据少并且美术制作简单

假设有一个下面这样结构的骨骼

body

armLeft

handLeft

armRight

handRight

head

legLeft

legRight

假设想在一帧中把动画整体向右移动,采用补间动画需要把body、armLeft、legRight等等全部移动,创建新的帧,而骨骼动画只需移动body的位置,其子节点会跟随父节点移动。对应导出的配置中,补间动画要处理body、armLeft等所有子节点导出的数据,而骨骼动画只有body一个节点数据的改变,导出的数据会小很多。

2.关节裂纹修复

下面的图是偷的《游戏引擎架构》449页,意思是如果美术作图时候不注意,关节链接处可能会有裂缝。采用骨骼动画可以解决这个问题,骨骼动画中的蒙皮可以按权重绑定到多个关节(骨骼中),并且可以按权重进行拉伸,cocostudio骨骼动画编辑器不熟,不知可不可多绑定,flash的dragonBones插件是不行的。 spine 对这种多绑定有不错的支持。

cocos2dx骨骼动画Armature源码剖析(一)

编辑器导出数据格式概览

cocostudio导出的json结构和dragonbones导出的xml结构相似,都是骨骼层,动画层,图片层三层结构,已dragonbones官方的demo为例(有删减):

<skeleton name="DragonBones_Tutorial_MultiBehavior" frameRate="24" version="2.2">
 <armatures>
  <armature name="Dragon">
   <b name="tail" parent="body" x="45.9" y="-70.8" kX="30" kY="30" cX="1" cY="1" pX="11.5" pY="176.35" z="10">
    <d name="parts-tail" pX="0" pY="-63.8"/>
   </b>
  </armature>
 </armatures>
 <animations>
  <animation name="Dragon">
   <mov name="stand" dr="7" to="6" drTW="100" lp="1" twE="0">
   </mov>
   <mov name="walk" dr="8" to="5" drTW="200" lp="1" twE="0">
   </mov>
   <mov name="jump" dr="5" to="3" drTW="5" lp="1" twE="NaN">
   </mov>
   <mov name="fall" dr="5" to="6" drTW="5" lp="1" twE="NaN">
   </mov>
  </animation>
 </animations>
 <TextureAtlas name="DragonBones_Tutorial_MultiBehavior" width="512" height="512">
 </TextureAtlas>
</skeleton>

<armatures></armatures>是骨骼部分,对应flash中1区域,一个layer就是一个bone。

<animations></animations>是动画部分,对应flash中2区域,用帧标签区分哪个动画,比如stand、walk、jump等。

<TextureAtlas></TextureAtlas>是骨骼部分,对应flash中3区域,是皮肤,也就是图信息。

有了这些信息,就可以在程序中还原flash中的动画效果,具体dr、drTW、x、kX、kY等等是什么意思之后的文章里会说。

cocos2dx骨骼动画Armature源码剖析(一)

源码概述

代码大体可以分成xml或json数据的解析 和 用解析出的数据产生动画两部分。

数据解析的相关代码的UML

cocos2dx骨骼动画Armature源码剖析(一)

大致介绍下每个类的作用:

DataReaderHelper:解析armatures、animations、TextureAtlas的数据生成程序能直接使用的数据结构ArmatureData、AnimationData、TextureData。

ArmatureDataManager:管理DataReaderHelper及其解析出来的数据。

ArmatureData:对应xml中的<armature></armature>。

AnimationData:对应xml中的<animation></animation>。

TextureData:对应xml中的<SubTexture></SubTexture>。

BoneData:对应xml中的<b></b>。

DisplayData:对应xml中的<d></d>。

MovementData:对应xml中的<mov></mov>。

MovementBoneData:对应xml中的<mov><b></b></mov>。

FrameData:对应xml中的<mov><b><f></f></b></mov>。

产生动画相关代码的UML

cocos2dx骨骼动画Armature源码剖析(一)

大致介绍下每个类的作用:

Armature:里面包含了骨骼信息及动画信息,有个这个就可以播放动画。

Tween:骨骼动画的补间,一个骨骼一个Tween。对应上面的flash面板就是stand动画的tail层的第一到第七帧。

ArmatureAnimation:所有Tween的集合,够成一个动画。

Bone:带有Tween的骨骼信息,从这里面可以得到某个时间点的骨骼状态。

DisplayFactory:创建skin等显示对象。

DisplayManager:每个Bone中有一个,管理骨骼上的显示对象。

Skin:图的显示对象。

以上内容就是三水点靠木的小编给大家分享的cocos2dx骨骼动画Armature源码剖析(一),希望大家喜欢。

Javascript 相关文章推荐
权威JavaScript 中的内存泄露模式
Aug 13 Javascript
jquery 入门教程 [翻译] 推荐
Aug 17 Javascript
IE与firefox下Dhtml的一些区别小结
Dec 02 Javascript
jQuery 学习第六课 实现一个Ajax的TreeView
May 17 Javascript
jQuery的实现原理的模拟代码 -2 数据部分
Aug 01 Javascript
JavaScript中统计Textarea字数并提示还能输入的字符
Jun 10 Javascript
jquery禁止回车触发表单提交
Dec 12 Javascript
javascript将异步校验表单改写为同步表单
Jan 27 Javascript
JavaScript高级程序设计(第三版)学习笔记1~5章
Mar 11 Javascript
Bootstrap打造一个左侧折叠菜单的系统模板(二)
May 17 Javascript
Vee-Validate的使用方法详解
Sep 22 Javascript
《javascript设计模式》学习笔记七:Javascript面向对象程序设计组合模式详解
Apr 08 Javascript
js带点自动图片轮播幻灯片特效代码分享
Sep 07 #Javascript
jquery实现Slide Out Navigation滑出式菜单效果代码
Sep 07 #Javascript
js图片轮播特效代码分享
Sep 07 #Javascript
基于jQuery全屏焦点图左右切换插件responsiveslides
Sep 07 #Javascript
jquery实现通用的内容渐显Tab选项卡效果
Sep 07 #Javascript
jquery仅用6行代码实现滑动门效果
Sep 07 #Javascript
JavaScript简单下拉菜单实例代码
Sep 07 #Javascript
You might like
php URL跳转代码 减少外链
2011/06/25 PHP
PHP使用CURL实现多线程抓取网页
2015/04/30 PHP
php开发微信支付获取用户地址
2015/10/04 PHP
js下用层来实现select的title提示属性
2010/02/23 Javascript
基于Javascript实现二级联动菜单效果
2016/03/04 Javascript
js 转json格式的字符串为对象或数组(前后台)的方法
2016/11/02 Javascript
在vue2.0中引用element-ui组件库的方法
2018/06/21 Javascript
QQ跳转支付宝并自动领红包脚本(最新)
2018/06/22 Javascript
如何用JavaScript实现功能齐全的单链表详解
2019/02/11 Javascript
详解vue在项目中使用百度地图
2019/03/26 Javascript
Vue.js项目实战之多语种网站的功能实现(租车)
2019/08/07 Javascript
在vue中封装方法以及多处引用该方法详解
2020/08/14 Javascript
[20:46]Ti4循环赛第三日VG vs DK
2014/07/12 DOTA
[00:34]拔城逐梦,热血永恒!2020(秋)完美世界城市挑战赛报名开启
2020/10/09 DOTA
基于Python log 的正确打开方式
2018/04/28 Python
python2与python3中关于对NaN类型数据的判断和转换方法
2018/10/30 Python
python开发游戏的前期准备
2019/05/05 Python
python3 反射的四种基本方法解析
2019/08/26 Python
python tkinter组件摆放方式详解
2019/09/16 Python
Python浮点数四舍五入问题的分析与解决方法
2019/11/19 Python
Python模块相关知识点小结
2020/03/09 Python
python 错误处理 assert详解
2020/04/20 Python
Pycharm2020.1安装无法启动问题即设置中文插件的方法
2020/08/07 Python
英国骑行、跑步、游泳、铁人三项运动装备专卖店:Wiggle
2016/08/23 全球购物
Ellos丹麦:时尚和服装在线
2016/09/19 全球购物
Mountain Warehouse德国官网:英国户外零售商
2019/08/11 全球购物
山海经纬软件测试笔试题和面试题
2013/04/02 面试题
25岁生日感言
2014/01/13 职场文书
自愿解除劳动合同协议书
2014/09/11 职场文书
2014镇副书记群众路线专题民主生活会思想汇报
2014/09/23 职场文书
2015年物资管理工作总结
2015/05/20 职场文书
2015暑假假期总结
2015/07/13 职场文书
个人自我鉴定怎么写?
2019/07/01 职场文书
30岁前绝不能错过的10本书
2019/08/08 职场文书
Win11 引入 Windows 365 云操作系统,适应疫情期间混合办公模式:启动时直接登录、模
2022/04/06 数码科技
mysql sock 文件解析及作用讲解
2022/07/15 MySQL