JavaScript多种滤镜算法实现代码实例

这篇文章主要介绍了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)之间的

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/17ae0e5ef610abc6728e7463c96e0d6e.html