JavaScript多種濾鏡算法實(shí)現(xiàn)代碼實(shí)例
這篇文章主要介紹了JavaScript多種濾鏡算法實(shí)現(xiàn)代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
1.灰色濾鏡
設(shè)定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)之間的
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js canvas實(shí)現(xiàn)畫圖、濾鏡效果
- 純JavaScript實(shí)現(xiàn)HTML5 Canvas六種特效濾鏡示例
- js模擬濾鏡的圖片漸顯效果
- tweenjs緩動算法的使用實(shí)例分析
- JS中的算法與數(shù)據(jù)結(jié)構(gòu)之集合(Set)實(shí)例詳解
- JS中的算法與數(shù)據(jù)結(jié)構(gòu)之字典(Dictionary)實(shí)例詳解
- JS中的算法與數(shù)據(jù)結(jié)構(gòu)之列表(List)實(shí)例詳解
- JS實(shí)現(xiàn)的排列組合算法示例
- nodejs中各種加密算法的實(shí)現(xiàn)詳解
相關(guān)文章
javascript中傳統(tǒng)事件與現(xiàn)代事件
本文給大家介紹的是使用傳統(tǒng)事件的方法來模擬現(xiàn)代事件,十分的簡單實(shí)用,有需要的小伙伴可以參考下。2015-06-06js+canvas實(shí)現(xiàn)滑動拼圖驗(yàn)證碼功能
這篇文章主要介紹了js+canvas實(shí)現(xiàn)滑動拼圖驗(yàn)證碼功能,本文結(jié)合實(shí)例代碼分步驟給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-03-03bootstrap日期插件daterangepicker使用詳解
這篇文章主要為大家詳細(xì)介紹了bootstrap日期插件daterangepicker的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10JS使用window.requestAnimationFrame()實(shí)現(xiàn)逐幀動畫
這篇文章介紹了JS使用window.requestAnimationFrame()實(shí)現(xiàn)逐幀動畫的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06JavaScript實(shí)現(xiàn)文字展開和收起效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)文字展開和收起效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09