基于Vue3實(shí)現(xiàn)視頻播放與截圖功能
視頻播放
使用 HTML5 的 <video> 標(biāo)簽實(shí)現(xiàn),src 改成你自己的視頻路徑。
<video ref="videoRef" class="video-element" src="@/assets/video/1.mp4" autoplay loop muted ></video>
video 標(biāo)簽基本屬性
| 屬性 | 說(shuō)明 |
|---|---|
| src | 視頻文件路徑(支持相對(duì)/絕對(duì)路徑) |
| autoplay | 自動(dòng)播放(部分瀏覽器需配合muted屬性) |
| controls | 顯示默認(rèn)播放控制條 |
| width/height | 設(shè)置視頻顯示尺寸 |
| muted | 靜音播放 |
| loop | 循環(huán)播放 |
| preload | 預(yù)加載策略(auto/metadata/none) |
視頻截圖功能實(shí)現(xiàn)
思路
- 視頻幀捕獲:首先,通過(guò)
<video>元素獲取當(dāng)前播放的視頻幀畫面,瀏覽器會(huì)將視頻解碼為連續(xù)的圖像幀,我們可以通過(guò)<video>標(biāo)簽的API訪問(wèn)當(dāng)前顯示的幀。 - Canvas 繪制轉(zhuǎn)換:創(chuàng)建一個(gè)與視頻尺寸相同的
Canvas畫布,使用Canvas 2D上下文(Context2D)的drawImage()方法將視頻幀繪制到畫布上。 - Base64 編碼輸出:調(diào)用
Canvas的toDataURL()方法,將繪制好的圖像數(shù)據(jù)轉(zhuǎn)換為Base64編碼的圖片URL。該方法支持指定輸出格式(如PNG/JPEG)和質(zhì)量參數(shù),轉(zhuǎn)換后的數(shù)據(jù)可以直接用作圖片源或下載保存。
代碼實(shí)現(xiàn)
HTML
<template>
<div class="video-container">
<!-- 視頻播放器 -->
<div class="video-wrapper">
<video
ref="videoRef"
class="video-element"
src="@/assets/video/1.mp4"
autoplay
controls
></video>
</div>
</div>
</template>
js
<script setup>
import { ref, onMounted, onBeforeUnmount } from "vue";
import { ElMessage } from "element-plus";
const videoRef = ref(null);
const screenshotUrl = ref(""); // 截圖后的圖片URL
// 截圖功能
const scanImage = () => {
if (!videoRef.value) return;
try {
// 創(chuàng)建canvas元素
const canvas = document.createElement("canvas");
const video = videoRef.value;
// 設(shè)置canvas尺寸與視頻相同
canvas.width = video.videoWidth;
canvas.height = video.videoHeight;
// 繪制當(dāng)前視頻幀到canvas
const ctx = canvas.getContext("2d");
ctx.drawImage(video, 0, 0, canvas.width, canvas.height);
// 轉(zhuǎn)換為DataURL
screenshotUrl.value = canvas.toDataURL("image/png");
ElMessage.success("截圖成功!");
} catch (error) {
console.error("截圖失敗:", error);
ElMessage.error("截圖失敗: " + error.message);
}
};
// 快捷鍵支持 (F9截圖)
const handleKeyDown = (e) => {
if (e.key === "F9") {
e.preventDefault();
scanImage();
}
};
// 添加事件監(jiān)聽(tīng)
onMounted(() => {
window.addEventListener("keydown", handleKeyDown);
});
// 移除事件監(jiān)聽(tīng)
onBeforeUnmount(() => {
window.removeEventListener("keydown", handleKeyDown);
});
</script>
css
<style lang="scss" scoped>
.video-container {
padding: 20px;
max-width: 800px;
margin: 0 auto;
}
.video-wrapper {
position: relative;
border-radius: 8px;
overflow: hidden;
box-shadow: 0 2px 12px 0 rgba(0, 0, 0, 0.1);
background: #000;
}
.video-element {
width: 100%;
display: block;
}
.screenshot-controls {
position: absolute;
bottom: 20px;
right: 20px;
z-index: 10;
}
.screenshot-result {
display: flex;
justify-content: center;
align-items: center;
min-height: 300px;
}
.screenshot-image {
max-width: 100%;
border: 1px solid #ebeef5;
border-radius: 4px;
}
.empty-tip {
color: #909399;
font-size: 14px;
text-align: center;
padding: 20px;
}
</style>
到此這篇關(guān)于基于Vue3實(shí)現(xiàn)視頻播放與截圖功能的文章就介紹到這了,更多相關(guān)Vue3視頻播放與截圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何在Vue項(xiàng)目中使用axios請(qǐng)求
這篇文章主要介紹了如何在Vue項(xiàng)目中使用axios請(qǐng)求,對(duì)Vue感興趣的同學(xué),可以參考下2021-05-05
vue中使用elementui實(shí)現(xiàn)樹(shù)組件tree右鍵增刪改功能
這篇文章主要介紹了vue中使用elementui實(shí)現(xiàn)對(duì)樹(shù)組件tree右鍵增刪改功能,右擊節(jié)點(diǎn)可進(jìn)行增刪改,對(duì)節(jié)點(diǎn)數(shù)據(jù)進(jìn)行模糊查詢功能,本文給大家分享了完整代碼,需要的朋友可以參考下2022-08-08
vue-cli 3 全局過(guò)濾器的實(shí)例代碼詳解
這篇文章主要介紹了vue-cli 3 全局過(guò)濾器的實(shí)例代碼,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-06-06
Vue filter 過(guò)濾器、以及在table中的使用介紹
這篇文章主要介紹了Vue filter 過(guò)濾器、以及在table中的使用介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-09-09
vue單頁(yè)面在微信下只能分享落地頁(yè)的解決方案
這篇文章主要介紹了vue單頁(yè)面在微信下只能分享落地頁(yè)的解決方案,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-04-04
vue組件實(shí)現(xiàn)彈出框點(diǎn)擊顯示隱藏效果
這篇文章主要為大家詳細(xì)介紹了vue組件實(shí)現(xiàn)彈出框點(diǎn)擊顯示隱藏,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
Vue使用canvas實(shí)現(xiàn)圖片壓縮上傳
這篇文章主要為大家詳細(xì)介紹了Vue使用canvas實(shí)現(xiàn)圖片壓縮上傳,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08

