canvas 像素操作(图片像素操作)

canvas 图片像素/像素操作

在 canvas 中的 drawImage() 方法允许在 canvas 中插入其他图像( img 和 canvas 元素都可以) 。图片绘制上去后,我们可以通过 getImageData() 方法来获取 canvas 区域包含的像素信息,该方法返回一个 ImageData 对象,我们可以通过修改 ImageData 对象来修改图片,最后通过 putImageData()imageData 对象重新绘制到 canvas 上。(所以也可以不用绘制图片,直接通过 getImageData()putImageData() 方法来绘制一张图片)

drawImage()

drawImage() 方法直接看下面的教程就可以,一看就明白了
https://www.runoob.com/jsref/met-canvas-drawimage.html

context.getImageData(x, y, width, height);

getImageData() 方法返回 ImageData 对象,该对象拷贝了画布指定矩形的像素数据。

注意: ImageData 对象不是图像,它规定了画布上一个部分(矩形),并保存了该矩形内每个像素的信息。

参数描述
x开始复制的左上角位置的 x 坐标(以像素计)。
y开始复制的左上角位置的 y 坐标(以像素计)。
width要复制的矩形区域的宽度。
height要复制的矩形区域的高度。

ImageData 对象中的每个像素都保存了rgba色值的四个值,这四个值以数组形式存在,并存储于 ImageData 对象的 data 属性中,并且是将所有的像素的rgba信息存到了一个一维数组里面。所以循环的时候我们需要 i+=4;。可参考下列代码和结果图片。

注意: 每一个像素的rgba取值都是 0-255,rgb好理解,a的值, 0表示透明度为100%,1表示完全不透明;

let canvas = document.getElementById("myCanvas");
if (canvas && canvas.getContext) {
  let ctx = canvas.getContext("2d");
  var img = $('#imageeys2A8 img')[0];	// 这里是一个图片的dom
  ctx.drawImage(img, 0, 0, 110, 58);

  let imgData = ctx.getImageData(0, 0, 200, 200);
  console.log("ImageData:", imgData)

}

在这里插入图片描述

putImageData(imgData, x, y, dirtyX, dirtyY, dirtyWidth, dirtyHeight);

putImageData() 方法将图像数据(从指定的 ImageData 对象)放回画布上。
因为后面几个参数是非必填,所以可以使用 putImageData(imgData, x, y);

参数描述
imgData规定要放回画布的 ImageData 对象。
xImageData 对象左上角的 x 坐标,以像素计。
yImageData 对象左上角的 y 坐标,以像素计。
dirtyX可选。水平值(x),以像素计,在画布上放置图像的位置。
dirtyY可选。垂直值(y),以像素计,在画布上放置图像的位置。
dirtyWidth可选。在画布上绘制图像所使用的宽度。
dirtyHeight可选。在画布上绘制图像所使用的高度。

修改图片/操作像素 例子:

// 获取canvas的dom
let canvas = document.getElementById("myCanvas");
if (canvas && canvas.getContext) {
  let ctx = canvas.getContext("2d");
  // 将图片插入到canvas画布上
  var img = $('#imageeys2A8 img')[0];
  ctx.drawImage(img, 0, 0, 110, 58);
  // 获取规定的区域的像素
  let imgData = ctx.getImageData(0, 0, 200, 200);
  // 修改每个像素的rgba的值
  for (let i = 0; i < imgData.data.length; i += 4) {
    imgData.data[i] = 255 - imgData.data[i];  // red
    imgData.data[i + 1] = 255 - imgData.data[i + 1];  // green
    imgData.data[i + 2] = 255 - imgData.data[i + 2];  // blue
    imgData.data[i + 3] = 255;  // alpha, 0表示透明度为100%,1表示完全不透明
  }
  // 将修改后的图片重新放回到画布上
  ctx.putImageData(imgData, 0, 0);
}

结果

在这里插入图片描述

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值