Animação de sprites sem spritesheet
-
21-12-2019 - |
Pergunta
Eu estou tentando criar uma animação de sprites em cocos2d-js, mas eu não quero usar um spritesheet como eu fiz no meu cocos2d-iphone projeto:
NSMutableArray *animationFrames = [NSMutableArray array];
int frameCount = 0;
for(int i = 1; i <= 9; ++i)
{
CCSpriteFrame *spriteFrame = [CCSpriteFrame frameWithImageNamed:[NSString stringWithFormat:@"hero-%d.png",i]];
[animationFrames addObject:spriteFrame];
}
NSLog(@"cria sprite com frames");
_player = [CCSprite spriteWithSpriteFrame:animationFrames.firstObject];
Como posso fazer isso em cocos2d-js?Eu não encontrar as mesmas funções em cocos2d-js documentação.
Solução
Talvez o código a seguir é um pouco mais complicada, pois ela poderia ser.Mas funciona e cargas de sprites a partir de arquivos e cria uma animação e usa-lo em um runAction no sprite (animFrame é uma matriz vazia, "esse" é um ccLayer).
var str = "";
for (var i = 1; i < 9; i++) {
str = "mosquito_fly" + (i < 10 ? ("0" + i) : i) + ".png";
var texture = cc.textureCache.addImage("res/Murbiks/"+str);
var spriteFrame = cc.SpriteFrame.create(texture,cc.rect(0,0,96,96));
animFrames.push(spriteFrame);
}
var animation = cc.Animation.create(animFrames, 0.06+Math.random()*0.01, 10);
var animate = this.animateMostafa = cc.Animate.create(animation);
// Create sprite and set attributes
mostafa = cc.Sprite.create(res.Mostafa_single_png);
mostafa.attr({
x: 0,
y: 0,
scale: 0.60+Math.random()*0.3,
rotation: 0
});
this.addChild(mostafa, 0);
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow