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

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

开场白

今天遇到一个场景;就是更改一个图片的颜色;
当听到这个。我直呼好家伙;这个是要上天了呀。
但是仔细一思考;借助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);
  }

遇见问题,这是你成长的机会,如果你能够解决,这就是收获。

相关文章
python用鼠标获取图像任一点的坐标和像素值
python用鼠标获取图像任一点的坐标和像素值
|
12月前
|
数据采集 JSON API
淘宝商品数据采集API技术分享
在电商领域,数据采集和分析对提升业务效率、优化用户体验至关重要。淘宝作为国内最大电商平台之一,提供了丰富的商品数据。通过淘宝商品采集API,开发者可高效获取这些数据,支持决策。本文详细介绍了如何注册、申请权限、构建请求、处理响应及注意事项,助力商家和开发者利用API进行商品数据采集。
|
12月前
|
人工智能 自然语言处理 测试技术
DeepSeek V3:DeepSeek 开源的最新多模态 AI 模型,编程能力超越Claude,生成速度提升至 60 TPS
DeepSeek V3 是深度求索公司开源的最新 AI 模型,采用混合专家架构,具备强大的编程和多语言处理能力,性能超越多个竞争对手。
1941 5
DeepSeek V3:DeepSeek 开源的最新多模态 AI 模型,编程能力超越Claude,生成速度提升至 60 TPS
|
11月前
|
存储 SQL 数据挖掘
深入理解 Flink 中的 State
Flink 的 State(状态)是其四大核心之一,为流处理和批处理任务提供强大支持。本文深入探讨 Flink 中的状态管理,涵盖 State 在 HDFS 中的存储格式、存在形式(如 ValueState、ListState 等)、使用方法、过期时间 TTL 和清除策略,并介绍 Table API 和 SQL 模块中的状态管理。通过实际案例,帮助读者理解如何在电商订单处理、实时日志统计等场景中有效利用状态管理功能。
1092 16
|
12月前
|
分布式计算 DataWorks 搜索推荐
用户画像分析(MaxCompute简化版)
通过本教程,您可以了解如何使用DataWorks和MaxCompute产品组合进行数仓开发与分析,并通过案例体验DataWorks数据集成、数据开发和运维中心模块的相关能力。
|
Web App开发 前端开发 JavaScript
WebKit 入门介绍
WebKit 入门介绍
|
小程序 API 开发者
【小程序全面解析】生命周期、常用组件,代码示例和使用场景
该文章全面介绍了小程序的生命周期、常用基础组件以及使用场景,并提供了相应的代码示例。读者可以了解小程序的生命周期函数及其执行时机,以及学习如何使用常用基础组件构建小程序页面。此外,文章还列举了各种使用场景,帮助读者更好地理解如何应用小程序开发。如果您是小程序开发的初学者或需要了解小程序的基础知识,该文章将为您提供全面的帮助和指导。
680 0
【小程序全面解析】生命周期、常用组件,代码示例和使用场景
|
存储 Linux Go
如何在Github上Pull Request的教程
关于如何在GitHub上发起Pull Request(合并请求)的详细教程,包括Fork(分支)、Clone(克隆)、创建新分支、修改代码、提交更改、推送到远程仓库等步骤,并提供了解决权限问题的方法,如创建个人访问令牌(Personal Access Token)。
691 6
|
SQL 分布式计算 DataWorks
DataWorks产品使用合集之如何将STRING类型转换为DATETIME类型
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
270 1
|
存储 算法 调度
基于和声搜索算法(Harmony Search,HS)的机器设备工作最优调度方案求解matlab仿真
通过和声搜索算法(HS)实现多机器并行工作调度,以最小化任务完成时间。在MATLAB2022a环境下,不仅输出了工作调度甘特图,还展示了算法适应度值的收敛曲线。HS算法模拟音乐家即兴创作过程,随机生成初始解(和声库),并通过选择、微调生成新解,不断迭代直至获得最优调度方案。参数包括和声库大小、记忆考虑率、音调微调率及带宽。编码策略将任务与设备分配映射为和声,目标是最小化完成时间,同时确保满足各种约束条件。

热门文章

最新文章