亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

canvas像素點操作之視頻綠幕摳圖

2024-09-05 07:22:39
字體:
來源:轉載
供稿:網友

 本文介紹了canvas像素點操作之視頻綠幕摳圖,分享給大家,具體如下:

用法:

context.putImageData(imgData, x, y, dX, dY, dWidth, dHeight);
  

參數 描述
imgData 規定要放回畫布的 ImageData 對象。
x ImageData 對象左上角的 x 坐標,以像素計。
y ImageData 對象左上角的 y 坐標,以像素計。
dX 可選。水平值(x),以像素計,在畫布上放置圖像的位置。
dY 可選。水平值(y),以像素計,在畫布上放置圖像的位置。
dWidth 可選。在畫布上繪制圖像所使用的寬度。
dHeight 可選。在畫布上繪制圖像所使用的高度。

下面的栗子簡單實現了幾個簡單的濾鏡效果,具體算法參考的這里,學過《數字圖像處理》的同學應該對此理解更深刻。

demo

該栗子純屬為了演示功能而做,如果只強調效果而不在乎數據的話,用CSS3的filter屬性便能高效又輕松地搞定。

部分代碼

import imgUrl from './component/sample.jpg';export default {	data () {		return {			imgUrl: imgUrl		}	},	methods: {		onOperate1 () {			this.ctx.putImageData(this.onCompute1(), 0, 0);		},		onOperate2 () {			this.ctx.putImageData(this.onCompute2(), 0, 0);		},		...		onCancel () {			this.reload();		},		onCompute1 () {			let data = this.frameData.data;	        for (let i = 0; i < this.imgDataLength; i += 4) {	          	let r = data[i + 0],	          		g = data[i + 1],	          		b = data[i + 2];	          	          		data[i + 0] = 255 - r;          		data[i + 1] = 255 - g;          		data[i + 2] = 255 - b;	        }	        return this.frameData;		},		onCompute2 () {			let data = this.frameData.data;	        for (let i = 0; i < this.imgDataLength; i += 4) {	          	data[i] = Math.abs(data[i + 1] - data[i + 2] + data[i + 1] + data[i]) * data[i] / 256;              	data[i + 1] = Math.abs(data[i + 2] - data[i + 1] + data[i + 2] + data[i]) * data[i] / 256;              	data[i + 2] = Math.abs(data[i + 2] - data[i + 1] + data[i + 2] + data[i]) * data[i + 1] / 256;	        }	        return this.frameData;		},		...	},	mounted () {        this.canvas = this.$refs['canvas'];        this.ctx = this.canvas.getContext('2d');        this.reload();	}}

上周跟同學去了一趟溧陽天目湖的南山竹海,在景區被忽悠拍了一張照片,就是這張 ——

然后被朋友圈吐槽摳圖。其實當時就是站在一塊綠幕前拍的:joy: 。

PS中魔法棒工具可以把圖片中一定容差下的相近像素都選中、清空,輕松做到一鍵“摳圖”,前提是主體一定要與背景有大的差異,即像素值差值越大,摳圖效果越好。

Canvas同樣可以做到,并且可以處理視頻幀,其中的原理是一樣的 —— 將每個視頻幀中綠幕的像素塊透明度置0即可。像這樣 ——

demo

部分代碼

import videoUrl from './component/video.ogv';import imgUrl from './component/sample.jpg';const TOLERANCE = 5;export default {	data () {		return {			videoUrl: videoUrl,			imgUrl: imgUrl		}	},	methods: {		draw () {			if (this.video.paused || this.video.ended) {	          	return;	        }			this.ctx.drawImage(this.video, 0, 0, this.width, this.height);			this.ctx.putImageData(this.cutOut(), 0, 0);		},		cutOut () {			let frameData = this.ctx.getImageData(0, 0, this.width, this.height),				len = frameData.data.length / 4;	        for (let i = 0; i < len; i++) {	          	let r = frameData.data[i * 4 + 0],	          		g = frameData.data[i * 4 + 1],	          		b = frameData.data[i * 4 + 2];	          	if (r - 100 >= TOLERANCE 	          	 && g - 100 >= TOLERANCE 	          	 && b - 43 <= TOLERANCE) {		            frameData.data[i * 4 + 3] = 0;	          	}	        }	        return frameData;		}	},	mounted () {		this.video = this.$refs['video'];        this.canvas = this.$refs['canvas'];        this.ctx = this.canvas.getContext('2d');        this.timer = null;        this.video.addEventListener('play', () => {            this.width = this.video.videoWidth;            this.height = this.video.videoHeight;            this.timer && clearInterval(this.timer);            this.timer = setInterval(() => {            	this.draw();            }, 50);        }, false);	}}

參考資料

Manipulating video using canvas

 Pixel manipulation with canvas

