JavaScript視頻截圖

適用業(yè)務(wù)場景:

  • 視頻截圖搀菩、視頻捕捉螃成、視頻快照旦签;
  • 截取視屏第一幀,用作視頻封面展示寸宏;

實現(xiàn)思路:

  1. 主要通過canvas完成該功能顷霹;
  2. 通過drawImage將視頻寫入canvas;
  3. 通過video.currentTime設(shè)置視頻開始時間击吱;
  4. 通過canvas.toDataURL將canvas內(nèi)容輸出base64;

window.devicePixelRatio在<canvas>中更正分辨率遥昧;

完整代碼如下:

/**
 * 視頻截圖
 * @param {string} videoInfo.url - 視頻鏈接
 * @param {string} videoInfo.progress - 視頻截取的秒數(shù)
 * @author juehm
 * @returns {Promise.resolve(base64)}
 */
const videoSnapshot = (videoInfo) => {
  return new Promise((resolve, reject) => {
      
    const video = document.createElement('video')
    video.currentTime = videoInfo.progress  //截取第幾秒
    video.setAttribute('crossOrigin', 'anonymous')  //解決資源跨域問題
    video.setAttribute('src', videoInfo.url)  //資源鏈接
      
    // 當媒介數(shù)據(jù)已加載時運行的腳本覆醇。
    video.addEventListener('loadeddata', function () {
        
      const canvas = document.createElement('canvas')
      const ctx = canvas.getContext('2d')
      const ratio = window.devicePixelRatio // 設(shè)備像素比(更正分辨率)
      canvas.width = video.videoWidth * ratio
      canvas.height = video.videoHeight * ratio
      ctx.drawImage(video, 0, 0, canvas.width, canvas.height) //繪制圖片
      resolve({
        base64: canvas.toDataURL('image/png') // 輸出base64
      })
        
    })
      
    video.addEventListener('error', function (event) {
      reject({
        msg: '視頻資源異常'
      })
    })
  })
}

videoSnapshot({ url: './cat.mp4', progress: 1 }).then(({base64}) => {
  console.log(base64);
}).catch((err) => {
  console.log(err);
})
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市炭臭,隨后出現(xiàn)的幾起案子永脓,更是在濱河造成了極大的恐慌,老刑警劉巖鞋仍,帶你破解...
    沈念sama閱讀 218,036評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件常摧,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機落午,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評論 3 395
  • 文/潘曉璐 我一進店門谎懦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人溃斋,你說我怎么就攤上這事界拦。” “怎么了梗劫?”我有些...
    開封第一講書人閱讀 164,411評論 0 354
  • 文/不壞的土叔 我叫張陵享甸,是天一觀的道長。 經(jīng)常有香客問我梳侨,道長蛉威,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,622評論 1 293
  • 正文 為了忘掉前任走哺,我火速辦了婚禮蚯嫌,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘割坠。我一直安慰自己齐帚,他們只是感情好,可當我...
    茶點故事閱讀 67,661評論 6 392
  • 文/花漫 我一把揭開白布彼哼。 她就那樣靜靜地躺著对妄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪敢朱。 梳的紋絲不亂的頭發(fā)上剪菱,一...
    開封第一講書人閱讀 51,521評論 1 304
  • 那天,我揣著相機與錄音拴签,去河邊找鬼孝常。 笑死,一個胖子當著我的面吹牛蚓哩,可吹牛的內(nèi)容都是我干的构灸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,288評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼岸梨,長吁一口氣:“原來是場噩夢啊……” “哼喜颁!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起曹阔,我...
    開封第一講書人閱讀 39,200評論 0 276
  • 序言:老撾萬榮一對情侶失蹤半开,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后赃份,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體寂拆,經(jīng)...
    沈念sama閱讀 45,644評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡奢米,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,837評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了纠永。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鬓长。...
    茶點故事閱讀 39,953評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖渺蒿,靈堂內(nèi)的尸體忽然破棺而出痢士,到底是詐尸還是另有隱情,我是刑警寧澤茂装,帶...
    沈念sama閱讀 35,673評論 5 346
  • 正文 年R本政府宣布怠蹂,位于F島的核電站,受9級特大地震影響少态,放射性物質(zhì)發(fā)生泄漏城侧。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,281評論 3 329
  • 文/蒙蒙 一彼妻、第九天 我趴在偏房一處隱蔽的房頂上張望嫌佑。 院中可真熱鬧,春花似錦侨歉、人聲如沸屋摇。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽炮温。三九已至,卻和暖如春牵舵,著一層夾襖步出監(jiān)牢的瞬間柒啤,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評論 1 269
  • 我被黑心中介騙來泰國打工畸颅, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留担巩,地道東北人。 一個月前我還...
    沈念sama閱讀 48,119評論 3 370
  • 正文 我出身青樓没炒,卻偏偏與公主長得像涛癌,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子送火,可洞房花燭夜當晚...
    茶點故事閱讀 44,901評論 2 355

推薦閱讀更多精彩內(nèi)容