麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > HTML > 正文

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

2024-08-26 00:21:00
字體:
來源:轉載
供稿:網友

 本文介紹了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

 

 
canvas,像素點,視頻,綠幕,摳圖

 

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

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

 

 
canvas,像素點,視頻,綠幕,摳圖

 

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

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

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

demo

 

 
canvas,像素點,視頻,綠幕,摳圖

 

部分代碼

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 大西瓜永久免费av在线 | 毛片毛片 | 日韩av在线网址 | 国产精品一品二区三区四区18 | 色综合久久99 | 国产精品99久久99久久久二 | 伊人二本二区 | 噜噜噜躁狠狠躁狠狠精品视频 | 精品一区二区久久久久久久网精 | 色妞妞视频 | 久久国产成人精品国产成人亚洲 | 成人毛片100部免费观看 | bt 自拍 另类 综合 欧美 | 九色免费视频 | 在线成人一区二区 | 蜜桃91丨九色丨蝌蚪91桃色 | 免费毛片电影 | 亚洲成人播放 | 毛片在线免费视频 | 欧美精品一区二区久久 | 88xx成人精品视频 | 污污黄| 免费一级毛片免费播放 | 日韩视频一区二区 | 一区在线视频观看 | 免费中文视频 | 欧美一级久久 | 免费中文视频 | 鲁丝一区二区三区不属 | 欧美一区高清 | 色综合视频 | 国产一区视频免费观看 | 色999久久久精品人人澡69 | 一区二区三区视频在线 | 草草在线观看 | 成人免费精品视频 | 激情视频导航 | 少妇一级淫片免费放正片 | 欧美性受ⅹ╳╳╳黑人a性爽 | 综合国产一区 | 成人毛片100部 |