JavaScript實(shí)現(xiàn)圖像模糊化的方法實(shí)例
前言
眾所周知一幅完整的圖像,是由紅色、綠色、藍(lán)色三個通道組成的。紅色、綠色、藍(lán)色三個通道的縮覽圖都是以灰度顯示的。用不同的灰度色階來表示" 紅,綠,藍(lán)"在圖像中的比重。通道中的純白,代表了該色光在此處為最高亮度,亮度級別是255。
模糊化方法:
就是將一個像素點(diǎn)的R(G,B)和它周圍像素點(diǎn)的R(G,B)取出,然后取平均值再賦給這個像素點(diǎn)的R(G,B);這樣就完成模糊化了;
例:
1 2 3
4 5 6
7 8 9
比如這個像素點(diǎn)5,把5像素點(diǎn)和周圍的8個像素點(diǎn)(1,2,3,4,6,7,8,9)的R(G,B)取出,取這9個點(diǎn)的平均值然后賦給5像素點(diǎn)
R(5) = (R1+R2+R3+R4+R5+R6+R7+R8+R9)/9;
G(5) = (G1+G2+G3+G4+G5+G6+G7+G8+G9)/9;
B(5) = (B1+B2+B3+B4+B5+B6+B7+B8+B9)/9;
效果圖:
實(shí)例代碼
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>ImgBase</title> <style type="text/css"> .scream{ width:400px; height:300px; position: absolute; top:60px; border: 1px solid; } #canvas{ position: absolute; top:60px; left:500px; border: 1px dashed; } </style> </head> <body> <input type="file" onchange="loadImg()"/> <input type="button" value="模糊化" onclick="Fuzzy()"/> <br/><br/> <div class="scream"> <img id="scream" width="400px" height="300px" alt="Image preview..."> </div> <canvas id="canvas" width="400px;" height="300px;"> your browser does not support canvas! </canvas> <script> function Fuzzy(){ var c=document.getElementById("canvas"); var ctx=c.getContext("2d"); var imgData=ctx.getImageData(0,0,c.width,c.height); var img_w = imgData.width; var img_h = imgData.height; for(var w=1;w<(img_w-1);w++){ for(var h=1;h<(img_h-1);h++){ //起始點(diǎn) var i = (w+img_w*h)*4; var R = imgData.data[i-1604]+imgData.data[i-1600]+imgData.data[i-1596]+imgData.data[i-4]+imgData.data[i] +imgData.data[i+4]+imgData.data[i+1596]+imgData.data[i+1600]+imgData.data[i+1604]; //R(0-255) var G = imgData.data[i-1603]+imgData.data[i-1599]+imgData.data[i-1595]+imgData.data[i-3]+imgData.data[i+1] +imgData.data[i+5]+imgData.data[i+1597]+imgData.data[i+1601]+imgData.data[i+1605]; //G(0-255) var B = imgData.data[i-1602]+imgData.data[i-1598]+imgData.data[i-1594]+imgData.data[i-2]+imgData.data[i+2] +imgData.data[i+6]+imgData.data[i+1598]+imgData.data[i+1602]+imgData.data[i+1606];; //G(0-255) var Alpha = imgData.data[i+3]; //Alpha(0-255) imgData.data[i] = R/9; imgData.data[i+1] = G/9; imgData.data[i+2] = B/9; imgData.data[i+3] = Alpha; } } ctx.putImageData(imgData,0,0); } </script> <script> //canvas圖像的寬高 var c_w = 400; var c_h = 300; //加載img圖像 function loadImg(){ var img = document.getElementById("scream"); var file = document.querySelector('input[type=file]').files[0]; if(!/image\/\w+/.test(file.type)){ alert("文件必須為圖片!"); return false; } var reader = new FileReader(); reader.addEventListener("load", function () { img.src = reader.result; }, false); if(file) { reader.readAsDataURL(file); loadCanvas(); } } //加載canvas圖像 function loadCanvas(){ var c=document.getElementById("canvas"); var ctx=c.getContext("2d"); var img = document.getElementById("scream"); img.onload = function() { ctx.drawImage(img,0,0,c_w,c_h); } } </script> </body> </html>
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
js構(gòu)造函數(shù)constructor和原型prototype原理與用法實(shí)例分析
這篇文章主要介紹了js構(gòu)造函數(shù)constructor和原型prototype原理與用法,結(jié)合實(shí)例形式分析js構(gòu)造函數(shù)constructor和原型prototype基本原理、功能、使用方法及操作注意事項(xiàng),需要的朋友可以參考下2020-03-03Jquery 返回json數(shù)據(jù)在IE瀏覽器中提示下載的問題
Jquery 返回json數(shù)據(jù),IE瀏覽器提示下載的問題,當(dāng)提交完數(shù)據(jù)后返回的本來是json數(shù)據(jù)的,在火弧里測試正常,解決方法如下2014-05-05原生js和jquery中有關(guān)透明度設(shè)置的相關(guān)問題
設(shè)置透明度問題,比如圖片的淡入淡出效果。下面我介紹一下在原生js和jQuery中設(shè)置透明度的相關(guān)問題和注意點(diǎn)2014-01-01Javascript類型轉(zhuǎn)換的規(guī)則實(shí)例解析
這篇文章主要介紹了Javascript類型轉(zhuǎn)換的規(guī)則實(shí)例解析,涉及到j(luò)avascript類型轉(zhuǎn)換相關(guān)知識,對本文感興趣的朋友一起學(xué)習(xí)吧2016-02-02webpack-url-loader 解決項(xiàng)目中圖片打包路徑問題
這篇文章主要介紹了webpack-url-loader 解決項(xiàng)目中圖片打包路徑問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-02-02js 用CreateElement動態(tài)創(chuàng)建標(biāo)簽示例
用CreateElement動態(tài)創(chuàng)建標(biāo)簽,主要是html中常用的一些標(biāo)簽,在本文有詳細(xì)的示例,喜歡的朋友可以參考下2013-11-11JavaScript實(shí)現(xiàn)預(yù)覽本地上傳圖片功能完整示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)預(yù)覽本地上傳圖片功能,結(jié)合完整實(shí)例形式分析了javascript圖片預(yù)覽相關(guān)的格式正則驗(yàn)證、瀏覽器判斷、頁面元素屬性動態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-03-03