用canvas就可以實現圖片的濾鏡轉化代碼實現

導語:canvas的getImageData可以獲取canvas內圖像的沒一個像素點的顏色值獲取,而且可以改變,下面是小編給大家提供的.用canvas就可以實現圖片的濾鏡轉化代碼實現,大家可以參考閱讀,更多詳情請關注應屆畢業生考試網。

用canvas就可以實現圖片的濾鏡轉化代碼實現

  使用方法:

1:先將圖片導入畫布。

2:var canvasData = mageData(0, 0, h, ht); //用這個將圖片每個像素點的信息獲取出來,得到一個數組。注意得到的信息不是[[r,g,b,a],[r,g,b,a]]這樣的二維數組而是[r,g,b,a,r,g,b,a]這樣的按rgba順序排列的單個的數組。

3:這一步就是開始將每個像素的rgba改變。這裏簡單介紹一下灰度效果的算法及實現步驟。

function gray(canvasData)

{

for ( var x = 0; x < h; x++) {

for ( var y = 0; y < ht; y++) {

// Index of the pixel in the array

var idx = (x + y * h) * 4;

var r = [idx + 0];

var g = [idx + 1];

var b = [idx + 2];

var gray = .299 * r + .587 * g + .114 * b;

// assign gray scale value

[idx + 0] = gray; // Red channel

[idx + 1] = gray; // Green channel

[idx + 2] = gray; // Blue channel

[idx + 3] = 255; // Alpha channel

// add black border

if(x < 8 || y < 8 || x > (h - 8) || y > (ht - 8))

{

[idx + 0] = 0;

[idx + 1] = 0;

[idx + 2] = 0;

}

}

}

return canvasData;

}

4:mageData(canvasData, 0, 0); //處理完像素顏色值之後,記得要這一句將畫布重繪

這些個代碼就是將圖片轉化爲黑白效果的代碼,具體可以實現多少效果就得看你掌握的濾鏡算法有多少了。