直播平台源码实现播放视频的方法
我们在直播平台中上传视频的时候往往会不知道自己上传的是什么格式的视频,在APP软件播放的时候有时可能会播放不出来,这时候我们就会专门按照该视频的格式进行播放,顺利的将视频展示出来,下面就给大家讲解下直播平台源码实现m3u8、flv、mp4视频播放的方法。
一、直播平台源码中播放m3u8格式视频
1、安装依赖
1 2 | npm install video.js --save // 视频播放器插件 npm install videojs-contrib-hls --save // 播放hls流插件 |
2、页面引入插件
1 2 | import videojs from "video.js" ; import "video.js/dist/video-js.css" ; |
3、页面中的使用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 | <template> <div> <video id= "videoPlayer" class = "video-js vjs-default-skin" controls playsinline autoplay= "autoplay" width= "500px" > <source :src= "attachmentLink" type= "application/x-mpegURL" /> </video> </div> </template> <script> import videojs from "video.js" ; import "video.js/dist/video-js.css" ; export default { data() { return { dp: null , options: { playbackRates: [ 0.7 , 1.0 , 1.5 , 2.0 ], //播放速度 aspectRatio: '16:9' , notSupportedMessage: '此视频暂无法播放,请稍后再试' , //允许覆盖Video.js无法播放媒体源时显示的默认信息。 autoplay: false , // 设置自动播放 muted: true , // 设置了它为true,才可实现自动播放,同时视频也被静音(Chrome66及以上版本,禁止音视频的自动播放) preload: "auto" , // 预加载 controls: true , // 显示播放的控件 }, attachmentLink: "https://e-sign.dms.t.cn-np.com/files/m3u8_file/c4b94118-3c8d-4410-9987-985c2b44c278/c4b94118-3c8d-4410-9987-985c2b44c278.m3u8" , }; }, mounted() { // 使用 $nextTick 解决vedio报错 The element or ID supplied is not valid. (videojs) this .$nextTick(() => { this .loadVideo(); }); }, methods: { loadVideo() { this .dp = videojs( "videoPlayer" , this .options); // 也可以使用以下方式给vedio设置 src // this.db.src([ // { // src: "https://e-sign.dms.t.cn-np.com/files/m3u8_file/c4b94118-3c8d-4410-9987-985c2b44c278/c4b94118-3c8d-4410-9987-985c2b44c278.m3u8", // 地址 // type: "application/x-mpegURL", // 告诉videojs,这是一个hls流 // }, // ]); }, // 销毁 beforeDestroy() { if ( this .dp) { this .dp.dispose(); // dispose()会直接删除Dom元素 } }, }, }; </script> <style scoped> .video-box { width: 100 %; max-width: 500px; max-height: 500px; } // 暂停播放按钮居中 ::v-deep .video-js .vjs-big-play-button { top: 50 %; left: 50 %; transform: translate(- 50 %, - 50 %); } </style> |
二、直播平台源码中flv格式的方案来播放视频
简介:flv.js是 HTML5 Flash 视频(FLV)播放器,纯原生 JavaScript 开发,没有用到 Flash。由 bilibili 网站开源。
开源地址: https://github.com/Bilibili/flv.js/
1、安装依赖
1 | npm install --save flv.js |
2、页面引入插件
1 | import flvjs from 'flv.js' |
3、页面中的使用
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 | <template> <div> <div> <video id= "videoElement" crossOrigin= "anonymous" controls autoplay muted width= "100%" height= "800px" ></video> </div> </div> </template> <script> import flvjs from 'flv.js' export default { data() { return { isPlay: false , player: null , }; }, methods: { // 设置视频配置(注意:createVideo应放在异步函数里或mounted之后,不可在created里直接加载,否则不生效) createVideo() { if (flvjs.isSupported()) { var videoElement = document.getElementById( 'videoElement' ); this .player= flvjs.createPlayer({ type: 'flv' , isLive: true , hasAudio: false , url: 'https://sf1-hscdn-tos.pstatp.com/obj/media-fe/xgplayer_doc_video/flv/xgplayer-demo-360p.flv' // 自己的flv视频流 },{ cors: true , // 是否跨域 // enableWorker: true, // 是否多线程工作 enableStashBuffer: false , // 是否启用缓存 stashInitialSize: 128 , // 缓存大小(kb) 默认384kb autoCleanupSourceBuffer: true // 是否自动清理缓存 }); this .player.attachMediaElement(videoElement); //挂载元素 this .player.load(); //加载流 this .player.play(); //播放流 } // 报错重连 this .player.on(flvjs.Events.ERROR, (err, errdet) => { // 参数 err 是一级异常,errdet 是二级异常 if (err == flvjs.ErrorTypes.MEDIA_ERROR) { console.log( '媒体错误' ) if (errdet == flvjs.ErrorDetails.MEDIA_FORMAT_UNSUPPORTED) { console.log( '媒体格式不支持' ) } } if (err == flvjs.ErrorTypes.NETWORK_ERROR) { console.log( '网络错误' ) if (errdet == flvjs.ErrorDetails.NETWORK_STATUS_CODE_INVALID) { console.log( 'http状态码异常' ) } } if (err == flvjs.ErrorTypes.OTHER_ERROR) { console.log( '其他异常:' , errdet) } if ( this .player) { this .destoryVideo() this .createVideo() } }) }, destoryVideo(){ if ( this .player) { this .player.pause(); // 暂停播放数据流 this .player.unload(); // 取消数据流加载 this .player.detachMediaElement(); // 将播放实例从节点中取出 this .player.destroy(); // 销毁播放实例 this .player= null ; } } }, mounted() { this .$nextTick(() => { this .createVideo() }) }, beforeDestroy() { this .destoryVideo() }, }; </script> <style scoped> </style> |
三、直播平台源码中mp4格式的方案来播放视频
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | <html> <head> <title>camera</title> <script type= "text/javascript" > function play() { var video = document.getElementById( "video" ); video.play(); } </script> </head> <body> <video id= "video" width= "640" height= "360" poster= "/video/cover.png" // 视频封面 controls //显示标准的 HTML5 视频/音频播放器控制条、控制按钮。 autoplay //让文件自动播放。 loop //让文件循环播放。 preload= "auto" //属性是用来缓存大体积文件的。它有三个可选值:"none" 不缓存、"auto" 缓存、"metadata" 只缓存文件元信息 playsinline= "true" // IOS微信浏览器支持小窗内播放 webkit-playsinline= "true" // 这个属性是ios 10中设置可以让视频在小窗内播放,也就是不是全屏播放*/ x5-video-player-type= "h5" // 启用H5播放器,是wechat安卓版特性 x5-video-player-fullscreen= "true" // 全屏设置,设置为 true 是防止横屏 x5-video-orientation= "portraint" // 播放器屏幕的方向,landscape横屏,portraint竖屏,默认值为竖屏。、、 οnclick= "play()" > <!-- 标签是为了能够兼容各种浏览器对不同媒体类型的支持,我们可以用多个<source></source>元素来提供多个不同的媒体类型。支持mp4格式视频流的浏览器可以播放mp4文件,如果不支持,可以播放Ogg文件。 --> <!-- codecs=dirac, speex - 是用来指定播放使用的解码器(codecs); 这样就可以更精确的让浏览器如何播放提供的视频。 --> <source src= "/video/text.mp4" type= "video/mp4" > <source src= "/video/text.ogg" type= "video/ogg; codecs=dirac, speex" > <div> <p>You must have an HTML5 capable browser.</p> </div> </video> </body> </html> |
在直播平台源码开发中使用上面的方式就可以对m3u8、flv、mp4这三种格式的视频进行播放了。
以上就是 直播平台源码实现播放视频的方法,更多内容欢迎关注之后的文章。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
2022-08-16 直播软件app开发,js判断文本框输入的是否是数字
2022-08-16 视频直播源码,Flutter实现一个自定义的弹窗
2022-08-16 直播系统搭建,点击显示或隐藏密码
2021-08-16 在小视频app源码中实现Camera预览旋转设置
2021-08-16 1对1直播源码实现录音和播放
2021-08-16 Kotlin实现一对一直播软件源码底部弹出的列表对话框