码迷,mamicode.com
首页 > 其他好文 > 详细

cocos2d-x学习笔记(二)序列帧动画实现的几种方法

时间:2015-08-17 19:44:53      阅读:121      评论:0      收藏:0      [点我收藏+]

标签:cocos2d   序列帧   动画   精灵   

一、cocos2d-x帮助文档中关于动画帧动画的实现有两种方法:

  • 手动添加序列帧到Animation类

  • 使用文件初始化Animation类

这里我就不列出来,大家可以看下官方文档

http://www.cocos.com/doc/article/index?type=cocos2d-x&url=/doc/cocos-docs-master/manual/framework/native/v3/frame-animation/zh.md


二、有些时候我们需要从plist取出指定的几个图片(而不是全部)来播放动画,接下来我们主要介绍下这种方法:


1、首先我们先通过使用SpriteFrameCache来创建精灵帧缓存

    

SpriteFrameCache::getInstance()->addSpriteFramesWithFile("test.plist");


2、假设test.plist中有machine_1.pngmachine_2.png这两个精灵图片,通过createWithSpriteFrameName可以获取精灵:


auto machine = Sprite::createWithSpriteFrameName("machine_1.png");

3、创建一个Vector类型的数据用来存放所需要的精灵帧,通过for循环添加动画精灵


Vector<SpriteFrame*>frameVector;
for(inti=1;i<3;i++)
{
    char pngName[100] = {0};
    sprintf(pngName, "machine_%d.png",i);
    frameVector.pushBack(SpriteFrameCache::getInstance()->getSpriteFrameByName(pngName));
}

4、设置动画参数并播放序列帧动画


//第二个参数是动画执行的持续时间
auto animation = Animation::createWithSpriteFrames(frameVector,0.2);
//设置动画执行完时是否回到原始状态
animation->setRestoreOriginalFrame(false);
//设置动画反复执行的次数
animation->setLoops(10000);
//用动画缓存初始化Animation实例,用Animate实例来播放序列帧动画
auto action = Animate::create(animation);
machine->runAction(Sequence::create(action,action->reverse(), NULL));

5、完整的代码如下:

    

SpriteFrameCache::getInstance()->addSpriteFramesWithFile("test.plist");
//创建精灵machine
auto machine = Sprite::createWithSpriteFrameName("machine_1.png");
machine->setPosition(Vec2(visible.width/2,visible.height/2));
this->addChild(machine,1);
//创建一个Vector类型的数据用来存放所需要的精灵帧
Vector<SpriteFrame*> frameVector;
for( int i=1;i<3;i++)
{
char pngName[100] = {0};
sprintf(pngName, "machine_%d.png", i);
SpriteFrame* pngNameSF = SpriteFrameCache::getInstance()->getSpriteFrameByName(pngName);
frameVector.pushBack(pngNameSF);
}
//第二个参数是动画执行的持续时间
auto animation = Animation::createWithSpriteFrames(frameVector, 0.2);
//设置动画执行完时是否回到原始状态
animation->setRestoreOriginalFrame(false);
//设置动画反复执行的次数
animation->setLoops(10000);
//用动画缓存初始化Animation实例,用Animate实例来播放序列帧动画
auto action = Animate::create(animation);
machine->runAction(Sequence::create(action, action->reverse(), NULL));


cocos2d-x学习笔记(二)序列帧动画实现的几种方法

标签:cocos2d   序列帧   动画   精灵   

原文地址:http://wty530.blog.51cto.com/3238860/1685336

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!