JavaScript判斷視頻編碼是否為h.264


1.視頻編碼是什么?

現在視頻編碼主流是h.264,對應着輸入格式為AVC

H.264/AVC是2003年制定的視頻編碼壓縮標准 ,集中了以往標准的優點,並吸收了以往標准制定中積累的經驗,采用簡潔設計,使它比MPEG4更容易推廣。H.264創造性了多參考幀、多塊類型、整數變換、幀內預測等新的壓縮技術,使用了更精細的分象素運動矢量(1/4、1/8)和新一代的環路濾波器,使得壓縮性能大大提高,系統更加完善。
有興趣深入了解可以好好看看

好學直通車
https://baike.baidu.com/item/%E8%A7%86%E9%A2%91%E7%BC%96%E7%A0%81/839038?fr=aladdin

2.獲取視頻的基本信息

  • 我們通過input拿到系統對象e里面的文件信息很有限,而且沒有我們想要的東西。

  • 引入插件mediainfo.js
    這是出色的MediaInfoLib的JavaScript端口, 可以直接在瀏覽器或Node.js中運行。它使用Emscripten從C ++源代碼進行編譯 。

演示地址https://mediainfo.js.org/

github地址https://github.com/buzz/mediainfo.js

看下他的魔法,使用很簡單可以直接用CDN

<script type="text/javascript" src="https://unpkg.com/mediainfo.js/dist/mediainfo.min.js"></script>
function base_videoInfo(id) {
	const fileinput = document.getElementById(id);
	const onChangeFile = (mediainfo) => {
		const file = fileinput.files[0]
		if (file) {
			const getSize = () => file.size
			const readChunk = (chunkSize, offset) =>
				new Promise((resolve, reject) => {
					const reader = new FileReader()
					reader.onload = (event) => {
						if (event.target.error) {
							reject(event.target.error)
						}
						resolve(new Uint8Array(event.target.result))
					}
					reader.readAsArrayBuffer(file.slice(offset, offset + chunkSize))
				})
			mediainfo.analyzeData(getSize, readChunk).then((result) => {
				// console.log(result)
				// console.log(result.media.track[1].Format)
				//result.media.track[1].Format == "AVC"說明是h264
				if (result.media.track[1].Format != "AVC") {
					
				}
			}).catch((error) => {
				console.log(error)
			})
		}
	}
	MediaInfo({ format: 'object' }, (mediainfo) => {//format結果值的格式(選擇:object,JSON,XML,HTML或text)
		fileinput.addEventListener('change', () => onChangeFile(mediainfo))
	})
}


看下拿到的東西夠不夠詳細

3.用canvas給上傳視頻畫個縮略圖

沒用插件之前我是通過先在頁面創建video標簽然后播放視頻最后拿到視頻的寬高、時長等信息,用了插件完全不需要了

		function drawVideoImage() {
			var videoUrl = window.URL.createObjectURL(file);
			var video = document.createElement('video');
			video.src = videoUrl;
			// 讓視頻自動播放來來獲取寬高和縮略圖
			video.autoplay = true;
			video.muted = true;
			$('#createDynamicMadal .video').html('');
			$('#createDynamicMadal .video').append(video);
			// 當video加載完成時獲取的
			$('#createDynamicMadal .video video')[0].onloadedmetadata = function () {
				videoHeight = $(this).height();
				videoWidth = $(this).width();
			}
			$('#createDynamicMadal .video video')[0].play();
			var index = 0;
			$('#createDynamicMadal .video video')[0].ontimeupdate = function () {
				var time = Math.floor(this.duration);
				var canvas = document.createElement('canvas');
				canvas.width = videoWidth;
				canvas.height = videoHeight;
				var context = canvas.getContext('2d');
				context.fillStyle = '#000';
				context.drawImage(this, 0, 0, canvas.width, canvas.height, 0, 0, canvas.width, canvas.height);
				var src = canvas.toDataURL('image/jpeg');
				// 將視頻的縮略圖渲染到頁面中
				if (src != 'data:,') {
					var dynamicImg = new Image();
					dynamicImg.src = src;
					$(dynamicImg).attr('index-video', '1');
					// 將壓縮的后的圖片渲染到頁面中
					$('.upload-video').before(`<div class="upload-item upload-items upload-video-img" style="display:inline-block;margin-right:5px;"><img src="${src}" index-video='2'><i class="iconfont icon-guanbishixin delete-img"></i><div class="edit_cover">編輯封面</div></div>`)
					thumbnailImg = dataURLtoFile(src, 'thumbnailImg.jpeg');
					duration = time;
					this.ontimeupdate = null;
					$('#file-upload').val('');
					// 隱藏選擇視頻框
					$('.upload-video').hide();
					$('#loading').hide();
					$('#loading .loading-item .loading-text').text('');
					// 清空創造的video標簽,避免造成性能浪費以及報錯
					$('#createDynamicMadal .video').html('');
					// 加載完成后銷毀url,節省性能
					window.URL.revokeObjectURL(videoUrl);
				}
			}
		}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM