(22)–动画类

最后更新于:2022-04-01 19:59:46

小满(bill man)个人原创,欢迎转载,转载请注明地址,小满(bill man)的专栏地址http://blog.csdn.net/bill_man 上一篇主要讲的是精灵类,和精灵类经常配合的就是动画类,动画类也有非常多的特性和应用。 建立动画帧集合,即导入贴图文件.png和导入贴图文件的配置文件.plist,如下例所示 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-04-26_571f3f133de6f.gif) 首先是获得cache,然后是通过addSpriteFrameWithFile加入贴图文件.png和导入贴图文件的配置文件.plist,第一个参数为.plist的路径,第二个参数为.png文件的路径,一个参数的函数的png文件的文件名与.plist文件相同。也就是说第一个addSpriteFrameWithFile的贴图文件的路径为animations/grossini.png。 关于plist文件,网上有一些工具可以生成,当然你可以使用Zwoptex(需付费),其实只是生成一个配置文件而已,你也可以自己编写这个小工具(本人打算尝试一下),plist文件的结构很像xml等文件,编写一个这样的工具也不是难事。当然,网上也有一些这样的工具。 2.生成逐帧动画CCSpriteFrame,见下图代码 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-04-26_571f3f134c334.gif) 首先通过CCMutableArray生成一个CCSpriteFrame数组,然后通过循环初始化每一帧的内容,每帧的CCSpriteFrame通过上面定义好的cache获得。 3.生成CCAnimation   这个步骤很简单,就是通过CCSpriteFrame数组生成CCAnimation ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-04-26_571f3f135e46a.gif) 这个函数有一个可选的参数,就是每帧的延迟,见api ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-04-26_571f3f136fdd6.gif) 这个就是一个参数的 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-04-26_571f3f1381bf9.gif) 第二个参数就是延迟时间 4.定义并执行CCAnimate  到这一步,终于可以定义动画了,第一个参数是CCAnimation,第二个参数如果置为true那么将在动画结束回到原始帧,否则将不会回到原始帧。如下例 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-04-26_571f3f139448e.gif) 当然,如果觉得这个步骤繁琐,有一种相对简便的,就是不通过cache,而是从贴图生成每帧的数组,之后的步骤同上。 首先,通过贴图逐帧生成数组,如下 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-04-26_571f3f13a3e8a.gif) 然后在生成CCAnimation,进一步再CCAnimate,如下 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-04-26_571f3f13b820f.gif) 补充CCSprite的一个知识点,就是通过reorderChild来改变精灵的层次,从而改变遮挡关系 刚开始研究此引擎,如有错误之处,希望大家多多指正 下一篇写一下schduler和控制屏幕朝向
';