Cocos2d_x 精灵动画CCAnimation

CCAnimation

其实这个类就是封装了一个Frame序列,作为精灵播放动画的参数,没有别的功能。

Animation* Animation::createWithSpriteFrames(const Vector<SpriteFrame*>& frames, float delay, unsigned int loops)
根据一个Frame数组构建CCAnimation对象,在CCAnimation中Frame序列就是用数组保存的
delay:设置了换帧的时间间隔,默认为0

-(void) addFrame:(CCSpriteFrame*)frame
向Frame序列中添加一个CCSpriteFrame对象。

-(void) addFrameWithFilename:(NSString*)filename
根据资源的文件名创建一个Frame并添加到序列中。

-(void) addFrameWithTexture:(CCTexture2D*)texture rect:(CGRect)rect
根据一个Texture创建一个Frame并添加到序列中。

-(void) setRestoreOriginalFrame(bool restoreOriginalFrame)
设置是否在动画播放结束后恢复到第一帧

CCAnimationCache

是用来缓存CCAnimation的,是一个单例
Cocos2d-x中,动画的具体内容是依靠精灵显示出来的,为了显示动态图片,我们需要不停切换精灵显示的内容,通过把静态的精灵变为动画播放器从而实现动画效果。动画由帧组成,每一帧都是一个纹理,我们可以使用一个纹理序列来创建动画。

我们使用Animation类描述一个动画,而精灵显示动画的动作则是一个Animate对象。动画动作Animate是精灵显示动画的动作,它由一个动画对象创建,并由精灵执行。

+ (CCAnimationCache *)sharedAnimationCache
获取单例

void addAnimation(Animation *animation, const std::string& name);
向池中添加一个CCAnimation对象。

void removeAnimation(const std::string& name);
根据key从池中删除CCAnimation对象。

Animation *animationByName(const std::string& name) { return getAnimation(name);}
根据key从池中获取CCAnimation对象。

-(void)addAnimationsWithDictionary:(NSDictionary *)dictionary
根据一个字典创建CCAnimation对象,并存入内存池。字典中保存的是每个动画的名字,动画中包含哪些帧,换帧间隔是多长。

-(void)addAnimationsWithFile:(NSString *)plist
根据一个plist文件创建CCAnimation对象,并存入内存池。先用文件中的信息生成一个字典,再调用addAnimationsWithDictionary方法来实现。

CCAnimate

这是一个持续型行为类,父类是CCActionInterval,它的作用就是根据CCAnimation中的序列及间隔时间,不断地切换精灵的帧,使其产生动画效果。

+ (id) actionWithAnimation: (CCAnimation*)anim
根据CCSpriteFrame对象生成一个动画播放行为,持续的时间由帧数和间隔时间相乘算出。

+ (id) actionWithAnimation: (CCAnimation*)anim restoreOriginalFrame:(BOOL)b
b为yes时,当动画播放完毕后会切换回播放前显示的帧。

+ (id) actionWithDuration:(ccTime)duration animation: (CCAnimation*)anim restoreOriginalFrame:(BOOL)b
手动设置动画的播放时间,时间到动画才算结束。

cocos2d_x 播放帧动画主要流程

(1)创建CCSpriteFrame数组,可以使用CCSpriteFrameCache或者CCTextureCache
(2)通过帧序列创建CCAnimation对象
(3)通过CCAnimation对象和间隔时间创建CCAnimate,生成一个持续性动作。
(4)使用精灵执行动作

动画创建方法(LUA)

(1)手动添加序列帧到Animation类

local png_file = "sprite.png"
local sprite = self:create_sprite(png_file)
sprite:setPosition(cc.p(0,0))
sprite:setScale(13)
self.view:addChild(sprite)

local texture =  cc.Director:getInstance():getTextureCache():addImage(png_file)
local animation = cc.Animation:create()

for i = 1, 10 do --从纹理中扣了10帧frame,组成序列帧数组
    local rect = cc.rect(i * 18, 0, 18, 32)
    local spriteFrame = cc.SpriteFrame:createWithTexture(texture,rect)
    animation:addSpriteFrame(spriteFrame)
end

animation:setDelayPerUnit(0.1); --播放两张图片的间隔时间
animation:setRestoreOriginalFrame(true); --动画执行后还原初始状态
local action = cc.Animate:create(animation);
local repeat_action = cc.RepeatForever:create(action)
sprite:runAction(repeat_action);

