首页 > 其他分享 >canvas操作图片像素点保证你看的明明白白

canvas操作图片像素点保证你看的明明白白

时间:2023-12-22 10:55:07浏览次数:27  
标签:canvas allImgData img 明明白白 ctx let data 像素点 255

开场白

今天遇到一个场景;就是更改一个图片的颜色;
当听到这个。我直呼好家伙;这个是要上天了呀。
但是仔细一思考;借助canvas好像也能实现;
于是下来研究了一下,并不难;
我们下面来看看怎么实现的

基本思路

主要是获取图片的像素点;ctx.getImageData()
然后去更改图片的像素点;
最后绘制在画布上ctx.putImageData()
特别提醒:
在canvas的getImageData方法中,一个像素点由四个元素表示;
通常这四个元素是[r, g, b, a],分别代表红、绿、蓝和透明度(alpha通道)。
r(红色通道):范围从0到255,表示红色的强度。
g(绿色通道):范围从0到255,表示绿色的强度。
b(蓝色通道):范围从0到255,表示蓝色的强度。
a(透明度/alpha通道):范围从0到255,表示像素的透明度。
  0是完全透明的,255是完全不透明的。

获取图片的所有像素

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <canvas id="canvas" width="1000" height="500" ></canvas>
</body>
<script>
  let  canvas =document.getElementById('canvas')
  // 获取画笔(上下文)
  let ctx= canvas.getContext('2d')
  // 创建一个图片实例
  let img = new Image()
  // 给图片赋值
  img.src= './img/01.png'
  // 图片加载完成后绘制在画布上
  img.onload = function(){
    // 从坐标0,0开始绘制;
    ctx.drawImage(img, 0, 0, 584, 333);
    // 获取图像的所有像素
    let allImgData = ctx.getImageData(0, 0, 584, 333);
    console.log('获取图像的所有像素==>', allImgData)
  }
</script>
</html>

操作图片像素点全部变为黄色

img.onload = function(){
  // 从坐标0,0开始绘制;
  ctx.drawImage(img, 0, 0, 584, 333);
  // 获取图像的所有像素
  let allImgData = ctx.getImageData(0, 0, 584, 333);
  console.log('获取图像的所有像素==>', allImgData)

  // 修改像素点;变成黄色; 4个为一组所以是:i+=4
  for(let i=0;i< allImgData.data.length;i+=4){
    allImgData.data[i] = 255
    allImgData.data[i+1] = 255
    allImgData.data[i+2] = 0
    allImgData.data[i+3] = 255
  } 
  // 将像素点绘制上去
  ctx.putImageData(allImgData, 0,0);
}

将当前图片变为灰色

img.onload = function(){
    // 从坐标0,0开始绘制;
    ctx.drawImage(img, 0, 0, 584, 333);
    // 获取图像的所有像素
    let allImgData = ctx.getImageData(0, 0, 584, 333);
    console.log('获取图像的所有像素==>', allImgData)
   
    // 修改像素点;变成灰色
    for(let i=0;i< allImgData.data.length;i+=4){
      // 计算当前像素的平均值
      let avg = ( allImgData.data[i] +  allImgData.data[i+1] + allImgData.data[i+2])/3
      allImgData.data[i] = avg
      allImgData.data[i+1] = avg
      allImgData.data[i+2] = avg
      allImgData.data[i+3] = 255
    } 
    // 将像素点绘制上去
    ctx.putImageData(allImgData, 0,0);
  }

有人看到这里会开喷

就你这变成灰色,写了这么多的代码
我一行css就搞定了。
这样确实是可以的;我这里主要是想表达怎么更加精确去操作图片像素;
大佬们不要开喷
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    canvas {
      /* 使用CSS3将元素转换为灰度。100%表示完全灰度。 */
      filter: grayscale(100%);
      /* 兼容主流浏览器 */
      -webkit-filter: grayscale(100%);
      -moz-filter: grayscale(100%);
      -ms-filter: grayscale(100%);
      -o-filter: grayscale(100%);
      /* 使用SVG滤镜实现灰度效果,用于一些不支持CSS滤镜的旧浏览器。 */
      filter: url("data:image/svg+xml;utf8,#grayscale");
      /* 用于旧版本的IE */
      filter: progid:DXImageTransform.Microsoft.BasicImage(grayscale=1);
      /* - 这也是用于WebKit浏览器的,灰度值设置为1而不是100%,因为某些旧版本的WebKit浏览器中可能是必需的。 */
      -webkit-filter: grayscale(1);
    }
  </style>
</head>
<body>
  <canvas id="canvas" width="1000" height="500" ></canvas>
</body>
<script>
  let  canvas =document.getElementById('canvas')
  // 获取画笔(上下文)
  let ctx= canvas.getContext('2d')
  // 创建一个图片实例
  let img = new Image()
  // 给图片赋值
  img.src= './img/01.png'
  // 图片加载完成后绘制在画布上
  img.onload = function(){
  // 从坐标0,0开始绘制;
  ctx.drawImage(img, 0, 0, 584, 333);
}
</script>

