爱易网
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 浏览次数:20261 次
以下是程序代码
<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写的一个书架式的图片缩放滚动展示特效代码
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
支付宝27日晚间曝严重破绽:买卖记载可被搜索
从WPS到office365,中国企业能否赶超美国?
HDS发布《2013中国CIO洞察白皮书》
【晚报】女子泰国游晒10照片 流量费2000
公信力消失:马航事件社交媒体传播之痛
PC迎9年来出货量新低 平板电脑渐成主流
挂号网高管团体离任 或因投资人失掉决计
首家国有独资P2P平台上线 或预示政策日渐明朗
二维码支付大战的号角注定已经吹响,尚需标准发放
推荐阅读
更多>
苏宁易购成世界最慢电商 专家称其涉嫌违约
广电地方营业厅的一句“罚停”,暴露出了他们的本质
只有切到刚需痛点,漫画APP才能走下去
北京今日实现用支付宝钱包为公交卡充值
小米打响手机价格战 为米3铺路或另有所图
云智慧:用大数据实现企业应用性能管理
支付宝被曝严重破绽 隐私平安再受质疑
迅雷高管解读财报:收购快盘可快速融入小米
史上最严电话实名制9月实行 三大难题待解
三星起诉LG在冰箱广告中玷污其企业笼统
苹果30亿美元收购Beats
广东移动董事长徐龙受调查 圈内对其褒贬不一
中国大陆人口13.7亿 光棍越来越多
刘强东:京东上市融资用于开拓三至六线城市
P2P平台科迅网疑“跑路” 涉及金额超2700万
三问刘强东:京东为何近来火气这么大?
固话上网卡或将实名制 运营商泄露用户信息将被罚
阿里国际化再落子:2.49亿美元投资新加坡邮政
Android版WhatsApp曝漏洞:聊天记录可被窃取
想玩P2P?几个您必须知道的潜规则