今天就跟大家聊聊有关使用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; }
看完上述内容,你们对使用JavaScript怎么实现一个滤镜算法有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。
当前标题:使用JavaScript怎么实现一个滤镜算法-创新互联
转载来源:https://www.cdcxhl.com/article12/dphjdc.html
成都网站建设公司_创新互联,为您提供小程序开发、网站设计、定制开发、动态网站、网站导航、建站公司
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联