function GameController:create_sprite(png)
    if png == nil then
        Log("png is nil!!")
        return nil
    end

    local sprite_frame = cc.SpriteFrameCache:getInstance():getSpriteFrame(png)
    local sprite = nil
    if sprite_frame then
        sprite = cc.Sprite:createWithSpriteFrame(sprite_frame)
    else
        local texture = cc.Director:getInstance():getTextureCache():addImage(png)
        if texture then
            sprite = cc.Sprite:createWithTexture(texture)
        else
            Log("纹理不存在", png)
        end
    end

    return sprite
end

效果:


sprite.gif

附:有各种不同动作的图片:sprite.png


sprite.jpg

(2)使用文件初始化Animation类
AnimationCache可以加载xml/plist文件,plist文件里保存了组成动画的相关信息,通过该类获取到plist文件里的动画。

使用文件添加的方法只需将创建好的plist文件添加到动画缓存里面,plist文件里包含了序列帧的相关信息。再用动画缓存初始化Animation实例,用Animate实例来播放序列帧动画。

local png_file = "PFBoom.png"
local sprite = self:create_sprite(png_file)
sprite:setPosition(cc.p(0,0))
sprite:setScale(10)
self.view:addChild(sprite)

local animation = cc.Animation:create()
animation:setDelayPerUnit(0.1); --播放两张图片的间隔时间

local cache = cc.SpriteFrameCache:getInstance()
cache:addSpriteFrames("PFBoom.plist") --添加plist文件

for i = 1, 18 do
    local png_name = "Boom_"..i..".png"
    local spriteFrame = cache:getSpriteFrame(png_name)
    animation:addSpriteFrame(spriteFrame)
end

local action = cc.Animate:create(animation);
local call_back = cc.CallFunc:create(handler(self, function ()
    Log("call_back")
end))
local seq = cc.Sequence:create(action, call_back)
local repeat_action = cc.RepeatForever:create(seq)
sprite:runAction(repeat_action)

效果:


PFBoom.gif

附:有各种不同动作的图片:PFBoom.png


PFBoom.png

plist文件:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>frames</key>
    <dict>
        <key>Boom_1.png</key>
        <dict>
            <key>frame</key>
            <string>{{204,305},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_10.png</key>
        <dict>
            <key>frame</key>
            <string>{{103,307},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_11.png</key>
        <dict>
            <key>frame</key>
            <string>{{103,206},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_12.png</key>
        <dict>
            <key>frame</key>
            <string>{{105,2},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_13.png</key>
        <dict>
            <key>frame</key>
            <string>{{103,105},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_14.png</key>
        <dict>
            <key>frame</key>
            <string>{{2,2},{101,101}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{101,101}}</string>
            <key>sourceSize</key>
            <string>{101,101}</string>
        </dict>
        <key>Boom_15.png</key>
        <dict>
            <key>frame</key>
            <string>{{2,408},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_16.png</key>
        <dict>
            <key>frame</key>
            <string>{{2,307},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_17.png</key>
        <dict>
            <key>frame</key>
            <string>{{2,206},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_18.png</key>
        <dict>
            <key>frame</key>
            <string>{{2,105},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_2.png</key>
        <dict>
            <key>frame</key>
            <string>{{204,204},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_3.png</key>
        <dict>
            <key>frame</key>
            <string>{{406,103},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_4.png</key>
        <dict>
            <key>frame</key>
            <string>{{305,103},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_5.png</key>
        <dict>
            <key>frame</key>
            <string>{{204,103},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_6.png</key>
        <dict>
            <key>frame</key>
            <string>{{408,2},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_7.png</key>
        <dict>
            <key>frame</key>
            <string>{{307,2},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_8.png</key>
        <dict>
            <key>frame</key>
            <string>{{206,2},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
        <key>Boom_9.png</key>
        <dict>
            <key>frame</key>
            <string>{{103,408},{99,99}}</string>
            <key>offset</key>
            <string>{0,0}</string>
            <key>rotated</key>
            <false/>
            <key>sourceColorRect</key>
            <string>{{0,0},{99,99}}</string>
            <key>sourceSize</key>
            <string>{99,99}</string>
        </dict>
    </dict>
    <key>metadata</key>
    <dict>
        <key>format</key>
        <integer>2</integer>
        <key>realTextureFileName</key>
        <string>PFBoom.png</string>
        <key>size</key>
        <string>{512,512}</string>
        <key>textureFileName</key>
        <string>PFBoom.png</string>
    </dict>
</dict>
</plist>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容