js canvas drawImage 不适用于循环变量
js canvas drawImage not working with loop variable
我正在尝试将某些条件的图像加载到画布中,但仅当我为 drawImage()(带有常量注释的 drawImage )函数提供常量作为参数时,才会加载图像。只要我使用常量作为参数,我就可以根据需要将任意数量的图像副本添加到画布上。我的代码有什么问题?请帮忙..
代码如下:
.JS:
slotSize=50px;
playArea=9;
var grid=[];
function renderGrid(grid)
{
for(var i=0,y=0;i<playArea;i++,y+=slotSize)
{
for(var j=0,x=0;j<playArea;j++,x+=slotSize)
{
ctx.fillStyle=grid[i][j];
if(grid[i][j]=="white")
{
grass=new Image();
grass.onload=function()
{
//console.log(x+","+y);
ctx.drawImage(grass,x,y,slotSize-2,slotSize-2);
//ctx.drawImage(grass,0,0,slotSize-2,slotSize-2); works!
}
grass.src="../assets/grass.jpg";
}
else
{
ctx.fillRect(x,y,slotSize,slotSize);
}
ctx.strokeRect(x,y,slotSize,slotSize);
}
}
}
window.onload=function loadLocal()
{
canvas=document.getElementById("canvas");
ctx = canvas.getContext("2d");
for(var i=0;i<playArea;i++)
{
grid[i]=[];
}
for(var i=0;i<playArea;i++)
{
for(var i=j;i<playArea;i++)
{
grid[i][j]="white";
}
}
renderGrid();
}
.HTML:
<canvas id="canvas" width="450" height="450">
Your browser does not support the canvas element.
http://plnkr.co/edit/h6H3UN45sS6mxtQHlLUz?p=preview
所以基本上你想先了解更多关于变量的上下文和范围。然后,您想了解有关偶数侦听器以及如何在异步环境中进行通信的更多信息。
欢迎提问和评论!
var slotSize=50;
var playArea=9;
var grid=[];
var canvas, ctx;
var grass=new Image();
function renderGrid()
{
for(var i=0,y=0;i<playArea;i++,y+=slotSize)
{
for(var j=0,x=0;j<playArea;j++,x+=slotSize)
{
var value = grid[i][j];
ctx.fillStyle = value;
if(grid[i][j]=="white")
{
console.log(x,y);
ctx.drawImage(grass,x,y,slotSize-2,slotSize-2);
}
else
{
ctx.fillRect(x,y,slotSize,slotSize);
}
ctx.strokeRect(x,y,slotSize,slotSize);
}
}
}
window.onload=function loadLocal()
{
canvas=document.getElementById("canvas");
ctx = canvas.getContext("2d");
for(var i=0;i<playArea;i++)
{
grid[i]=[];
for(var j=i;j<playArea;j++)
{
grid[i][j]="white";
}
}
grass.onload = renderGrid;
grass.src = "http://images.clipartpanda.com/grass-clipart-grass-md.png";
}
相关文章:
- 如何在Javascript函数调用中循环变量
- Jquery将循环变量绑定到getJSON函数
- 如何使用jQuery循环变量名
- FileReader加载端中循环变量的值
- 为什么 CoffeScript 不“重用”循环变量
- 循环变量的Javascript不起作用
- 循环变量作为异步函数调用中的参数
- 将循环变量调用到自动压缩选择中
- Javascript 循环变量
- 如何使用以 js 为单位递增的字符串创建 for 循环变量
- JQuery:如何在 jquery 选择器中使用 for 循环变量
- 余烬每循环加倍.使用内部每个循环变量的值绑定到外部每个循环的变量中命名相同的属性
- 处理循环变量的重复声明警告
- 如何将递增的 for 循环变量传递给 node.js 中的函数
- 如何处理来自函数和与垃圾回收器有关的函数的循环变量
- 如何将循环变量传递给元素
- js canvas drawImage 不适用于循环变量
- 在 Jquery 中添加循环变量并存储在输入字段中
- 使用 for 循环变量更改 html 类的名称
- 通过循环变量引用Javascript数组元素