我目前正在从事太空侵略者游戏。但是,我偶然发现了一个问题,当我的画布加载要显示的精灵时,该精灵未显示。我检查了路径,它是正确的。我什至打开了检查器,它显示精灵文件在那里。 Sprite
之类的某些功能已在文件中预定义。我正在通过tutorial
var screen, input, frames;
var alSprite, taSprite, ciSprite;
var aliens, dir, tank, bullets, cities;
function main () {
screen = new Screen(510, 600);
input = new InputHandler();
var img = new Image();
img.addEventListener("load", function(){
alSprite = [
[new Sprite(this, 10, 10, 22, 15), new Sprite(this, 0, 16, 22, 16)],
[new Sprite(this, 22, 16, 15), new Sprite(this, 22, 15, 16, 16)],
[new Sprite(this, 38, 0, 24, 16), new Sprite(this, 38, 16, 24, 16)]
];
taSprite = new Sprite(this);
ciSprite = new Sprite(this);
init();
run();
});
img.src = "res/invaders.png";
};
function init() {};
function run() {
var loop = function(){
update();
render();
window.requestAnimationFrame(loop, screen.canvas);
};
};
function update() {};
function render() {
screen.drawSprite(alSp[0][0], 10, 10);
};
canvas{
background-color: #000;
display: block;
position: absolute;
margin: auto;
top: 0;
bottom: 0;
left: 0;
right: 0
}
<!DOCTYPE html>
<html>
<head>
<script src="js/helper.js"></script>
<title></title>
</head>
<body onload="main()">
</body>
</html>
我还包括了helper.js文件。
//Helper function
//Screen
function Screen(width, height){
this.canvas = document.createElement("canvas");
this.canvas.width = this.width = width;
this.canvas.height = this.height = height;
this.ctx = this.canvas.getContext("2d");
document.body.appendChild(this.canvas);
};
Screen.prototype.drawSprite = function(sp, x, y){
this.ctx.drawImage(sp, img, sp.x, sp.y, sp.w, sp.h, x, y, sp.w, sp.h);
};
//Sprite
function Sprite(img, x, y, w, h){
this.img = img;
this.x = x;
this.y = y;
this.w = w;
this.h = h;
};
//InputHandler
function InputHandler() {
this.down = {};
this.pressed = {};
var _this = this;
document.addEventListener("keydown", function(evt){
_this.down[evt.keyCode];
});
document.addEventListener("keyup", function(evt){
delete _this.down[evt.keyCode];
delete _this.pressed[evt.keyCode];
});
};
InputHandler.prototype.isDown = function(code){
return this.down[code];
};
InputHandler.prototype.isPressed = function(code){
if(this.pressed[code]) {
return false;
} else if (this.down[code]) {
return this.pressed[code] = true;
}
return false;
};
答案 0 :(得分:1)
您的代码中存在多个语法错误,就像@Kaiido指出的那样:
drawSprite(alSp[0][0]...
在drawSprite中也应该是:
this.ctx.drawImage(sp.img,
您必须缩小问题的规模,否则它们将使您不知所措。
这是朝正确方向的推动。我确实将图像转换为base64,因此所有内容都在代码段中运行。
function Screen(width, height) {
this.canvas = document.createElement("canvas");
this.canvas.width = this.width = width;
this.canvas.height = this.height = height;
this.ctx = this.canvas.getContext("2d");
document.body.appendChild(this.canvas);
};
Screen.prototype.drawSprite = function(sp, x, y) {
this.ctx.drawImage(sp.img, sp.x, sp.y, sp.w, sp.h, x, y, sp.w, sp.h);
};
function Sprite(img, x, y, w, h) {
this.img = img;
this.x = x; this.y = y;
this.w = w; this.h = h;
};
var screen, frames, alSprite;
function main() {
screen = new Screen(510, 600);
var img = new Image();
img.addEventListener("load", function() {
alSprite = [
[new Sprite(this, 10, 10, 22, 15), new Sprite(this, 0, 16, 22, 16)],
];
run();
});
img.src = "";
};
function run() {
screen.drawSprite(alSprite[0][0], 10, 10);
window.requestAnimationFrame(run, screen.canvas);
};
<body onload="main()"></body>