绘制图像不起作用

drawImage is not working

本文关键字:不起作用 图像 绘制      更新时间:2023-09-26
var canvas = null;
var context = null;
var img = null;
var frames = [];
var assets = [];
var imgLoadCount = 0;
setup = function (fileArray) {
  assets = fileArray;
  //Loading an image
  for(var i = 0; i < assets.length; i++) {
    console.log(i);
    frames.push(new Image()); // declare image object
    frames[i].onload = onImageLoad(assets.length); //declare onload method
    frames[i].src = URL.createObjectURL(assets[i]); //set url 
  }
};
onImageLoad = function (len) {
  console.log("IMAGE!!!");
  canvas = document.getElementById("my_canvas"); //creates a canvas element
  context = canvas.getContext('2d');
  canvas.width = window.innerWidth; //for full screen
  canvas.height = window.innerHeight;
  var x, y, numTilesRow;
  numTilesRow = 10;
  imgLoadCount++;
  console.log("imgLoadCount = " + frames.length + ", length = " + len);
  if(imgLoadCount != len) {
    return;
  }
  for(var index = 0; index < len; index++) {
    x = Math.floor((index % numTilesRow));
    y = Math.floor(index / numTilesRow);
    worldX = x * numTilesRow;
    worldY = y * numTilesRow;
    context.drawImage(frames[index], worldX, worldY);
  }
};

我不知道为什么 drawImage 在插入代码后突然停止工作if(imgLoadCount != len( {return;} 确保所有图像都正确加载。 请有人帮我找到解决这个问题的方法。

您必须了解函数引用和函数调用之间的区别。.onload 属性希望分配一个函数引用,但你为它分配了对函数.onImageLoad的即时 (!( 调用的返回值。区别在于括号()

如果你想调用一个带有参数的函数作为对.onload的回调,那么你必须把它包含在一个匿名函数中(它本身就是一个函数引用(

frames[i].onload = function() {onImageLoad(assets.length);};

当然,有了这个,你创建了一个闭包。这意味着在执行时,onImageLoad()方法将可以访问assets.length的当前值(而不是赋值点的值!但在你的情况下,这没有任何区别,因为assets.length永远不会改变。