新闻中心

使用Canvas实现简单的图片滤镜_j*ascript canvas

2025-10-31
浏览次数:
返回列表
先创建canvas并加载图片,再通过getImageData获取像素数据,遍历data数组修改RGBA值实现滤镜效果,如灰度化采用加权平均计算亮度值。

使用canvas实现简单的图片滤镜_javascript canvas

在网页开发中,使用 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.src = '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 多语言多风格版 情感家园企业站5.0 多语言多风格版

一套面向小企业用户的企业网站程序!功能简单,操作简单。实现了小企业网站的很多实用的功能,如文章新闻模块、图片展示、产品列表以及小型的下载功能,还同时增加了邮件订阅等相应模块。公告,友情链接等这些通用功能本程序也同样都集成了!同时本程序引入了模块功能,只要在系统默认模板上创建模块,可以在任何一个语言环境(或任意风格)的适当位置进行使用!

情感家园企业站5.0 多语言多风格版 0 查看详情 情感家园企业站5.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追踪 

搜索