Cocos Creator js动画精灵

问题描述 投票:0回答:1

我使用精灵表和更新函数为精灵设置了动画,如下所示:

注意:我已将plist拖动到Ccos Creator UI中sprite节点(与monster.js脚本相连的节点)的atlas字段中。

//monster.js
onLoad: function(){
// change monsters face
            this.faces['1'] =  'monster1';
            this.faces['2'] =  'monster2';
            this.faces['3'] =  'Rmonster1';
            this.faces['4'] =  'Rmonster2';

}
    update: function (dt) {


    this.timekeep += dt;

    if(this.timekeep > 0.1){

var self = this;
          cc.loader.loadRes('monsters', cc.SpriteAtlas, function (err, atlas) {
  self.getComponent(cc.Sprite).spriteFrame = atlas.getSpriteFrame(self.faces[self.monstersN]);
});     

                this.timekeep = 0;

                this.monstersN++;
                if(this.monstersN > 4){

                    this.monstersN = 1;

                }
            }

它实际上工作正常。我已经认为我应该将cc.loader.loaderRes导出到onLoad函数中,并将atlas保存为全局var,而不是每次调用更新时都加载。

但是......看到内置的动画功能,这可能不是正确的解决方案。所以我尝试了这个:

onLoad: function () {
            // change monster face
            this.faces['1'] =  'monster1';
            this.faces['2'] =  'monster2';
            this.faces['3'] =  'Rmonster1';
            this.faces['4'] =  'Rmonster2';
            var self = this;
                  cc.loader.loadRes('monsters', cc.SpriteAtlas, function (err, atlas) {
var sprite = self.getComponent(cc.Sprite);

        var animFrames = [];
 for (var i = 1; i < 4; i++) {   
     var spriteFrame = atlas.getSpriteFrame(self.faces[i]);
        var animFrame = new cc.AnimationFrame();
            animFrame.initWithSpriteFrame(spriteFrame, 1, null);
        animFrames.push(animFrame);
 }      
 var animation = sprite.Animation.create(animFrames, 0.2, 100);
    var animate   = sprite.Animate.create(animation); 

    sprite.runAction(animate); 
              });    


        },

我收到此错误:

cc.AnimationFrame不是构造函数

那么我试过这个:

onLoad: function () {

            // change monster face
            this.faces['1'] =  'monster1';
            this.faces['2'] =  'monster2';
            this.faces['3'] =  'Rmonster1';
            this.faces['4'] =  'Rmonster2';
            var self = this;
                  cc.loader.loadRes('monsters', cc.SpriteAtlas, function (err, atlas) {
self.atlasA = atlas;
              });    

 var sprite = this.getComponent(cc.Sprite);

        var animFrames = [];
 for (var i = 1; i < 4; i++) {   
     var spriteFrame = this.atlasA.getSpriteFrame(this.faces[i]);
    var animFrame = new cc.AnimationFrame();
        animFrame.initWithSpriteFrame(spriteFrame, 1, null);
    animFrames.push(animFrame);
 }      
 var animation = sprite.Animation.create(animFrames, 0.2, 100);
var animate   = sprite.Animate.create(animation); 

sprite.runAction(animate); 

        },

我收到此错误:

无法读取未定义的属性'getSpriteFrame'

如何使用cc.animate使用我的spritesheet更改精灵。我想要实现的是按照图片在plist中的顺序移动plist,重复直到怪物被放回到它来自的池中。

animation sprite cocos2d-x cocoscreator
1个回答
0
投票

这是任何可能仍在寻找的人的解决方案.....

cc.AnimationClip.createWithSpriteFrames([sf1, sf2, ...], fps)
© www.soinside.com 2019 - 2024. All rights reserved.