新闻中心
使用Canvas实现简单的图片滤镜_j*ascript canvas
先创建canvas并加载图片,再通过getImageData获取像素数据,遍历data数组修改RGBA值实现滤镜效果,如灰度化采用加权平均计算亮度值。

在网页开发中,使用 J*aScript 和 Canvas 可以轻松实现对图片的实时滤镜处理。Canvas 提供了直接操作像素的能力,通过读取图像数据并修改其颜色值,就能实现各种视觉效果,比如灰度、反色、模糊、亮度调整等。
准备 Canvas 和图片
要处理图片,先需要将图片绘制到 canvas 上,然后才能获取像素数据进行操作。
基本步骤如下:
- 创建一个 canvas 元素,并获取其上下文
- 使用 Image 对象加载图片
- 图片加载完成后,用 drawImage 方法绘制到 canvas
- 通过 getImageData 获取像素数据
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
const img = new Image();
img.sr
c = 'your-image.jpg';
img.onload = function() {
canvas.width = this.width;
canvas.height = this.height;
ctx.drawImage(img, 0, 0);
const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
// 接下来处理像素
}
常见的简单滤镜实现
拿到 imageData 后,它的 data 属性是一个一维数组,包含每像素的 RGBA 值(红、绿、蓝、透明度),每个值范围是 0–255。
我们遍历这个数组,修改颜色通道即可实现滤镜。
1. 灰度滤镜
将每个像素的 RGB 值设为亮度的平均值(常用加权平均)。
function applyGrayscale(data) {
for (let i = 0; i < data.length; i += 4) {
const r = data[i];
const g = data[i + 1];
const b = data[i + 2];
// 使用加权平均更符合人眼感知
const gray = 0.3 * r + 0.59 * g + 0.11 * b;
data[i] = data[i + 1] = data[i + 2] = gray;
}
}
2. 反色滤镜(负片)
情感家园企业站5.0 多语言多风格版
一套面向小企业用户的企业网站程序!功能简单,操作简单。实现了小企业网站的很多实用的功能,如文章新闻模块、图片展示、产品列表以及小型的下载功能,还同时增加了邮件订阅等相应模块。公告,友情链接等这些通用功能本程序也同样都集成了!同时本程序引入了模块功能,只要在系统默认模板上创建模块,可以在任何一个语言环境(或任意风格)的适当位置进行使用!
0
查看详情
用 255 减去每个颜色值。
function applyInvert(data) {
for (let i = 0; i < data.length; i += 4) {
data[i] = 255 - data[i]; // R
data[i + 1] = 255 - data[i + 1]; // G
data[i + 2] = 255 - data[i + 2]; // B
}
}
3. 亮度调整
给每个颜色值加上或减去一个数值。
function adjustBrightness(data, value) {
for (let i = 0; i < data.length; i += 4) {
data[i] += value; // R
data[i + 1] += value; // G
data[i + 2] += value; // B
// 确保值在 0-255 范围内
for (let j = 0; j < 3; j++) {
if (data[i + j] > 255) data[i + j] = 255;
else if (data[i + j] < 0) data[i + j] = 0;
}
}
}
应用滤镜并显示结果
修改完 imageData.data 后,使用 putImageData 将数据写回 canvas。
// 示例:应用灰度滤镜 const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height); applyGrayscale(imageData.data); ctx.putImageData(imageData, 0, 0);
此时 canvas 上的图像就会变成灰度效果。
你也可以把处理后的 canvas 导出为图片:
const outputUrl = canvas.toDataURL('image/png');
document.querySelector('img#output').src = outputUrl;
基本上就这些。不复杂但容易忽略细节,比如像素边界和颜色范围控制。掌握这些基础后,可以尝试更复杂的滤镜如模糊、锐化或色彩偏移。
以上就是使用Canvas实现简单的图片滤镜_j*ascript canvas的详细内容,更多请关注其它相关文章!
# 它比
# 微小网站建设营销
# 南昌网站推广高手
# 优化网站的协议合同
# 红桥区推广网站搭建中心
# seo抖音优化教程
# 郑州seo优化技术
# 薛城网络营销推广
# 青海抖音营销推广哪家好
# 越秀本地的网站推广
# 视频网站建设定制
# 是一个
# javascript
# 如何使用
# 怎么做
# 加载
# 锐化
# 加权平均
# 遍历
# 多语言
# 滤镜
# canva
# app
# java
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
优化 Python 函数中的条件逻辑:解决 if-else 嵌套与参数选择问题
顺丰快递查询系统 官方正版查询入口
谷歌邮箱网页版官方页面入口 谷歌邮箱网页端快速访问
Win11怎么隐藏桌面图标 Win11一键隐藏所有桌面元素及恢复显示
ArrayList与LinkedList操作复杂度详解:遍历与修改
J*a最大堆Heapify方法修复:索引计算与边界条件深度解析
美团外卖商家服务中心入口 美团商家版官网入口
哔哩哔哩忘记密码了怎么找回_哔哩哔哩密码找回方法
Tabulator表格日期时间排序问题及自定义解决方案
如何在J*a中使用Locale处理多语言环境
文心一言怎样用插件调度API数据_文心一言用插件调度API数据【API调用】
html网页设计源代码怎么运行_运行html网页设计源代码步骤【指南】
Win11怎么开启高性能模式_Windows 11电源计划优化设置
mc.js游戏直达 mc.js网页免下载版本秒进地址
mcjs网页版在线存档 mcjs云存档登录入口
机器学习中对数变换预测结果的反向还原
将JSON对象数组转置为键值对列表的实用指南
CSS Flexbox与媒体查询:实现响应式布局中元素的并排与堆叠
Go与Ruby之间实现AES加密互通:CFB模式下的密钥长度匹配策略
优化Log4j2控制台输出性能:解决异步日志瓶颈
照顾宝贝2小游戏点击立即在线玩
taptap防沉迷怎么解除 taptap解除健康系统限制说明【2025最新】
印象笔记如何设离线包出差查阅_印象笔记设离线包出差查阅【离线阅读】
Win11截图该按哪些键 Win11截屏完整流程解析【教程】
微信怎么把收藏的内容分类管理 微信收藏内容标签分类方法
Win10系统怎么查看已安装更新_Win10卸载有问题的更新补丁
邮政编码查询不到怎么办_邮政编码查询不到的常见原因与对策
QQ邮箱在线使用入口 QQ邮箱个人账号网页版登录
C++如何打印当前代码行号与文件名_C++预定义宏FILE与LINE的使用
魅族20怎样在浏览器开无图省流_iPhone魅族20浏览器开无图省流【流量节省】
c++中的std::launder有什么实际用途_c++对象生命周期与指针优化
css卡片内容溢出如何处理_使用overflow隐藏或scroll显示内容
yy漫画网页版官方入口_yy漫画官网登录页面链接
Basecamp怎样用留言钉固定重点_Basecamp用留言钉固定重点【重点标记】
百度网盘网页版入口 百度网盘网页版官方登录网址
Python中高效且防溢出的双曲正弦计算:基于对数空间的优化策略
Animex动漫社网入口地址 Animex动漫社网正版在线入口
TypeScript/J*aScript:高效查找数组中首个唯一ID对象
如何使 Jest 模拟函数默认抛出错误以提高测试效率
优化LangChain文档加载与ChromaDB集成:解决多文档处理与分块问题
Win10桌面图标出现小盾牌怎么办 Win10去除UAC图标教程【解决】
MAC怎么让Dock栏只显示当前运行的应用_MAC终端命令实现极简Dock栏
TikTok搜索结果不显示如何解决 TikTok搜索刷新优化方法
Word2013如何插入视频和音频媒体_Word2013媒体插入的多媒体支持
提升Kafka消费者健壮性:会话超时处理与消息处理语义
j*a toString()的覆盖
新三国志曹操传110级星符试炼夏侯渊极难攻略
打开就能玩的植物大战僵尸 植物大战僵尸网页版传送门
京东单号查询入口_京东快递订单追踪入口
苹果手机如何防止被恶意App追踪


2025-10-31
浏览次数:次
返回列表
c = 'your-image.jpg';
img.onload = function() {
canvas.width = this.width;
canvas.height = this.height;
ctx.drawImage(img, 0, 0);
const imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
// 接下来处理像素
}