爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
JS特效
用canvas实现图片滤镜效果详解之灰度效果
用canvas实现图片滤镜效果详解之灰度效果
日期:2014-05-18 浏览次数:20266 次
以下是程序代码
<html> <head> <script> window.onload = function() { var cv = document.getElementById('cv'); var c = cv.getContext('2d'); var canvas = document.getElementById("myCanvas"); var context = canvas.getContext("2d"); var img = new Image(); img.src = 'http://bbs.blueidea.com/forum.php?mod=attachment&aid=MjEyNDg2fDg2ZTBmYzk2fDEzODM1MjQ0NjF8NjU2ODk5fDMxMDU2ODA%3D'; img.onload=function(){ canvas.width = img.width; canvas.height = img.height; context.drawImage(img, 0, 0); var canvasData = context.getImageData(0, 0, canvas.width, canvas.height); // 1.灰度效果 //计算公式 .299 * r + .587 * g + .114 * b; // calculate gray scale value for ( var x = 0; x < canvasData.width; x++) { for ( var y = 0; y < canvasData.height; y++) { // Index of the pixel in the array var idx = (x + y * canvasData.width) * 4; var r = canvasData.data[idx + 0]; var g = canvasData.data[idx + 1]; var b = canvasData.data[idx + 2]; var gray = .299 * r + .587 * g + .114 * b; // assign gray scale value canvasData.data[idx + 0] = gray; // Red channel canvasData.data[idx + 1] = gray; // Green channel canvasData.data[idx + 2] = gray; // Blue channel canvasData.data[idx + 3] = 255; // Alpha channel // 加上黑色的边框 if(x < 8 || y < 8 || x > (canvasData.width - 8) || y > (canvasData.height - 8)) { canvasData.data[idx + 0] = 0; canvasData.data[idx + 1] = 0; canvasData.data[idx + 2] = 0; } } } context.putImageData(canvasData, 0, 0); } } </script> </head> <body> <canvas id="myCanvas" >Gray Filter</canvas> <canvas id="cv" >Gray Filter</canvas> </body> </html>
[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]
上一篇:狡猾的按钮特效
下一篇:原生JS写的一个书架式的图片缩放滚动展示特效代码
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
电信资费新政:三巨头压力大 短期降价仍有争议
首批四款“官方”打车软件发布:均为安卓版本
墨迹也要做硬件,工具类应用如何“变异”的
诺基亚依托规模效应 猛攻国际市场空白
SAP高层调整:联席CEO孟鼎铭成唯一掌舵人
传苹果与雅虎协作信息提供 进一步摆脱谷歌
苹果MacBook Air劣势渐显 或推新产品改变命运
二代 iPad Air将配备2GB内存?为同屏多任务做准备
第二梯队也PK:当1号店“遇上”京东手机节
推荐阅读
更多>
打车软件“明补变暗补”背后的小算盘
微软谷歌高层访韩面前:忌惮三星的崛起
国美痛批网购七宗罪 用短暂盈利输了未来
小米年度发布会遭围剿!多款新品难阻品牌危机
新浪微博推粉丝头条功能 意欲与大号分成
“合聚变”来了 UC优视确认并入阿里巴巴
快递企业征收“份子钱” 成全了谁 苦了谁?
神州泰岳雪上加霜:副总违规买卖遭罚
苹果6月20日发布iPhone5S 触摸屏概念股生动
眼球识别技术EyeVerify融资600万美元 360参投
HTC以品牌营销突围 专家建议改变经营思路
“世界杯+618”集体磨刀的本质是绑架全民
三星维修新规:Galaxy S4主板进水也收费修
微信收费形式三选一 腾讯或变身运营商
只有切到刚需痛点,漫画APP才能走下去
微信企业号必须搬走四座大山,否则只能铩羽而归!
优酷土豆兼并一年:依然处于烧钱形状
百度吴恩达:图像和音视频搜索是人工智能新方向
阿里巴巴IPO难掩的四个现实问题:天猫销售额成谜、淘宝拖后腿、营收迅猛其他不行和投资者未必买账
黑狐病毒疯传播 电脑管家首推 专杀工具