gpt4 book ai didi

javascript - Craftyjs 动画没有正确改变

转载 作者:行者123 更新时间:2023-11-30 18:16:11 25 4
gpt4 key购买 nike

我正在使用 http://craftyjs.com/对于 Github Game Off,我在动画方面遇到了一些麻烦。我第一次启动动画(当我在主场景中初始化播放器实体时)它起作用了。但是当我通过 CustomControls 组件设置动画时,它只播放动画的第一帧。

我认为问题出在 CustomControls 组件中,因此这是相关代码: https://gist.github.com/3992392

如果您想克隆它并进行测试,这里是所有代码:https://github.com/RylandAlmanza/dragons-suck

如果有人知道可能是什么问题,请告诉我。谢谢!

编辑:这是一个最小的 jsfiddle 示例,除了移动和应该是动画的内容之外,所有内容都被删除:http://jsfiddle.net/x7FDF/

var SPRITE_SIZE = 32;
Crafty.init();
Crafty.canvas.init();
Crafty.sprite(SPRITE_SIZE, "http://i.imgur.com/9sN9V.png", {
player_east_1: [0, 0],
player_east_2: [1, 0],
player_east_3: [2, 0],
player_west_1: [0, 1],
player_west_2: [1, 1],
player_west_3: [2, 1],
player_south_1: [0, 2],
player_south_2: [1, 2],
player_south_3: [2, 2],
player_north_1: [0, 3],
player_north_2: [1, 3],
player_north_3: [2, 3]
});

Crafty.scene("loading", function() {
Crafty.background("#000");
Crafty.e("2D, DOM, Text")
.attr({
w: 100,
h: 20,
x: 150,
y: 120
})
.text("Loading")
.css({"text-align": "center"});
Crafty.load(["http://i.imgur.com/9sN9V.png"], function() {
Crafty.scene("main");
});
});

Crafty.scene("main", function() {
Crafty.background("#000");

var player = Crafty.e("2D, DOM, SpriteAnimation, player_east_1, Collision, TileCollision, CustomControls")
.attr({
x: 0,
y: 0,
x_velocity: 0,
y_velocity: 0,
w: SPRITE_SIZE,
h: SPRITE_SIZE
})
.animate("stand_east", 0, 0, 0)
.animate("stand_west", 0, 1, 0)
.animate("stand_south", 0, 2, 0)
.animate("stand_north", 0, 3, 0)
.animate("walk_east", [[0, 0], [1, 0], [0, 0], [2, 0]])
.animate("walk_west", [[0, 1], [1, 1], [0, 1], [2, 1]])
.animate("walk_south", [[0, 2], [1, 2], [0, 2], [2, 2]])
.animate("walk_north", [[0, 3], [1, 3], [0, 3], [2, 3]])
.animate("stand_east", 45, -1)
.CustomControls();
});


Crafty.c("CustomControls", {
CustomControls: function() {
this.bind("EnterFrame", function() {
var up = Crafty.keydown[Crafty.keys.UP_ARROW];
var down = Crafty.keydown[Crafty.keys.DOWN_ARROW];
var left = Crafty.keydown[Crafty.keys.LEFT_ARROW];
var right = Crafty.keydown[Crafty.keys.RIGHT_ARROW];
if (up) {
this.y_velocity = -2;
if (!this.isPlaying("walk_north")) {
this.stop().animate("walk_north", 45, -1);
}
}
if (down) {
this.y_velocity = 2;
if (!this.isPlaying("walk_south")) {
this.stop().animate("walk_south", 45, -1);
}
}
if (left) {
this.x_velocity = -2;
if (!this.isPlaying("walk_west")) {
this.stop().animate("walk_west", 45, -1);
}
}
if (right) {
this.x_velocity = 2;
if (!this.isPlaying("walk_east")) {
this.stop().animate("walk_east", 45, -1);
}
}
if (!left && !right) {
this.x_velocity = 0;
this.stop();
}
if (!up && !down) {
this.y_velocity = 0;
this.stop();
}
this.x += this.x_velocity;
this.y += this.y_velocity;
});
}
});

Crafty.scene("loading");​

最佳答案

"enterFrame" 的末尾,您有:

if (!left && !right) {
this.x_velocity = 0;
this.stop();
}
if (!up && !down) {
this.y_velocity = 0;
this.stop();
}

因此,动画总是停止,然后在下一帧从头重新开始。例如,当您的玩家向下移动时,(!left && !right) 评估为 true 并且动画停止。

一种解决方案是在所有 4 个方向都为假时停止动画。

if (!left && !right) {
this.x_velocity = 0;
}
if (!up && !down) {
this.y_velocity = 0;
}
if (!(up | down | left | right)) {
this.stop();
}

关于javascript - Craftyjs 动画没有正确改变,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13185644/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com