- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
问:视频播放卡死是什么原因?
我正在使用 Safari。
我有一个比特率相当高的视频文件:
10596496 位/秒
我怀疑比特率在整个视频持续时间(4 分 7 秒)内变化很大。
正在使用的 mime 类型编解码器字符串是:
"video/mp4; codecs=\"avc1.4d0028, mp4a.40.2\""
我的问题是,当在文件的某些区域寻找或启动流时,会导致 html5 视频播放器无限期停止。
我使用的服务器将文件作为实时流而不是范围字节请求提供。
注意:这意味着当在文件中搜索到某个时间时,将启动一个新的直播流(我拆除旧的媒体源扩展对象及其源缓冲区)我创建一个新的媒体源对象然后添加使用相同 mime 类型编解码器字符串的新源缓冲区。基本上,搜索就像开始一个新的回放 session 。
我已尝试确保在最后一个视频文件 block 附加到源缓冲区后关闭媒体源。
我试过清空视频播放器,然后在搜索时每次发出新请求之前和之后重新加载它:
videoPlayer = document.getElementsByTagName('video')[0];
videoPlayer.src = '';
videoPlayer.load();
videoPlayer.src = URL.createObjectURL(myMediaSource);
videoPlayer.load();
我在记录所有事件的本地 html5 视频播放器上添加了事件监听器。
如果我任意寻找文件中已成功播放的点,我会看到以下控制台日志:
[Log] EMPTIED (bundle.js, line 7131)
[Log] PLAY (bundle.js, line 7131)
[Log] WAITING (bundle.js, line 7131)
[Log] LOADSTART (bundle.js, line 7131)
[Log] LOADEDMETADATA (bundle.js, line 7131)
[Log] LOADEDDATA (bundle.js, line 7131)
[Log] CANPLAY (bundle.js, line 7131)
[Log] PLAYING (bundle.js, line 7131)
[Log] CANPLAYTHROUGH (bundle.js, line 7131)
[Log] PROGRESS (bundle.js, line 7131)
[Log] PROGRESS (bundle.js, line 7131)
[Log] RESULT.DONE (bundle.js, line 75634)
[Log] PROGRESS (bundle.js, line 7131)
[Log] STALLED (bundle.js, line 7131)
如果我任意查找文件中的某个点但未成功开始播放,我会看到以下控制台日志:
[Log] EMPTIED (bundle.js, line 7131)
[Log] PLAY (bundle.js, line 7131)
[Log] WAITING (bundle.js, line 7131)
[Log] LOADSTART (bundle.js, line 7131)
[Log] LOADEDMETADATA (bundle.js, line 7131)
[Log] PROGRESS (bundle.js, line 7131)
[Log] RESULT.DONE (bundle.js, line 75634)
[Log] PROGRESS (bundle.js, line 7131)
[Log] STALLED (bundle.js, line 7131)
我可以在网络选项卡中看到,在每次搜索时,向后端发出的提取请求确实接收到数据(最多 100 MB - 我将其限制在 100 MB 以内停止,以便源缓冲区不会运行内存不足)。正如您从日志中看到的那样,html5 视频播放器确实识别出正在接收数据,但在某些情况下,它认为它没有足够的数据来开始播放。
此外,我可以看到视频播放器在发出进度事件后正在缓冲视频的很大一部分,但它仍然卡住:
videoPlayer.buffered.end(0)
145.22842222222224
是什么导致视频播放无限期卡住?
最佳答案
我相信我已经找到了原因和可行的解决方法。
正如我在播放器无限期挂起而不开始播放的情况下提到的,videoPlayer.buffered.end(0) 调用将返回一些合理的值,例如 145.22842222222224。然而,在这些情况下,缓冲开始时间似乎始终设置为 0.08342222222222222。
所以我们有:
videoPlayer.buffered.start(0) // returns 0.08342222222222222
videoPlayer.buffered.end(0) // returns 145.22842222222224
videoPlayer.currentTime // returns 0
这会诱使 safari 视频播放器相信它没有足够的数据来开始播放,因为视频播放器的当前时间不在缓冲的开始和缓冲的结束时间范围内。我可以通过将视频播放器的当前时间设置为该范围内的某个时间来解决此问题,例如:
videoPlayer.currentTime = 0.9;
videoPlayer.play();
这实际上足以解决我的问题并允许开始播放视频。
关于javascript - 使用 Media Source Extension API 发出开始播放高可变比特率视频的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57209995/
我有一个问题,我想通过其他程序打开 chrome://extensions/页面,例如 cmd.exe 或其他程序。 我们知道,如果我们用chrome.exe打开一个网站,我们可以在cmd.exe中执
当您编写manifest.json 文件时,您必须为内容脚本指定匹配。 http 和 https 工作正常,但如果我尝试包含 chrome://*/* 或其任何变体,我会得到一个我尝试对我的匹配使用无
我真的很困惑我想制作一个可以扩展用户的Google日历的Chrome扩展程序,我应该在Google API下注册哪种程序? 它是Web App吗?但是我不打算让服务器托管任何东西,因为Chrome扩展
我想在带有chrome-extension://URL的iframe上运行内容脚本。我在我的manifest.json文件中添加了一行代码,该行是从http://code.google.com/chr
目前,我正在使用记事本和 chrome 控制台的组合对我的 google-chrome-extensions 进行编码。我 100% 确信有更好的方法来对这些扩展进行编程。人们使用什么环境? 最佳答案
在编写 manifest.json 文件时,必须指定 matches用于您的内容脚本。 http和 https工作正常,但如果我尝试包含 chrome://*/*或它的任何变体,我收到一个错误,提示我
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 7 年前。 Improve
在发布更新后,我正在尝试为我的 Chrome 扩展程序的用户创造流畅的体验。 我在更新应用程序时重新注入(inject)了我的内容脚本,即使用户继续在扩展更新后未刷新的页面上使用我的扩展,我的功能仍然
将扩展程序从 Chrome 移植到 FF 遵循本教程(在 Chrome 中运行良好):http://www.codingscripts.com/check-whether-user-has-a-chr
我正在将 google-chrome 扩展改编成 firefox。 这个扩展相当简单,它只是重新加载当前浏览器窗口并在其中放置一个特定的字符串(它用于在 Odoo 上激活调试状态)。 但是,当我在 m
我正在尝试在普通 HTML 页面(非扩展)中链接到 chrome://extensions。但是单击链接不会执行任何操作: chrome://extensions 右键单击并在新选项卡中打开只会打开
为 String 编写扩展名很容易,但问题是它总是显示为 "MyString".ExtensionMethod() 如果这样写: public static class Extensions{
如题。我正在运行 Joomla 2.5。 “扩展”下拉菜单中唯一可见的项目是: 模块经理 插件管理器 模板管理器 语言经理 编辑:我这样做是为了安装模板,按照此页面上的说明:http://docs.j
基本上我希望文件名以扩展名列表中的扩展名结尾。这是我在 python 中的代码。我已经将一些示例文件名作为列表,如下所示: extensions = ['.mp3','.m4a','.wma'] fi
在 background.html : chrome.tabs.query({active:true, currentWindow:true},function(tabs){ chrome.tab
我有一个可能被用户禁用的 chrome 扩展。在这种情况下,我想创建一个指向 chrome://extensions 菜单的链接。它会是这样的 Chrome extensions 这是不允许的:不允许
我查看了 Google 文档,但不知道如何更改其类型。 这是我加载时遇到的错误。 尝试安装此扩展时出现警告:“browser_action”仅允许用于扩展程序,这是一个旧版打包应用程序。 这是我的ma
我有一个正在构建的 chrome 扩展,它使用 OAuth 访问许多 API。我没有将我的消费者 secret 存储在扩展程序中,而是重定向到获取 token 的服务器,然后重定向回我的扩展程序中的页
我有一个正在构建的 chrome 扩展,它使用 OAuth 访问许多 API。我没有将我的消费者 secret 存储在扩展程序中,而是重定向到获取 token 的服务器,然后重定向回我的扩展程序中的页
这个问题已经有答案了: Why would a developer place a forward slash at the start of each relative path? (4 个回答)
我是一名优秀的程序员,十分优秀!