vue3使用flv.js播放flv直播流的代碼示例
目前有個(gè)需求是:管理直播機(jī)有一個(gè)列表需要查看每個(gè)直播機(jī)的實(shí)時(shí)內(nèi)容,所以需要在后臺(tái)加這個(gè)功能。
效果:我用ffmpeg模擬推流:
如何用ffmpeg模擬推流請(qǐng)看我上一篇文章
網(wǎng)頁(yè):
如上是可以正確再網(wǎng)頁(yè)端拉流,這個(gè)功能費(fèi)了一天的時(shí)間,在這里免費(fèi)分享出來(lái)。
首先安裝flv.js(用npm的話我遇到過(guò)報(bào)錯(cuò)):
pnpm i flv.js
頁(yè)面核心代碼:
html:
<video ref="videoElementRef" controls autoplay muted style="width: 400px; height: 300px; object-fit: fill"></video>
js:
import { computed, ref, nextTick, watch } from 'vue'; const formValue = ref(newState(null)); const flvPlayer = ref<flvjs.Player | null>(null); const videoElementRef = ref<HTMLVideoElement | null>(null); // 明確類型 const createVideo = async () => { if (flvjs.isSupported()) { if (!videoElementRef.value) { console.warn('videoElementRef.value is null, retrying...'); return; // 如果 video 元素還未準(zhǔn)備好,則直接返回 } console.log('videoElement', videoElementRef.value); flvPlayer.value = flvjs.createPlayer({ type: 'flv', // 只支持flv和mp4 url: 'http://live.xxx.com/xxx/2.flv', //你的url地址 isLive: true, hasAudio: true, }); console.log('flvPlayer.value', flvPlayer.value); flvPlayer.value.attachMediaElement(videoElementRef.value); flvPlayer.value.load(); flvPlayer.value.play(); //處理視頻播放錯(cuò)誤的語(yǔ)法 flvPlayer.value.on('error', () => { message.error(`視頻加載失敗,請(qǐng)稍候重試!`); return false; }); } }; // 監(jiān)聽(tīng) formValue 的變化,當(dāng)數(shù)據(jù)加載完成后初始化視頻 watch( () => formValue.value, (newFormValue) => { if (newFormValue && showModal.value) { nextTick(() => { createVideo(); }); } }, { deep: true, immediate: false } // 深度監(jiān)聽(tīng),并且初始不執(zhí)行 ); ?
頁(yè)面關(guān)閉時(shí)銷毀flvPlayer:
//銷毀播放器
if (flvPlayer.value) { flvPlayer.value.pause(); flvPlayer.value.unload(); flvPlayer.value.detachMediaElement(); flvPlayer.value.destroy(); flvPlayer.value = null; }
總結(jié)
到此這篇關(guān)于vue3使用flv.js播放flv直播流的文章就介紹到這了,更多相關(guān)vue3 flv.js播放flv直播流內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue.js設(shè)計(jì)與實(shí)現(xiàn)無(wú)限遞歸學(xué)習(xí)總結(jié)
這篇文章主要為大家介紹了Vue.js設(shè)計(jì)與實(shí)現(xiàn)無(wú)限遞歸學(xué)習(xí)總結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05詳解利用eventemitter2實(shí)現(xiàn)Vue組件通信
這篇文章主要介紹了詳解利用eventemitter2實(shí)現(xiàn)Vue組件通信,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11uniapp使用scroll-view下拉刷新無(wú)法取消的坑及解決
這篇文章主要介紹了uniapp使用scroll-view下拉刷新無(wú)法取消的坑及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-05-05Vue如何處理Axios多次請(qǐng)求數(shù)據(jù)顯示問(wèn)題
這篇文章主要介紹了Vue如何處理Axios多次請(qǐng)求數(shù)據(jù)顯示問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01詳解vue過(guò)度效果與動(dòng)畫(huà)transition使用示例
Vue 在插入、更新或者移除 DOM 時(shí),提供多種不同方式的應(yīng)用過(guò)渡效果,Vue 提供了內(nèi)置的過(guò)渡封裝組件transition,該組件用于包裹要實(shí)現(xiàn)過(guò)渡效果的組件2021-10-10Vue基礎(chǔ)之MVVM,模板語(yǔ)法和數(shù)據(jù)綁定
這篇文章主要為大家介紹了Vue之MVVM,模板語(yǔ)法和數(shù)據(jù)綁定,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2021-12-12在vite項(xiàng)目中使用@進(jìn)行文件的引入方式
這篇文章主要介紹了在vite項(xiàng)目中使用@進(jìn)行文件的引入方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03關(guān)于Vue新搭檔TypeScript快速入門(mén)實(shí)踐
這篇文章主要介紹了關(guān)于Vue新搭檔TypeScript快速入門(mén)實(shí)踐,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09