博客
关于我
腾讯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/

你可能感兴趣的文章
Netty源码—7.ByteBuf原理四
查看>>
Netty源码—8.编解码原理二
查看>>
Netty源码解读
查看>>
Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
查看>>
Netty相关
查看>>
Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
查看>>
Network Sniffer and Connection Analyzer
查看>>
NFS共享文件系统搭建
查看>>
ng 指令的自定义、使用
查看>>
nginx + etcd 动态负载均衡实践(二)—— 组件安装
查看>>
Nginx + uWSGI + Flask + Vhost
查看>>
Nginx Location配置总结
查看>>
Nginx 动静分离与负载均衡的实现
查看>>
Nginx 反向代理解决跨域问题
查看>>
Nginx 反向代理配置去除前缀
查看>>
nginx 后端获取真实ip
查看>>
Nginx 学习总结(17)—— 8 个免费开源 Nginx 管理系统,轻松管理 Nginx 站点配置
查看>>
nginx 常用配置记录
查看>>
Nginx 我们必须知道的那些事
查看>>
Nginx 的 proxy_pass 使用简介
查看>>