javascript - 检测 HLS 音频播放事件

标签 javascript jquery nginx http-live-streaming

我正在使用 nginx 和 nginx rtmp 模块为移动设备创建音频流。对于视频,我使用 ffmpeg 将视频切片为 jpeg 图像,这样我就可以向移动用户显示视频流。音频分离导致音频延迟 15-30 秒。我假设发生这种情况是因为 jpeg 视频在音频缓冲区之前开始。所以我尝试的是捕获 <audio>事件“canplay”,当此事件触发时,开始视频预览。

音频源示例:http://example.com:8081/hls/audio.m3u8

检测代码:

 var audio = document.getElementById('preview-audio');
 audio.oncanplay=function(){ console.log('audio loaded'); };

但是这个事件永远不会触发。只有触发的事件是“loadstart”和“progress”。如何检测音频是否已缓冲,以便我可以将其与 jpeg 同步?

提前致谢

最佳答案

我相信您可以使用 oncanplaythrough 事件。

var audio = document.getElementById("preview-audio");
audio.oncanplaythrough = function() {
    console.log("Audio can be played.");
};

关于 oncanplaythrough 的更多信息 here .

关于javascript - 检测 HLS 音频播放事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35840786/

相关文章:

javascript - 在滴管插件 jquery 中删除图像预览

javascript - Three.js 相机旋转顺序

javascript - Angular JS绑定(bind)等待输入

javascript - 购物车 : Sum on drop event (JQuery)

javascript - tablesorter()jQuery函数,用于dd-MMM-yyyy格式

java - 具有基本 token 身份验证的 OkHttp 适用于 GET 但不适用于 DELETE

javascript - 如何使用 HTML5 Canvas 标签显示视频

jQuery 根据最近图像的宽度更改 div 的宽度?

node.js - PM2 正在运行额外的进程

通过 nginx 和 unicorn 访问 rails 应用程序时出现 Mysql2 错误