flv.js 直播_前端视频播放插件

flv.js 直播_前端视频播放插件关于使用flvjs文章目录关于使用flvjs1.创建2.事件处理3.踩到的坑1.创建HTML<videoid=”largeVideo”style=”width:100%;height:600px”class=”centeredVideo”controlsautoplaymutedwidth=”1015″

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

关于使用flvjs

1.创建

HTML

        <video id="largeVideo" style="width: 100%; height: 600px" class="centeredVideo" controls autoplay muted width="1015" height="576" >
          Your browser is too old which doesn't support HTML5 video.
        </video>

Jetbrains全家桶1年46,售后保障稳定

javascript

 let flvPlayerRef1 = document.getElementById("largeVideo");//获取创建dom
 let flvPlayerObjM1 = flvjs.createPlayer(
          { 
   
            type: "flv",
            isLive: true, //是否直播
            url: url, //地址
            hasAudio: true,
            hasVideo: true,
          },
          { 
   
            cors: true, // 是否跨域
            stashInitialSize: 384, // 缓存大小(kb) 默认384kb
            enableStashBuffer: true, // 是否启用缓存
            autoCleanupMaxBackwardDuration: 3 * 60,//自动清除缓存时间
            enableWorker: false, // 是否多线程工作
            autoCleanupSourceBuffer: true, // 是否自动清理缓存
            fixAudioTimestampGap: true,//音视频同步
          }
 flvPlayerObjM1.load(); //加载
 flvPlayerObjM1.play(); //播放

2.事件处理

flvjs.Events.STATISTICS_INFO 信息出错销毁直播

flvPlayerRef1.on(flvjs.Events.STATISTICS_INFO, function (res) { 
   
         	flvPlayerObjM1.pause();
            flvPlayerObjM1.unload();
            flvPlayerObjM1.detachMediaElement();
            flvPlayerObjM1.destroy();
            flvPlayerObjM1 = null;
});

flvjs.Events.ERROR 断流报错销毁

flvPlayerRef1.on(
          flvjs.Events.ERROR,
          (errorType, errorDetail, errorInfo) => { 
   
            console.log("errorType:", errorType);
            console.log("errorDetail:", errorDetail);
            console.log("errorInfo:", errorInfo);
            flvPlayerObjM1.pause();
            flvPlayerObjM1.unload();
            flvPlayerObjM1.detachMediaElement();
            flvPlayerObjM1.destroy();
            flvPlayerObjM1 = null;
          }
        );

flvjs.Events.VIDEO_FROZEN视频卡顿监听

flvPlayerRef1.on(
          flvjs.Events.VIDEO_FROZEN,
          (errorType, errorDetail, errorInfo) => { 
   
            console.log("errorType:", errorType);
            console.log("errorDetail:", errorDetail);
            console.log("errorInfo:", errorInfo);
            flvPlayerObjM1.pause();
            flvPlayerObjM1.unload();
            flvPlayerObjM1.detachMediaElement();
            flvPlayerObjM1.destroy();
            flvPlayerObjM1 = null;
          }
        );

将创建写入方法,在事件监听中调用可以实现断流重连,卡顿重连等问题

3.踩到的坑

当使用创建时,记住每次都需要销毁当前创建的直播流,是整个都需要销毁,不然很容易造成内存溢出,直接导致浏览器卡死,在断流重连和卡顿修复的时候尤其注意是否完全销毁这个直播组件!!!


新加
flv传入的url最好遵循同源策略,不要跨协议去请求。如果是用rtmp可以不考虑此处
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/234853.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Java strictfp[通俗易懂]

    Java strictfp[通俗易懂]Javastrictfp关键字的作用strictfp关键字可以应用于方法,类和接口。strictfp关键字的非法代码Javastrictfp关键字确保您将在每个平台上获得相同的结果,如果在浮点变量中执行操作。不同平台的精度可能不同,这就是为什么java编程语言提供了strictfp关键字,它用于在每个平台上获得相同的结果。所以,现在我们就可以更好的控制浮点数据类型运算了。strictf…

    2022年10月21日
    0
  • Jps命令—使用详解[通俗易懂]

    Jps命令—使用详解[通俗易懂]原文:https://blog.csdn.net/wisgood/article/details/38942449 jps是jdk提供的一个查看当前java进程的小工具,可以看做是JavaVirtualMachineProcessStatusTool的缩写。非常简单实用。    命令格式:jps[options][hostid]     [options…

    2022年9月20日
    0
  • 常用sql语句整理:mysql

    常用sql语句整理:mysql

    2021年10月10日
    48
  • VMWare14 安装Mac OS系统(操作图解)

    VMWare14 安装Mac OS系统(操作图解)近日恰逢双十一,瞅了瞅自己干瘪的钱包,没忍心入手期待已久的macPro,只好在虚拟机里玩一下mac好了,等以后钱包傲气的时候再来个真实的。安装环境:windows10VMWare14.2VMwareWorkstationPro14已安装或自行安装Unlocker(链接:https://pan.baid…

    2022年6月2日
    33
  • mysql datetime、date、time、timestamp区别

    mysql datetime、date、time、timestamp区别mysql datetime、date、time、timestamp区别

    2022年4月24日
    43
  • 0x0000007e_c0000005改兼容性没用

    0x0000007e_c0000005改兼容性没用对于怎么解决应用程序正常初始化0xc0000005失败这个问题,小编觉得是需要知道的,因为我们在生活中遇到类似这样的问题几率还是蛮大的。所以小伙伴们要接着往下看哟~接下来小编就来告诉你们怎么解决应用程序正常初始化0xc0000005失败的问题。有的时候刷网页刷到一半,就突然间出现应用程序正常初始化0xc0000005失败的窗口提示,但是这是怎么回事呢?又该怎么解决呢?稳住,接下来小编就来告诉你们怎…

    2022年10月3日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号