繁体   English   中英

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

[英]Images not loading to canvas with context.drawImage() in JS - Tile based Game

我正在尝试使用画布在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. 您忘记在多维数组中放置逗号。

  2. 在某些地方您拥有var 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> 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM