开场白

今天遇到一个场景;就是更改一个图片的颜色;
当听到这个。我直呼好家伙;这个是要上天了呀。
但是仔细一思考;借助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操作图片像素点保证你看的明明白白的更多相关文章

  1. 在c#中用指针操作图片像素点

    在Bitmap类中有两个函数SetPixel,GetPixel,分别用来设置或读取图片中指定点的颜色(这里发现了VS的一个错误,SetPixel的文档说明写的是“获取颜色”??). 当要对一幅图进行相 ...

  2. canvas操作图片,进行面板画图,旋转等

    HTML5 <canvas> 标签用于绘制图像(通过脚本,通常是 JavaScript). 不过,<canvas> 元素本身并没有绘制能力(它仅仅是图形的容器) - 您必须使用 ...

  3. 国庆总结:echarts自定义颜色主题,保证你看的明明白白

    为什么需要使用颜色主题 随着用户审美越来越高,不再是过去那样只注重功能. 所以对界面的颜色样式都具有一定的审美要求 此时颜色是否好看就非常重要了 因为人都是视觉动物 对界面的第一印象肯定都是颜色. 如 ...

  4. Vue3.2中的setup语法糖,保证你看的明明白白!

    vue3.2 到底更新了什么? 根据原文内容的更新的内容主要有以下 5 块: 1.SSR:服务端渲染优化.@vue/server-renderer包加了一个ES模块创建, 与Node.js解耦,使在非 ...

  5. vue下一代状态管理Pinia.js 保证你看的明明白白!

    1.pinia的简单介绍 Pinia最初是在2019年11月左右重新设计使用Composition API的 Vue 商店外观的实验. 从那时起,最初的原则相同,但 Pinia 适用于 Vue 2 和 ...

  6. vue混入mixin的使用,保证你看的明明白白!

    场景描述 有些时候,我们发现有些组件部分功能代码是几乎是一样的. 这个时候,我们就可以将相同的逻辑代码抽离出来 此时我们的主角混入mixin就登场了 下面我们有a-test和b-test两个组件,点击 ...

  7. node使用node-xlsx实现excel的下载与导入,保证你看的明明白白

    需求简介 很多时候,我们都会有这样一个业务. 将列表中的数据导出为excel. 这样做的目的是为了方便查看,同时可以保存在本地归档. 还可以将导出的Excel后的数据进行加工. node-xlsx 的 ...

  8. canvas插入图片设置背景,渐变

    ##在canvas中插入图片(需要image对象) 1.canvas操作图片时,必须要等图片加载完才能操作 2.drawImage(image, x, y, width, height) 其中 ima ...

  9. 神奇的canvas——巧用 canvas 为图片添加水印

    代码地址如下:http://www.demodashi.com/demo/11637.html 很久之前写过一篇关于 canvas 的文章,是通过 canvas 来实现一个绚丽的动画效果,不管看过没看 ...

  10. canvas学习笔记:canvas对图片的像素级处理--ImageData的应用

    学习了canvas的基本绘图功能后,惊喜的发现canvas对图片数据也有相当强大的处理功能,能够从像素级别操作位图,当然[lte ie8]不支持. 主要的函数有三个: ctx.createImageD ...

随机推荐

  1. 华为云开天aPaaS 上线,服务千万开发者,使能行业场景化创新

    摘要:9月25日,华为云在华为全联接2021发布四大生态策略,并宣布2022年投入1亿美元升级沃土云创计划.华为云开天aPaaS正式上线,实现经验即服务,使能行业场景化创新. 本文分享自华为云社区&l ...

  2. Kubernetes(K8S) 配置管理 Secret 介绍

    Secret 作用:加密数据(base64)存在 etcd 里面,让 Pod 容器以挂载 Volume 方式进行访问 场景:凭证 [root@k8smaster ~]# echo -n 'admin' ...

  3. Go--Println、Printf区别

    Println:打印字符串.变量:    同函数输出多项,之间存在空格    不同函数输出自动换行 Printf:打印需要格式化的字符串,可以输出字符串类型的变量:不可以输出整型变量和整型   同函数 ...

  4. 语音顶会 ICASSP 2022 成果分享:基于时频感知域模型的单通道语音增强算法

    近日,阿里云视频云音频技术团队与新加坡国立大学李海洲教授团队合作论文 <基于时频感知域模型的单通道语音增强算法 >(Time-Frequency Attention for Monaura ...

  5. InnoDB 事务加锁分析

    本文首发于 vivo互联网技术 微信公众号 链接:https://mp.weixin.qq.com/s/S7MhlsZveBHRSQhq5aTIJA作者:何志创 一般大家对数据库事务的了解可能停留在事 ...

  6. 应届生必读:Java真实项目的开发流程和常用工具

    本文出自本人写的书,谢绝转载,更勿抄袭. 本人有多年的Java面试官经验,经常要和一些包装项目经验的求职者打交道.当然平时也兼职做些Java面试辅导工作,最近也陆续帮一些在校生朋友成功找到Java工作 ...

  7. <vue 基础知识 8、购物车样例>

    代码结构 一.     效果 1. 展示列表v-for 2. 购买数量增加减少,使用@click触发回调函数. 减少的时候如果已经为1了就不让继续减少,使用了v-bind绑定属性 3. 移除也是使用@ ...

  8. vue学习笔记 十二、通过计算属性获取定义的状态数据

    系列导航 vue学习笔记 一.环境搭建 vue学习笔记 二.环境搭建+项目创建 vue学习笔记 三.文件和目录结构 vue学习笔记 四.定义组件(组件基本结构) vue学习笔记 五.创建子组件实例 v ...

  9. 【转载】内存基本概念-slab算法

    Linux内存管理之slab 2:slab API https://blog.csdn.net/lqy971966/article/details/119801912 1. 为什么有了Buddy(伙伴 ...

  10. 项目API请求模块封装