画布加载时精灵未显示

时间:2018-08-31 18:37:16

标签: javascript html canvas

我目前正在从事太空侵略者游戏。但是,我偶然发现了一个问题,当我的画布加载要显示的精灵时,该精灵未显示。我检查了路径,它是正确的。我什至打开了检查器,它显示精灵文件在那里。 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;

};

1 个答案:

答案 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>