HTML5 canvas createImageData() 方法

实例

创建 100*100 像素的 ImageData

Your browser does not support the HTML5 canvas tag.

JavaScript:

var c=document.getElementById("myCanvas");
var ctx=c.getContext("2d");
var imgData=ctx.createImageData(100,100);
for (var i=0;i<imgData.data.length;i+=4)
  {
  imgData.data[i+0]=255;
  imgData.data[i+1]=0;
  imgData.data[i+2]=0;
  imgData.data[i+3]=255;
  }
ctx.putImageData(imgData,10,10);

Internet Explorer 9、Firefox、Opera、Chrome 以及 Safari 支持 createImageData() 方法。

注释:Internet Explorer 8 <canvas> 元素。

createImageData() 的空白 ImageData 素值 transparent black。

对于 ImageData 即 RGBA 值:

  • R - 红色 (0-255)
  • G - 绿色 (0-255)
  • B - 蓝色 (0-255)
  • A - alpha 通道 (0-255; 0 255 的)

因此 ,transparent black 表示 (0,0,0,0)。

color/alpha 大小是 ImageData ImageDataObject.data.length)

包含 color/alpha 存储于 ImageData 对象的 data 属性中。

提示:数组中的 color/alpha putImageData() 画布上。

例子:

该语法把 ImageData 为红色:

imgData=ctx.createImageData(100,100);

imgData.data[0]=255;
imgData.data[1]=0;
imgData.data[2]=0;
imgData.data[3]=255;

该语法把 ImageData 为红色:

imgData=ctx.createImageData(100,100);

imgData.data[4]=0;
imgData.data[5]=255;
imgData.data[6]=0;
imgData.data[7]=255;

JavaScript 语法

的 createImageData() 方法:

1. 的 ImageData 对象:

var imgData=context.createImageData(width,height);

2. 的另一个 ImageData 同的新 ImageData 据):

var imgData=context.createImageData(imageData);

参数值

参数 描述
width ImageData 。
height ImageData 。
imageData 另一个 ImageData 对象。