日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

html5 手机拍视频滤镜,用canvas实现图片滤镜效果附演示_html5教程技巧

發布時間:2025/3/8 编程问答 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 html5 手机拍视频滤镜,用canvas实现图片滤镜效果附演示_html5教程技巧 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

這是一個很有意思的特效,模擬攝像機拍攝電視屏幕畫面時出現點狀顆粒的效果。顆粒的大小通過變換矩陣實現,可以任意調節,有興趣研究的朋友可以嘗試更多的效果,代碼沒有經過優化,只是一個粗糙的Demo,大家可以自行改進。

1.獲取圖像數據

復制代碼代碼如下:

img.src = ’http://bloglaotou.duapp.com/wp-content/themes/frontopen2/tools/filter/image2.jpg’;

canvas.width = img.width;

canvas.height = img.height;

var context = canvas.getContext(“2d”);

context.drawImage(img, 0, 0);

var canvasData = context.getImageData(0, 0, canvas.width, canvas.height);

2.設置過濾矩陣

復制代碼代碼如下:

var m_VideoType=0;

var pattern=new Array();

switch (m_VideoType)

{

case0://VIDEO_TYPE.VIDEO_STAGGERED:

{

pattern = [

0, 1,

0, 2,

1, 2,

1, 0,

2, 0,

2, 1,

];

break;

}

case1://VIDEO_TYPE.VIDEO_TRIPED:

{

pattern = [

0,

1,

2,

];

break;

}

case2://VIDEO_TYPE.VIDEO_3X3:

{

pattern =

[

0, 1, 2,

2, 0, 1,

1, 2, 0,

];

break;

}

default:

{

pattern =

[

0, 1, 2, 0, 0,

1, 1, 1, 2, 0,

0, 1, 2, 2, 2,

0, 0, 1, 2, 0,

0, 1, 1, 1, 2,

2, 0, 1, 2, 2,

0, 0, 0, 1, 2,

2, 0, 1, 1, 1,

2, 2, 0, 1, 2,

2, 0, 0, 0, 1,

1, 2, 0, 1, 1,

2, 2, 2, 0, 1,

1, 2, 0, 0, 0,

1, 1, 2, 0, 1,

1, 2, 2, 2, 0,

];

break;

}

}

var pattern_width = [ 2, 1, 3, 5 ];

var pattern_height = [6, 3, 3, 15 ];

3.獲取過濾數據

復制代碼代碼如下:

for ( var x = 0; x < canvasData.width; x++) {

for ( var y = 0; y < canvasData.height; y++) {

// Index of the pixel in the array

var idx = (x + y * canvasData.width) * 4;

var r = canvasData.data[idx + 0];

var g = canvasData.data[idx + 1];

var b = canvasData.data[idx + 2];

var nWidth = pattern_width[m_VideoType];

var nHeight = pattern_height[m_VideoType];

var index = nWidth * (y % nHeight) + (x % nWidth);

index = pattern[index];

if (index == 0)

var r = fclamp0255(2 * r);

if (index == 1)

var g = fclamp0255(2 * g);

if (index == 2)

var b = fclamp0255(2 * b);

// assign gray scale value

canvasData.data[idx + 0] = r; // Red channel

canvasData.data[idx + 1] = g; // Green channel

canvasData.data[idx + 2] = b; // Blue channel

canvasData.data[idx + 3] = 255; // Alpha channel

// 加上黑色的邊框

if(x < 8 || y < 8 || x > (canvasData.width - 8) || y > (canvasData.height - 8))

{

canvasData.data[idx + 0] = 0;

canvasData.data[idx + 1] = 0;

canvasData.data[idx + 2] = 0;

}

}

}

4.寫入過濾后的數據

復制代碼代碼如下:

context.putImageData(canvasData, 0, 0);

5.參考資料

代震軍ImageFilter開源項目

聲明:本文原創發布php中文網,轉載請注明出處,感謝您的尊重!如有疑問,請聯系admin@php.cn處理

總結

以上是生活随笔為你收集整理的html5 手机拍视频滤镜,用canvas实现图片滤镜效果附演示_html5教程技巧的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。