Canvas and images and pixels

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
性色av一区二区三区| 亚洲精品综合精品自拍| 国产91热爆ts人妖在线| 久久国产精品久久久久久久久久| 亚洲欧洲午夜一线一品| 日韩欧美在线免费观看| 日韩高清av在线| 欧洲午夜精品久久久| 美女啪啪无遮挡免费久久网站| 欧美日韩免费看| 国产成人精品视频| 欧美日韩国产一区在线| 久久久国产成人精品| 欧美有码在线视频| 国产va免费精品高清在线| 日本亚洲精品在线观看| 精品久久久久久久久国产字幕| 国产精品久久久久久久久久久久| 欧美午夜精品久久久久久浪潮| 韩日欧美一区二区| 亚洲欧美日韩一区二区三区在线| 亚洲精品一区二区网址| 国外日韩电影在线观看| 国产午夜一区二区| 茄子视频成人在线| www日韩中文字幕在线看| 97香蕉超级碰碰久久免费的优势| 欧美性69xxxx肥| 欧美激情日韩图片| 国产午夜精品一区二区三区| 欧美激情视频网| 日韩欧美亚洲综合| 日韩欧美在线视频观看| 欧美xxxx综合视频| 国产伦精品免费视频| 亚洲在线免费看| 国产成人精品视频在线| 国产深夜精品福利| 亚洲色图av在线| 色偷偷888欧美精品久久久| 日韩禁在线播放| 成人午夜一级二级三级| 九九热99久久久国产盗摄| 精品亚洲国产视频| www高清在线视频日韩欧美| 欧美亚洲成人xxx| 欧美亚洲视频在线看网址| 97欧美精品一区二区三区| 欧美成人精品一区二区三区| 亚洲性视频网址| 成人在线精品视频| 亚洲欧美激情在线视频| 色妞色视频一区二区三区四区| 亚洲a在线观看| 欧美激情亚洲一区| 国内揄拍国内精品| 黑人精品xxx一区| 国产日韩欧美视频在线| 欧美日韩亚洲91| 91夜夜未满十八勿入爽爽影院| 国产精品亚洲美女av网站| 国产精品欧美一区二区| 7777kkkk成人观看| 欧美亚洲国产成人精品| 欧美性生活大片免费观看网址| 中文字幕日韩欧美精品在线观看| 91天堂在线视频| 91色视频在线观看| 久久综合88中文色鬼| 国产精品久久久久99| 中文字幕一区日韩电影| 国产亚洲激情视频在线| 国产日韩欧美中文在线播放| 精品综合久久久久久97| 欧美精品在线网站| 国产久一一精品| 91中文精品字幕在线视频| 欧美麻豆久久久久久中文| 色妞色视频一区二区三区四区| 国产视频欧美视频| 中文字幕日本精品| 91久久国产精品| 日韩免费av片在线观看| 久热精品视频在线| 超薄丝袜一区二区| 欧美视频在线观看免费网址| 一区二区福利视频| 这里只有精品在线播放| 欧美性资源免费| 一区二区亚洲精品国产| 狠狠爱在线视频一区| 日韩精品小视频| 国产精品视频网站| 成人网中文字幕| 亚洲性生活视频在线观看| 国产精品免费福利| 91精品国产91久久久久久吃药| 欧美日韩激情小视频| 2023亚洲男人天堂| 国产精品91视频| 欧洲亚洲妇女av| 成人免费网站在线观看| 夜夜狂射影院欧美极品| 欧美午夜影院在线视频| 国产成人精品在线观看| 国产极品jizzhd欧美| 成人免费淫片aa视频免费| 欧美中文字幕在线观看| 欧美成人午夜免费视在线看片| 亚洲欧洲偷拍精品| 日本中文字幕久久看| 亚洲精品中文字幕女同| 成人免费视频在线观看超级碰| 日韩av综合中文字幕| 在线观看日韩www视频免费| 庆余年2免费日韩剧观看大牛| 亚洲人免费视频| 久久夜精品香蕉| 亚洲美女av在线播放| 中文字幕av一区中文字幕天堂| 精品久久久久久中文字幕大豆网| 欧美巨大黑人极品精男| 成人激情在线观看| xvideos亚洲人网站| 亚洲精品视频久久| 国产成人精品一区二区三区| 亚洲美女精品成人在线视频| 亚洲精品电影在线观看| 人妖精品videosex性欧美| 亚洲综合中文字幕在线观看| 国产精品你懂得| 亚洲高清久久网| 日韩三级影视基地| 日本久久中文字幕| 国产精品久久久久久久久久99| 欧美国产视频一区二区| 国产精品激情av电影在线观看| 亚洲综合日韩中文字幕v在线| 久久久之久亚州精品露出| 欧美一二三视频| 日韩精品视频在线观看免费| 午夜精品一区二区三区av| 日韩欧美黄色动漫| 精品动漫一区二区| 2019中文字幕全在线观看| 欧美日韩国产麻豆| 2025国产精品视频| 国产精品日韩在线一区| 91大神福利视频在线| 欧美色道久久88综合亚洲精品| 亚洲国产天堂久久综合| 日韩av在线网| 中文国产成人精品久久一| 国产日韩欧美成人| 日韩精品视频在线免费观看| 久99九色视频在线观看| 久久久97精品| 成人午夜黄色影院| 亚洲欧洲美洲在线综合| 日韩中文字幕久久| 欧美理论片在线观看| 色综合伊人色综合网| 色妞欧美日韩在线| 欧美日韩国产一区中文午夜|