JS預先載入視訊音訊/視訊擷取截圖技巧分享
本文主要介紹了JS實現預先載入視訊音訊/視訊獲取截圖(返回canvas截圖)的相關資料,需要的朋友可以參考下,希望能幫助到大家。
#load-media.js
/** * Create by Capricorncd 2017 */ // 同域资源实现视频截图,可上传的图片数据格式 // 非同域资源实现canvas截图预览 // 提示码 const CODES = { 0: 'success', 1: 'The url is not valid', 2: 'onerror' } /** * constructor * @param opts.url 音频|视频URL * @param opts.type 'audio|video' * @param opts.callback 回调函数 */ function loadMedia(opts) { this.callback = opts.callback || function (res) { console.log(res); } // 初始化 this.init(opts); } // prototype loadMedia.prototype = { /** * 初始化media * @param url */ init: function (opts) { let self = this; if (!opts.url || typeof opts.url !== 'string') { this.callback({code: 1, msg: CODES[1]}); return; } // 创建media let mediaType = opts.type === 'audio' ? 'audio' : 'video'; this.media = document.createElement(mediaType); console.log('this.media', this.media); // loaded this.listener('canplaythrough', function (e) { // 截图 if (mediaType === 'video') { self.screenshot(); } else { self.callback({ code: 0, msg: CODES[0], thumb: null, media: this.media, canvas: null }); } }); // error this.listener('error', function (e) { self.callback({code: 2, msg: CODES[2], data: e}); }) this.media.setAttribute('src', opts.url); }, screenshot: function () { // create canvas let canvas = document.createElement('canvas'); canvas.width = this.media.videoWidth; canvas.height = this.media.videoHeight; let ctx = canvas.getContext('2d'); // 截取 ctx.drawImage(this.media, 0, 0); let thumb = null; // 非跨域资源 // !!非同域资源无法获取数据 try { let type = 'image/png'; let data = canvas.toDataURL(type); thumb = this.toBlobData(data, type); } catch (e) {} this.callback({ code: 0, msg: CODES[0], thumb: thumb, media: this.media, canvas: canvas }) }, // 数据转换 toBlobData: function (data, type) { // 获取base64数据 // base64数据格式: // "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQEASABIAAD/2wBDAAkGB+wgHBgkIBwgKCgkLDRYPDQw//9k=" data = window.atob(data.split(',')[1]); let ia = new Uint8Array(data.length); for (let i = 0; i < data.length; i++) { ia[i] = data.charCodeAt(i); }; // canvas.toDataURL 返回的默认格式是 image/png return new Blob([ia], {type: type}); }, /** * addEventListener 事件监听 * @param en EventName * @param callback */ listener: function (en, callback) { this.media.addEventListener(en, function (e) { if (callback) { callback(e); } else { console.warn(this); } }, false); } /** * 资源是否跨域 * @param url 资源地址 * @returns {boolean} */ // isCrossDomain: function (url) { // let loc, host, protocol; // loc = window.location; // host = loc.host; // protocol = loc.protocol; // // 是否为http链接 // if (/(http|https):\/\//.test(url)) { // if (url.indexOf(protocol + '//' + host) >= 0) { // return false; // } else { // return true; // } // } // // './xxx.mp4' '/xxx.mp4' 'xxx.mp4' // return false; // } }
export default loadMedia;
// 参考资料 // HTML5的Video标签的属性,方法和事件汇总 // http://www.cnblogs.com/TF12138/p/4448108.html # 使用 import loadMedia from '@/common/js/load-media' let loadVideo = new loadMedia({ type: 'video', url: 'http://xmqvip1-1253933147.file.myqcloud.com/chat/video/60/2017/09/29/qgj1c8K7oaYn-SCVideo-Merged.mp4', callback: handleCallback }) function handleCallback (res) { console.log(res) // canplaythrough if (res.code === 0) { } // error if (res.code === 2) { } }
相關推薦:
javascript - 如何使用phantomjs取得截圖並儲存
#以上是JS預先載入視訊音訊/視訊擷取截圖技巧分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

截圖是電腦上非常常用的功能,它可以輕鬆捕捉並分享螢幕上的內容。在電腦上,有許多方法可以進行截圖。現在,讓我們來介紹一下聯想ThinkPadX13筆記本常用的截圖方法。聯想ThinkPadX13螢幕截圖方法介紹關於電腦上的截圖方法,有多種選擇可供使用。在這裡,我們將重點介紹ThinkPadX13的快捷鍵截圖和主流軟體截圖的方法。 ThinkPadX13提供了簡單的快速鍵截圖功能。您只需按下Fn鍵和PrtSc鍵,即可將目前畫面的內容截圖儲存到剪貼簿中。之後,您可以開啟任何圖片編輯軟體,如Paint

