前端页面播放 rtmp 流与 flv 格式视频文件

Posted anjjie

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了前端页面播放 rtmp 流与 flv 格式视频文件相关的知识,希望对你有一定的参考价值。

技术 :angular/cli , html5 , typescript , scss ,es 6 ...

项目类型:直播视频与视频回放

使用到 插件 : videojs + ckplayer

遇到的问题:

  1. 一开始使用 flv.js 插件播放flv格式类型,遇到的问题 40M 以下可以播放出来,超过一定视频文件大小就会出现异常。

  解决方案:使用 ckplayer 插件代替flv插件

  ckplayer 使用方法:

技术分享图片
1         var videoObject = {
2             container: ‘#name‘ , //容器的ID或className
3             variable: ‘player‘,//播放函数名称
4             flashplayer: true,
5             video: [//视频地址列表形式
6                 ["url链接", ‘video/flv‘, ‘中文标清‘, 0]
7             ]
8         };
9         var player = new ckplayer(videoObject);
ckplayer

  flv.js 使用方法:

技术分享图片
1 if (flvjs.isSupported()) {
2             const flvPlayer = flvjs.createPlayer({
3                 type: "flv",
4                 url: url
5             });
6             flvPlayer.attachMediaElement(videoElement);//videoElement:h5 video 元素
7             flvPlayer.load();
8             flvPlayer.play();
9     }
flv.js

  2.videojs 在创建播放器的时候每次都要实例化并且加载新的播放器,不然播放会没有效果;

  使用方法:

技术分享图片
 1 html:
 2 <video id="{{ obj }}" class="video video-js vjs-big-play-centered" preload="auto" data-setup="{}" autoplay controls="controls">
 3           <source [src]="safeUrl" type=‘rtmp/flv‘>
 4         </video>
 5 
 6 -----------------------------------------------------------------------------------------
 7 实例化:
 8 var videos = document.getElementsByTagName(‘video‘);//获取所有的h5元素 video 
 9         for (i = 0; i < videos.length; i++) {
10           var video = videos[i];
11           if (video.className.indexOf(‘video-js‘) > -1) {
12             videojs(video.id).ready(function () {//实例化播放器
13             });
14           }
15         }
16 
17 -----------------------------------------------------------------------------------------
18 单击更换播放链接:
19 var _video = videojs("video_index_1");
20             _video.src(url);
21             _video.play();
videojs

 

欢迎各位前辈评论指教!!!

  

以上是关于前端页面播放 rtmp 流与 flv 格式视频文件的主要内容,如果未能解决你的问题,请参考以下文章

13 rtsp视频服务 基于node+ffmpeg 转换为 flv 视频服务

13 rtsp视频服务 基于node+ffmpeg 转换为 flv 视频服务

直播视频和m3u8格式flv格式

JavaCV音视频开发宝典:使用JavaCV和springBoot实现websocket-flv直播服务,无需流媒体服务,浏览器网页flv.js播放器直接播放rtsp,rtmp等实时视频

JavaCV音视频开发宝典:使用JavaCV和springBoot实现websocket-flv直播服务,无需流媒体服务,浏览器网页flv.js播放器直接播放rtsp,rtmp等实时视频

JavaCV音视频开发宝典:使用JavaCV和springBoot实现websocket-flv直播服务,无需流媒体服务,浏览器网页flv.js播放器直接播放rtsp,rtmp等实时视频