极乐门资源网 Design By www.ioogu.com
这篇文章主要介绍了JavaScript多种滤镜算法实现代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
1.灰色滤镜
设定R,G,B值相等
function makeGray(img){ for(var pixel of img.values()){ var avg = (pixel.getRed()+pixel.getGreen()+pixel.getBlue())/3; pixel.setRed(avg); pixel.setGreen(avg); pixel.setBlue(avg); } return img; }
2.单色滤镜(以红色为例)
计算R,G,B的均值avg,判断avg是否小于128.
function makeRed(img){ for(var pixel of img.values()){ var avg = (pixel.getRed()+pixel.getGreen()+pixel.getBlue())/3; if(avg<128){ pixel.setRed(2*avg); pixel.setGreen(0); pixel.setBlue(0); } else{ pixel.setRed(255); pixel.setGreen(2*avg-255); pixel.setBlue(2*avg-255); } } return img; }
3.彩色滤镜
function makeRainbow(img){ for(var pixel of img.values()){ var x = pixel.getX(); var y = pixel.getY(); var avg = (pixel.getRed()+pixel.getGreen()+pixel.getBlue())/3; var h = img.height; if(y<h/7){ if(avg<128){ pixel.setRed(2*avg); pixel.setGreen(0); pixel.setBlue(0); } else{ pixel.setRed(255); pixel.setGreen(2*avg-255); pixel.setBlue(2*avg-255); } } if(y>=h/7 && y<h*2/7){ if(avg<128){ pixel.setRed(2*avg); pixel.setGreen(0.8*avg); pixel.setBlue(0); } else{ pixel.setRed(255); pixel.setGreen(1.2*avg-51); pixel.setBlue(2*avg-255); } } if(y>=h*2/7 && y<h*3/7){ if(avg<128){ pixel.setRed(2*avg); pixel.setGreen(2*avg); pixel.setBlue(0); } else{ pixel.setRed(255); pixel.setGreen(255); pixel.setBlue(2*avg-255); } } if(y>=h*3/7 && y<h*4/7){ if(avg<128){ pixel.setRed(0); pixel.setGreen(2*avg); pixel.setBlue(0); } else{ pixel.setRed(2*avg-255); pixel.setGreen(255); pixel.setBlue(2*avg-255); } } if(y>=h*4/7 && y<h*5/7){ if(avg<128){ pixel.setRed(0); pixel.setGreen(0); pixel.setBlue(2*avg); } else{ pixel.setRed(2*avg-255); pixel.setGreen(2*avg-255); pixel.setBlue(255); } } if(y>=5*h/7 && y<h*6/7){ if(avg<128){ pixel.setRed(0.8*avg); pixel.setGreen(0); pixel.setBlue(2*avg); } else{ pixel.setRed(1.2*avg-51); pixel.setGreen(2*avg-255); pixel.setBlue(255); } } if(y>=h*6/7){ if(avg<128){ pixel.setRed(1.6*avg); pixel.setGreen(0); pixel.setBlue(1.6*avg); } else{ pixel.setRed(0.4*avg+153); pixel.setGreen(2*avg-255); pixel.setBlue(0.4*avg+153); } } } return img; }
4.模糊滤镜
(1)生成(0,1)之间的
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
JavaScript,滤镜算法
极乐门资源网 Design By www.ioogu.com
极乐门资源网
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
极乐门资源网 Design By www.ioogu.com
暂无JavaScript多种滤镜算法实现代码实例的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 群星《歌手2024 第13期》[FLAC/分轨][325.93MB]
- 阿木乃《爱情买卖》DTS-ES【NRG镜像】
- 江蕾《爱是这样甜》DTS-WAV
- VA-Hair(OriginalBroadwayCastRecording)(1968)(PBTHAL24-96FLAC)
- 博主分享《美末2RE》PS5 Pro运行画面 玩家仍不买账
- 《双城之战2》超多新歌MV发布:林肯公园再次献声
- 群星《说唱梦工厂 第11期》[320K/MP3][63.25MB]
- 群星《说唱梦工厂 第11期》[FLAC/分轨][343.07MB]
- 群星《闪光的夏天 第5期》[320K/MP3][79.35MB]
- 秀兰玛雅.1999-友情人【大旗】【WAV+CUE】
- 小米.2020-我想在城市里当一个乡下人【滚石】【FLAC分轨】
- 齐豫.2003-THE.UNHEARD.OF.CHYI.3CD【苏活音乐】【WAV+CUE】
- 黄乙玲1986-讲什么山盟海誓[日本东芝版][WAV+CUE]
- 曾庆瑜1991-柔情陷阱[台湾派森东芝版][WAV+CUE]
- 陈建江《享受男声》DTS-ES6.1【WAV】