- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我遇到一个问题,游戏 Sprite 动画在对 Angular 线移动期间不播放,它只是卡在对 Angular 线动画的第一帧。如果有人知道发生了什么,我将不胜感激。
function init() {
'use strict';
var menuSelected = false;
var shape = new createjs.Shape();
var g = shape.graphics;
shape.graphics.beginFill("#ffffff").drawRect(100, 300, 450, 100, 25);
var $container, canvas, stage, canvasW, canvasH,
manifest, totalLoaded, queue,
map1, mapTiles, game, mapWidth, mapHeight, tileSheet, tiles, board,
player, playerSheet, firstKey,
keysPressed = {
38: 0,
40: 0,
37: 0,
39: 0
};
$container = document.getElementById("container");
canvasW = 640;
canvasH = 416;
map1 = [
[2, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
[2, 1, 1, 1, 0, 0, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
[2, 1, 1, 1, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 1, 1, 1],
[2, 1, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1],
[2, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1],
[2, 1, 1, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1, 0, 0, 0, 0, 1, 1, 1],
[2, 1, 1, 1, 1, 1, 1, 0, 0, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1, 1],
[2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1],
[2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 1, 1],
[2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0],
[2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0],
[2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0],
[2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1],
];
mapTiles = {};
function buildMap(map) {
var row, col, tileClone, tileIndex, defineTile;
if (!board) {
board = new createjs.Container();
board.x = 0;
board.y = 0;
stage.addChild(board);
}
mapWidth = map[0].length;
mapHeight = map.length;
defineTile = {
walkable: function (row, col) {
if (map[row][col] === 0) {
return false;
} else {
return true;
}
}
};
tileIndex = 0;
for (row = 0; row < mapHeight; row++) {
for (col = 0; col < mapWidth; col++) {
tileClone = tiles.clone();
tileClone.name = "t_" + row + "_" + col;
tileClone.gotoAndStop(map[row][col]);
tileClone.x = col * tileSheet._frameWidth;
tileClone.y = row * tileSheet._frameHeight;
mapTiles["t_" + row + "_" + col] = {
index: tileIndex,
walkable: defineTile.walkable(row, col)
};
tileIndex++;
board.addChild(tileClone);
}
}
}
function addPlayer(x, y) {
player.x = x * tileSheet._frameWidth + (tileSheet._frameWidth / 2);
player.y = y * tileSheet._frameHeight + (tileSheet._frameHeight / 2);
player.speed = 6;
player.height = 96;
player.width = 96;
player.gotoAndStop("standDown");
board.addChild(player);
}
function moveChar(char, dirx, diry) {
if (dirx === 0) {
char.y += diry * char.speed;
}
if (diry === 0) {
char.x += dirx * char.speed;
}
}
document.addEventListener("keydown", function (e) {
keysPressed[e.keyCode] = 1;
if (!firstKey) { firstKey = e.keyCode; }
});
document.addEventListener("keyup", function (e) {
if (keysPressed[88] === 1) {
menuSelected = !(menuSelected);
}
keysPressed[e.keyCode] = 0;
if (firstKey === e.keyCode) { firstKey = null; }
if (player.currentAnimation == "walkDown") { player.gotoAndStop("standDown");}
if (player.currentAnimation == "walkRight") { player.gotoAndStop("standRight");}
if (player.currentAnimation == "walkUp") { player.gotoAndStop("standUp");}
if (player.currentAnimation == "walkLeft") { player.gotoAndStop("standLeft");}
if (player.currentAnimation == "walkDiagUpRight") { player.gotoAndStop("standDiagUpRight");}
if (player.currentAnimation == "walkDiagUpLeft") { player.gotoAndStop("standDiagUpLeft");}
if (player.currentAnimation == "walkDiagDownRight") { player.gotoAndStop("standDiagDownRight");}
if (player.currentAnimation == "walkDiagDownLeft") { player.gotoAndStop("standDiagDownLeft");}
});
function detectKeys() {
if (keysPressed[38] === 1) {
if (player.currentAnimation !== "walkUp") { player.gotoAndPlay("walkUp"); }
moveChar(player, 0, -1);
}
if (keysPressed[40] === 1) {
if (player.currentAnimation !== "walkDown") { player.gotoAndPlay("walkDown"); }
moveChar(player, 0, 1);
}
if (keysPressed[37] === 1) {
if (player.currentAnimation !== "walkLeft") { player.gotoAndPlay("walkLeft"); }
moveChar(player, -1, 0);
}
if (keysPressed[39] === 1) {
if (player.currentAnimation !== "walkRight") { player.gotoAndPlay("walkRight"); }
moveChar(player, 1, 0);
}
// diagonal movement
if (keysPressed[38] === 1 && keysPressed[37] === 1) {
player.gotoAndPlay("walkDiagUpLeft");
}
if (keysPressed[38] === 1 && keysPressed[39] === 1) {
player.gotoAndPlay("walkDiagUpRight");
}
if (keysPressed[40] === 1 && keysPressed[37] === 1) {
player.gotoAndPlay("walkDiagDownLeft");
}
if (keysPressed[40] === 1 && keysPressed[39] === 1) {
player.gotoAndPlay("walkDiagDownRight");
}
}
function handleTick() {
detectKeys();
if (menuSelected === true) {
stage.addChild(shape);
}
if (menuSelected === false) {
stage.removeChild(shape);
}
stage.update();
}
function gameInit() {
manifest = [
{src: "img/tileset.png", id: "tiles"},
{src: "img/swordsman-spritesheet.png", id: "player"}
];
totalLoaded = 0;
function handleLoadComplete(event) {
totalLoaded++;
if (totalLoaded < manifest.length) {
console.log(totalLoaded + "/" + manifest.length + " loaded");
}
}
function handleFileLoad(event) {
var img, audio;
if (event.item.type === "image") {
img = new Image();
img.src = event.item.src;
img.onload = handleLoadComplete;
} else if (event.item.type === "sound") {
audio = new Audio();
audio.src = event.item.src;
audio.onload = handleLoadComplete;
}
}
function handleComplete(event) {
buildMap(map1);
addPlayer(3, 4, 0);
}
queue = new createjs.LoadQueue(false);
queue.installPlugin(createjs.SoundJS);
queue.addEventListener("fileload", handleFileLoad);
queue.addEventListener("complete", handleComplete);
queue.loadManifest(manifest);
canvas = document.getElementById("canvas");
stage = new createjs.Stage(canvas);
stage.enableMouseOver(30);
createjs.Touch.enable(stage);
createjs.Ticker.setFPS(30);
createjs.Ticker.useRAF = true;
createjs.Ticker.addEventListener("tick", handleTick);
tileSheet = new createjs.SpriteSheet({
images: ["img/tileset.png"],
frames: {
height: 32,
width: 32,
regX: 0,
regY: 0,
count: 3
}
});
tiles = new createjs.Sprite(tileSheet);
playerSheet = new createjs.SpriteSheet({
animations: {
standRight:[0],
standDown:[32],
standLeft:[57],
standUp:[8],
standDiagUpRight:[16],
standDiagUpLeft:[24],
standDiagDownLeft:[48],
standDiagDownRight:[40],
walkDiagUpRight:[16,23,"walkDiagUpRight"],
walkDiagUpLeft:[24,31,"walkDiagUpLeft"],
walkDiagDownRight:[39,46,"walkDiagDownRight"],
walkDiagDownLeft:[47,55,"walkDiagDownLeft"],
walkRight:[0,7,"walkRight"],
walkLeft:[57,63,"walkLeft"],
walkUp:[8,15,"walkUp"],
walkDown:[32,39,"walkDown"]},
images: ["img/swordsman-spritesheet.png"],
frames: {width:96, height:96, regX:48, regY:48 }
});
player = new createjs.Sprite(playerSheet);
}
gameInit();
}
最佳答案
您的 sprite 动画永远没有机会在对 Angular 线上运行,因为您在每个刻度上调用 detectKeys()
,如果对 Angular 键组合评估为真,它会重新开始动画。通过首先检查您的玩家是否已经在 gotoAndPlay 之前行走,您在常规行走动画中有了正确的想法,如下所示:
if (keysPressed[38] === 1) {
if (player.currentAnimation !== "walkUp") { player.gotoAndPlay("walkUp"); }
moveChar(player, 0, -1);
}
您也需要为您的对 Angular 线执行此操作。像这样的东西:
if (keysPressed[38] === 1 && keysPressed[37] === 1) {
if(player.currentAnimation !== "walkDiagUpLeft") { player.gotoAndPlay("walkDiagUpLeft"); }
}
关于javascript - EaselJS( Sprite 动画不会在对 Angular 线方向播放),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21472487/
尝试使用集成到 QTCreator 的表单编辑器,但即使我将插件放入 QtCreator.app/Contents/MacOS/designer 也不会显示。不过,相同的 dylib 文件确实适用于独
在此代码示例中。 “this.method2();”之后会读到什么?在返回returnedValue之前会跳转到method2()吗? public int method1(int returnedV
我的项目有通过gradle配置的依赖项。我想添加以下依赖项: compile group: 'org.restlet.jse', name: 'org.restlet.ext.apispark', v
我将把我们基于 Windows 的客户管理软件移植到基于 Web 的软件。我发现 polymer 可能是一种选择。 但是,对于我们的使用,我们找不到 polymer 组件具有表格 View 、下拉菜单
我的项目文件夹 Project 中有一个文件夹,比如 ED 文件夹,当我在 Eclipse 中指定在哪里查找我写入的文件时 File file = new File("ED/text.txt"); e
这是奇怪的事情,这个有效: $('#box').css({"backgroundPosition": "0px 250px"}); 但这不起作用,它只是不改变位置: $('#box').animate
这个问题在这里已经有了答案: Why does OR 0 round numbers in Javascript? (3 个答案) 关闭 5 年前。 Mozilla JavaScript Guide
这个问题在这里已经有了答案: Is the function strcmpi in the C standard libary of ISO? (3 个答案) 关闭 8 年前。 我有一个问题,为什么
我目前使用的是共享主机方案,我不确定它使用的是哪个版本的 MySQL,但它似乎不支持 DATETIMEOFFSET 类型。 是否存在支持 DATETIMEOFFSET 的 MySQL 版本?或者有计划
研究 Seam 3,我发现 Seam Solder 允许将 @Named 注释应用于包 - 在这种情况下,该包中的所有 bean 都将自动命名,就好像它们符合条件一样@Named 他们自己。我没有看到
我知道 .append 偶尔会增加数组的容量并形成数组的新副本,但 .removeLast 会逆转这种情况并减少容量通过复制到一个新的更小的数组来改变数组? 最佳答案 否(或者至少如果是,则它是一个错
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
noexcept 函数说明符是否旨在 boost 性能,因为生成的对象中可能没有记录异常的代码,因此应尽可能将其添加到函数声明和定义中?我首先想到了可调用对象的包装器,其中 noexcept 可能会产
我正在使用 Angularjs 1.3.7,刚刚发现 Promise.all 在成功响应后不会更新 angularjs View ,而 $q.all 会。由于 Promises 包含在 native
我最近发现了这段JavaScript代码: Math.random() * 0x1000000 10.12345 10.12345 >> 0 10 > 10.12345 >>> 0 10 我使用
我正在编写一个玩具(物理)矢量库,并且遇到了 GHC 坚持认为函数应该具有 Integer 的问题。是他们的类型。我希望向量乘以向量以及标量(仅使用 * ),虽然这可以通过仅使用 Vector 来实现
PHP 的 mail() 函数发送邮件正常,但 Swiftmailer 的 Swift_MailTransport 不起作用! 这有效: mail('user@example.com', 'test
我尝试通过 php 脚本转储我的数据,但没有命令行。所以我用 this script 创建了我的 .sql 文件然后我尝试使用我的脚本: $link = mysql_connect($host, $u
使用 python 2.6.4 中的 sqlite3 标准库,以下查询在 sqlite3 命令行上运行良好: select segmentid, node_t, start, number,title
我最近发现了这段JavaScript代码: Math.random() * 0x1000000 10.12345 10.12345 >> 0 10 > 10.12345 >>> 0 10 我使用
我是一名优秀的程序员,十分优秀!