透骨色

img.onload = function(){
    // 从坐标0,0开始绘制;
    ctx.drawImage(img, 0, 0, 584, 333);
    // 获取图像的所有像素
    let allImgData = ctx.getImageData(0, 0, 584, 333);
    console.log('获取图像的所有像素==>', allImgData)
   
    // 修改像素点;变成透骨色
    for(let i=0;i< allImgData.data.length;i+=4){
      let avg = ( allImgData.data[i] +  allImgData.data[i+1] + allImgData.data[i+2])/3
      allImgData.data[i] = 255-  allImgData.data[i]
      allImgData.data[i+1] = 255-  allImgData.data[i+1]
      allImgData.data[i+2] = 255-  allImgData.data[i+2]
      allImgData.data[i+3] = 255
    } 
    // 将像素点绘制上去
    ctx.putImageData(allImgData, 0,0);
  }

标签:canvas,allImgData,img,明明白白,ctx,let,data,像素点,255
From: https://www.cnblogs.com/IwishIcould/p/17920808.html

相关文章

  • Canvas三种模式
    1.ScreenSpace-OverlayCanvas永远撑满屏幕并显示在最上层,不绑定Camera(有没有Camera都能显示)。适合用来做最上层的UI。导航栏、分辨率自适应两边的框等。2.ScreenSpace-CameraCanvas自动填充指定摄像机的屏幕,但其他游戏对象(模型等)可以在它之前显示,根据和指定摄像机距离调整是......
  • Lucky-Canvas抽奖插件的使用
    官方网站:https://100px.net/新建一个空白的js文件’lucky-canvas.js‘,复制官网的JS代码'https://unpkg.com/lucky-canvas@1.7.25/dist/index.umd.js'新建一个html网页'lucky-canvas.html',引入刚刚新建的js文件<!doctypehtml><html><head><metacharset="......
  • 微信小程序canvas实现人员签名
    这里使用获取canvas节点实现的小程序最新的api签字面板效果图        wxml部分:<view class="container" >  <view class="sig_txt">    <canvas type="2d" id="myCanvas"      style="width:{{width}}px;height:{{height}}p......
  • 手把手教你使用ArkTS中的canvas实现签名板功能
     一、屏幕旋转● 实现签名板的第一个功能就是旋转屏幕。旋转屏幕在各种框架中都有不一样的方式,比如:在H5端,我们一般是使用CSS中的transform属性中的rotate()方法来强制将网页横屏,然后实现一系列功能● 在嵌套第三方APP中,我们一般是调用对应的SDK提供的方法,即可实现旋转屏幕......
  • 开发案例:使用canvas实现图表系列之折线图
     一、功能结构实现一个公共组件的时候,首先分析一下大概的实现结构以及开发思路,方便我们少走弯路,也可以使组件更加容易拓展,维护性更强。然后我会把功能逐个拆开来讲,这样大家才能学习到更详细的内容。下面简单阐述下折线图组件的功能结构:以上是基础的功能结构框架,包含一些比......
  • js(canvas) 图片压缩
    1functioncompress(url,width,height){2returnnewPromise((resolve,reject)=>{3letimg=document.createElement('img')4img.onload=()=>{5letw=width6leth=img.naturalH......
  • uniapp 微信小程序使用canvas
    微信小程序基础库大于2.9.0后,canvas(画布)支持一套新Canvas2D接口(需指定type属性),同时支持同层渲染,原有接口不再维护。在这种情况下使用原有接口会报错,报错例如:1、使用ctx.draw()会报错:drawisnotafunction,原因:新版Canvas2D接口没有draw方法2、使用ctx.setfillStyle......
  • 用html+css+js做canvas烟花模拟网页动画代码
    圣诞节、元旦就要到了,本案例我们将用html+css+js做canvas烟花模拟网页动画代码,程序员的浪漫这不就来了嘛,与家人朋友一起看烟花吧!   附源码<!DOCTYPEhtml><htmllang="en"><head> <metacharset="UTF-8"/> <title>烟花模拟器</title> <metaname="viewport"......
  • matplotlib报错:AttributeError: module 'backend_interagg' has no attribute 'Figure
    使用本地python环境可以成功执行importpandasaspdimportmatplotlib.pyplotasplt#设置字体plt.rcParams['font.sans-serif']=['SimHei']#能正确显示负号plt.rcParams['axes.unicode_minus']=False#设置画布大小plt.figure(figsize=(11,8))#柱状图pat......
  • 微信小程序使用canvas生成分享海报功能复盘
    前言近期需要开发一个微信小程序生成海报分享的功能。在h5一般都会直接采用html2canvas或者dom2image之类的库直接处理。但是由于小程序不具备传统意义的dom元素,所以也没有办法采用此类工具。所以就只能一笔一笔的用canvas画出来了,下面对实现这个功能中遇到的问题做一......