国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > HTML5 > 正文

canvas像素點(diǎn)操作之視頻綠幕摳圖

2024-09-05 07:22:39
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

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

用法:

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

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

下面的栗子簡(jiǎn)單實(shí)現(xiàn)了幾個(gè)簡(jiǎn)單的濾鏡效果,具體算法參考的這里,學(xué)過(guò)《數(shù)字圖像處理》的同學(xué)應(yīng)該對(duì)此理解更深刻。

demo

該栗子純屬為了演示功能而做,如果只強(qiáng)調(diào)效果而不在乎數(shù)據(jù)的話,用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();	}}

上周跟同學(xué)去了一趟溧陽(yáng)天目湖的南山竹海,在景區(qū)被忽悠拍了一張照片,就是這張 ——

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

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

Canvas同樣可以做到,并且可以處理視頻幀,其中的原理是一樣的 —— 將每個(gè)視頻幀中綠幕的像素塊透明度置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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 潞西市| 乾安县| 简阳市| 潞西市| 扬中市| 绍兴市| 涡阳县| 阿城市| 和林格尔县| 翁牛特旗| 灵川县| 大城县| 金门县| 海南省| 织金县| 浪卡子县| 西青区| 噶尔县| 五华县| 孝义市| 澄迈县| 柏乡县| 龙川县| 普兰县| 广宗县| 宁安市| 石台县| 泰宁县| 吉安市| 平江县| 陇南市| 甘泉县| 台北市| 正宁县| 乐都县| 宁津县| 陇西县| 阿克苏市| 石首市| 昌宁县| 保定市|