博客
关于我
腾讯TcPlayer listener函数监听
阅读量:126 次
发布时间:2019-02-26

本文共 1009 字,大约阅读时间需要 3 分钟。

触发条件

从指定的直播地址进行拉流

使用腾讯云的TcPlayer播放器

在网站允许flash的情况下,如果指定的直播地址提供了flv格式的流源,则优先使用flash播放器

播放器被隐藏(display:none)

问题描述

使用腾讯云的TcPlayer从指定的直播地址拉流时,可以在初始化播放器时设置一个listener方法,用于监听流的拉取状态

在刚开始时播放器会被设置为display:none隐藏起来,原因是需要先展示一个未开始播放的状态,待拉取流成功后再进行播放器的展示

此时(播放器被隐藏)的情况下,如果采用h5的video播放方式的m3u8流,能够正常地通过listener函数监听到流的状态

但如果使用flv格式的流源进行播放,由于flash技术的特性,listener函数将无法接收到流的状态信息,必须移除display:none才可以正常监听

listener函数的实现代码示例:listener: function (msg) {    if (msg.type == 'error') {        console.log(msg, '播放报错');        _this.$emit('update-stream-state', 3);        //尝试5次拉流        if (_this.player) {            timer = setTimeout(() => {                _this.player && _this.player.load();                console.log('重试拉流');            }, 5000);            setInterval(() => {                clearTimeout(timer);            }, 25000);        }    } else if (msg.type == 'play') {        console.log(msg, '拉流成功');        //清除拉流的定时器        clearTimeout(timer);        _this.$emit('update-stream-state', 1);    }}

转载地址:http://izof.baihongyu.com/

你可能感兴趣的文章
ORA-00932: inconsistent datatypes: expected - got NCLOB【ORA-00932: 数据类型不一致: 应为 -, 但却获得 NCLOB 】【解决办法】
查看>>
ORA-00942 表或视图不存在
查看>>
ORA-01034: ORACLE not available
查看>>
ORA-01152: 文件 1 没有从过旧的备份中还原
查看>>
ORA-01207:文件比控制文件更新 - 旧的控制文件
查看>>
ORA-01795: 列表中的最大表达式数为 1000
查看>>
ORA-06575: 程序包或函数 NO_VM_DROP_PROC 处于无效状态
查看>>
ORA-08102的错误
查看>>
ORA-12505, TNS:listener does not currently know of SID given in connect descriptor异常
查看>>
ora-12541:tns:no listener
查看>>
【docker知识】联合文件系统(unionFS)原理
查看>>
ORACEL学习--理解over()函数
查看>>
oracle 10g crs命令,Oracle 10g CRS安装问题解决一例
查看>>
oracle 10g的安装配置
查看>>
Oracle 11.2.0.4 x64 RAC修改public/private/vip/scan地址
查看>>
Oracle 11G INDEX FULL SCAN 和 INDEX FAST FULL SCAN 对比分析
查看>>
Oracle 11g UNDO表空间备份增强
查看>>
Oracle 11g 使用RMAN备份数据库
查看>>
Oracle 11g 单实例安装文档
查看>>
Oracle 11g 操作ASM权限问题
查看>>