JS中未使用context.drawImage()将图像加载到画布上-基于图块的游戏

时间:2018-10-30 22:41:27

标签: javascript

我正在尝试使用画布在JavaScript / HTML中创建图块地图。我将两个55 x 55像素的.png图像文件用于草地和水的纹理。

在“ for循环”数组期间,此游戏的图块未加载到画布中。这两个图像文件都与.html页面位于同一文件夹级别。

任何帮助将不胜感激。

var canvas = document.getElementById('canvas');
var context = canvas.getContext('2d');
var mapArray = [
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
  [0, 0, 0, 1, 1, 0, 0, 0, 0, 0]
  [0, 0, 0, 1, 1, 0, 0, 0, 0, 0]
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
];

var grass = new Image();
var water = new Image();

grass.src = 'grass_tile.png';
water.src = 'water_tile.png';

var posX = 0;
var PosY = 0;

for (var i = 0; i < mapArray.length; i++) {
  for (var j = 0; j < mapArray[i].length; j++) {
    if (mapArray[i][j] == 0) {
      context.drawImage(grass, posX, PosY, 55, 55);
    }
    if (mapArray[i][j] == 1) {
      context.drawImage(water, posX, PosY, 55, 55);
    }
    posX += 55;
  }
  posX = 0;
  posY += 55;
}
<style>#canvas {
  border: 1px solid black;
}

</style>
<!doctype <!document html>
<html>

<head>
  <meta charset="utf-8">
  <title>GAME</title>
</head>

<body>
  <canvas id="canvas" height="520px" width="520px"></canvas>
</body>

</html>

1 个答案:

答案 0 :(得分:2)

这里有几点:

  1. 您忘记在多维数组中放置逗号。

  2. 在某些地方您拥有变量PosY,在其他地方您拥有posY

  3. 您应该等待图像加载才能绘制它们。

var canvas = document.getElementById('canvas');
var context = canvas.getContext('2d');
var mapArray = [
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
  [0, 0, 0, 1, 1, 0, 0, 0, 0, 0],
  [0, 0, 0, 1, 1, 0, 0, 0, 0, 0],
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
  [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
];

var grass = new Image();
var water = new Image();

grass.src = 'https://fyldegrass.co.uk/wordpress/wp-content/uploads/2016/04/Lytham-Ebay-Top2-128x128.jpg';
water.src = '';


var posX = 0;
var posY = 0;

grass.onload = function () { draw(); };


function draw() {
  for (var i = 0; i < mapArray.length; i++) {
    for (var j = 0; j < mapArray[i].length; j++) {
      if (mapArray[i][j] == 0) {
        context.drawImage(grass, posX, posY, 55, 55);
      }
      if (mapArray[i][j] == 1) {
        context.drawImage(water, posX, posY, 55, 55);
      }
      posX += 55;
    }
    posX = 0;
    posY += 55;
  }
}
<style>#canvas {
  border: 1px solid black;
}

</style>
<!doctype <!document html>
<html>

<head>
  <meta charset="utf-8">
  <title>GAME</title>
</head>

<body>
  <canvas id="canvas" height="520px" width="520px"></canvas>
</body>

</html>