當前位置:才華齋>計算機>java語言>

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

java語言 閱讀(1.44W)

導語: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); //處理完畫素顏色值之後,記得要這一句將畫布重繪

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