Vue+Video.js實(shí)現(xiàn)視頻抽幀并返回抽幀圖片Base64
1.vue
// 抽幀 (url視頻地址 time00:00:00:00時(shí)分秒幀 FPS視頻幀率) 返回抽幀圖片Base64
getImgBase64(url,time,FPS) {
var base64URL = ''
let video = document.createElement('video')
video.setAttribute('crossOrigin', 'anonymous') //處理跨域
video.setAttribute('src', url)
video.currentTime = this.timeToSeconds(time,FPS);
video.addEventListener('loadeddata', function() {
let canvas = document.createElement('canvas')
//使用視頻的寬高作為canvas、預(yù)覽圖的寬高
let width = video.videoWidth
let height = video.videoHeight
canvas.width = width
canvas.height = height
canvas.getContext('2d').drawImage(video, 0, 0, width, height) //繪制canvas
base64URL = canvas.toDataURL('image/jpeg') //轉(zhuǎn)換為base64,圖片格式默認(rèn)為png,這里修改為jpeg
// console.log(base64URL.split(",")[1]);
return base64URL.split(",")[1];
})
},
//時(shí)分秒幀 轉(zhuǎn)為秒
timeToSeconds(time,FPS) {
// 按小時(shí)、分鐘、秒進(jìn)行切割
const [hours, minutes, seconds,frame] = time.split(':');
// 計(jì)算總共的秒數(shù)
var second = parseInt(hours) * 3600 + parseInt(minutes) * 60 + parseInt(seconds)+ (1/FPS) * parseInt(frame);
//若秒數(shù)為0 防止黑幀 賦值0.1
if(second == 0){
second = 0.1;
}
return second;
},2.Java接口測(cè)試生成文件
/**
* 抽幀
* @param jsonObject
* @return
*/
@PostMapping("/getFetchFrame")
public AjaxResult getFetchFrame(@RequestBody JSONObject jsonObject) {
String imgStr = jsonObject.getString("imgStr");
OutputStream out = null;
BASE64Decoder decoder = new BASE64Decoder();
try {
byte[] b = decoder.decodeBuffer(imgStr);
//文件存儲(chǔ)位置
String uploadUrl = "C:\\Users\\cdv\\Desktop";
File testFile = new File(uploadUrl);
if (!testFile.exists()) {
testFile.mkdirs();
}
String fileName = "frame" + System.currentTimeMillis() + ".jpg";
String imgFilePath = uploadUrl + "/" + fileName;
out = new FileOutputStream(imgFilePath);
out.write(b);
out.flush();
return AjaxResult.success();
} catch (Exception e) {
logger.error("抽幀失??! error : " + e.getMessage());
return AjaxResult.error("抽幀失敗");
} finally {
try {
if (out != null) {
out.close();
}
} catch (Exception e2) {
logger.error("關(guān)閉輸出流失??! error : " + e2.getMessage());
return AjaxResult.error("關(guān)閉輸出流失敗");
}
}
}到此這篇關(guān)于Vue+Video.js實(shí)現(xiàn)視頻抽幀并返回抽幀圖片Base64的文章就介紹到這了,更多相關(guān)Vue Video.js視頻抽幀內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
關(guān)于vue項(xiàng)目vue-cli-service啟動(dòng)報(bào)錯(cuò)失敗問(wèn)題的解決方法
前端拉取代碼后,想要運(yùn)行代碼的時(shí)候可以能遇到啟動(dòng)報(bào)錯(cuò)的問(wèn)題,這里我們只針對(duì)于vue-cli-service報(bào)錯(cuò)項(xiàng)來(lái)說(shuō),文中通過(guò)圖文結(jié)合的方式給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下2024-08-08
vue中使用gantt-elastic實(shí)現(xiàn)可拖拽甘特圖的示例代碼
這篇文章主要介紹了vue中使用gantt-elastic實(shí)現(xiàn)可拖拽甘特圖,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07
Vue?計(jì)算屬性之姓名案例的三種實(shí)現(xiàn)方法
這篇文章主要介紹了Vue?計(jì)算屬性之姓名案例的三種實(shí)現(xiàn)方法,計(jì)算屬性實(shí)現(xiàn)、methods實(shí)現(xiàn)和插值語(yǔ)法實(shí)現(xiàn),下面文章具體介紹,需要的小伙伴可以參考一下2022-05-05
Vue 第三方字體圖標(biāo)引入 Font Awesome的方法
今天小編就為大家分享一篇Vue 第三方字體圖標(biāo)引入 Font Awesome的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
Vue封裝一個(gè)簡(jiǎn)單輕量的上傳文件組件的示例
這篇文章主要介紹了Vue封裝一個(gè)簡(jiǎn)單輕量的上傳文件組件的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-03-03
vue實(shí)現(xiàn)移動(dòng)端原生小球滑塊
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)移動(dòng)端原生小球滑塊,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03

