我正在尝试使用画布在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>
答案 0 :(得分:2)
这里有几点:
您忘记在多维数组中放置逗号。
在某些地方您拥有变量PosY
,在其他地方您拥有posY
。
您应该等待图像加载才能绘制它们。
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>