螢幕截圖功能在您的iPhone上不起作用嗎?截圖非常簡單,因為您只需同時按住「提高音量」按鈕和「電源」按鈕即可抓取手機螢幕。但是,還有其他方法可以在設備上捕獲幀。修復1–使用輔助觸控使用輔助觸控功能截取螢幕截圖。步驟1–轉到您的手機設定。步驟2–接下來,點選以開啟「輔助功能」設定。步驟3–開啟「觸摸」設定。步驟4–接下來,開啟「輔助觸控」設定。步驟5–打開手機上的「輔助觸控」。步驟6–打開“自訂頂級選單”以存取它。步驟7–現在,您只需將這些功能中的任何一個連結到螢幕擷取即可。因此,點擊那裡的首

最近很多消費者都考慮更換手機,Redmi13C是一款性價比很高的選擇。這款手機性能配置很出色,為了方便日常使用,以下我來簡單介紹一下如何在紅米13C上進行截圖操作,讓我們一起來了解一下吧!紅米13c怎麼截圖1.快捷鍵截圖:同時按下紅米手機的電源鍵和音量減鍵,即可實現截圖操作。 2.手勢截圖:進入紅米手機的設置,找到“更多設置”,在其中找到並點擊“手勢及按鍵快捷方式”,然後開啟“三指下拉”操作,設置成截圖。這樣在需要截圖的時候,只需要用三根手指在螢幕上向下滑動,即可實現截圖。 3.通知欄截圖:從手機螢幕

mac截圖該怎麼發送微信,首先在桌面找到launchpad打開進去後找到微信,然後點擊微信進行登入最後再彈出來的偏好設定中進入快捷鍵設定視窗就可以了。 mac截圖怎麼發送微信1、在桌面找到launchpad。 2、然後找到微信。 3.點選登入微信。 4.登入上去後在電腦頁面的左上角找到微信選項並開啟。 5.然後在彈出來的選單中偏好設定選項進入快捷設定窗口,最後在快捷鍵設定頁面中找到截圖功能並設定好按鍵就可以了。

1.按下win鍵+r鍵,輸入regedit,點選確定。 2.在開啟的登錄編輯窗口,依序展開:HKEY_LOCAL_MACHINESYSTEMCurrentControlSetControlGraphicsDriversDCI,選取右邊的Timeout雙擊。 3.然後把【數值資料】中的7改為0,確定退出即可。

Win8如何利用快捷鍵進行截圖?在日常使用電腦的過程中,我們經常需要將螢幕上的內容截圖。對於Windows8系統的使用者來說,透過快捷鍵截圖是一個方便且有效率的操作方式。在這篇文章中,我們將介紹Windows8系統中幾種常用的快捷鍵進行截圖的方法,幫助大家更快速地進行螢幕截圖操作。第一種方法是使用「Win鍵+PrintScreen鍵」組合鍵來進行全

榮耀Magic5Pro配備了MagicOS7.1作業系統,操作非常順暢。那麼,如何在Magic5Pro上進行截圖呢?本文將為大家提供詳細的一鍵截圖教學榮耀Magic5Pro截圖教學榮耀Magic5Pro支援標準截圖、局部截圖和長截圖。以下是具體的截圖方法:在手機螢幕的頂部邊緣向下滑動,就可以打開控制中心。在控制中心中找到截圖圖標,點擊它可以快速進行截圖。另外,也可以同時按下【音量-】和【開機鍵】來進行截圖操作如果您需要進行局部截圖或長截圖,您需要點擊截圖圖示右下角的倒三角。一旦點擊,會顯示【局

聯想電腦win10系統該如何截圖呢?當我們工作的時候,快捷鍵截圖可以省心跟多,節約時間又方便,今天小編整理了相關的截圖方法,希望可以幫助到大家,下面一起來看吧。聯想電腦win10截圖快捷鍵方式一、電腦本身快捷鍵截圖1、抓取全螢幕首先找到想截取的圖片,點一下鍵盤上的PrintScreen鍵(或prtsc)鍵,然後啟動「畫圖(開始-程式-附件)”,按Ctrl+V或“編輯-貼上”就可以將當前畫面抓下來,然後儲存為Bmp/Jpeg就可以了。 2、抓取目前活動視窗(最常用)按下Alt鍵,點選PrintScr
