- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个 Android 应用程序,可以通过 Google Cast 从网络(主要是 icecast)播放直播流。一切都运行良好且快速,但现在某些流开始(发出声音)需要更长的时间。这可能与 Chromecast 固件升级有某种关系,因为我的 Chromecast 设备最近已更新到最新版本 (1.32.124602)。
这是我通过 Cast 播放流媒体的方式:
MediaMetadata metadata = new MediaMetadata(MediaMetadata.MEDIA_TYPE_GENERIC);
metadata.putString(MediaMetadata.KEY_TITLE, "My title");
metadata.putString(MediaMetadata.KEY_SUBTITLE, "My subtitle");
metadata.addImage(new WebImage(myImageUri);
MediaInfo mediaInfo = new MediaInfo.Builder(streamUrl)
.setStreamType(MediaInfo.STREAM_TYPE_LIVE)
.setContentType("audio/mpeg")
.setMetadata(metadata)
.build();
MediaLoadOptions options = new MediaLoadOptions.Builder()
.setAutoplay(true)
.setPlayPosition(0)
.build();
sessionManager.getCurrentCastSession().getRemoteMediaClient().load(mediaInfo, options);
奇怪的是,有些流非常快,而有些则不是:
我还注意到,对于第二个流,load() 函数的 ResultCallback 几乎是立即触发的,而第一个大约需要 3 秒。
我很感激任何帮助或想法如何解决这个问题。
最佳答案
第二个链接有一个更大的缓冲区来刷新给你。
此图显示吞吐量。第一个问题是我在 stream.funradio.sk:8000
上测试第一个 URL 时。第二个问题是我在 stream.expres.sk:8000
上测试第二个 URL 时。
您会注意到,在两者中,连接开始时都会出现大量数据。这些旨在尽快填充播放器缓冲区,以立即开始播放。您还会注意到第二个流在连接开始时有更多这样的内容。这是因为它有一个准备就绪的音频数据缓冲区。
每个流的缓冲区大小是可配置的。配置第二个流的人们认为可以增加此缓冲区,从而使听众能够快速启动,这已被发现对于留住听众至关重要。这里唯一真正的权衡是延迟。第二个流有效地预先录制了几秒钟的音频以发送给新客户。对于大多数互联网广播电台来说,这种延迟根本不是问题。让该流快速启动要好得多,并且对于连接不稳定的听众来说更可靠。
I appreciate any help or idea how to fix this.
除了代理流之外,您无能为力。 Android 设备和 Chromecast 对 MP3 流特别挑剔,需要大量数据才能与其同步。
此外,Chrome 用于确定缓冲区是否足够满以在不停止的情况下播放的算法不知道您正在为其提供 radio 流,并且会在开始之前看到速率下降和缓冲区更多。这个问题可以通过完全编码你自己的播放器来解决,缓冲数据然后将它传递给解码器,而不是仅仅给底层系统一个 URL。在网络上,这可以通过媒体源扩展来完成。对于 Android,我没有太多经验。
关于android - 某些流的 Google Cast 速度慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52504992/
我的应用程序中有以下查询: SELECT a.*, f.* FROM flights_database f JOIN airports a ON f.airport = a.airportNameCl
我们在使用 MySQL(以及 MariaDB)时遇到了一个奇怪的问题。一个简单的数据库,有 2 个表(InnoDB 引擎),都包含(以及其他一些)3 或 4 个带有 XML 数据的文本列。大小为 1-
我在 MySQL 上的执行路径上遇到问题,导致查询缓慢且不一致。这是一个全新的现象。我们还有其他具有完全相同(好吧,尽可能接近)设置的表,这很好,但出于某种原因,现在创建新表会遇到这个缓慢/不一致的问
我使用 Eclipse Marketplace 的下载速度始终非常慢(现在从 http://download.eclipse.org 开始,下载速度为 3 MB/s,下载速度为 25 kB/s),这使
我正在开发一个 Qt Creator 项目,其中包含大量头文件(点云库、Boost 等)。例如。 Boost 有大约 9000 个头文件。现在看来,包含的数量确实减慢了 IDE。代码完成很慢,大约。
我在一个项目中使用 document.elementFromPoint,它看起来很慢。 100,000 次迭代需要 7051 毫秒。 document.getElementsByTagName("*"
我有一个 tableView ,每行有四个图表,大约 20 行。当我尝试滚动表格时,我将删除现有图表并为每一行构建新图表。 此操作使 TableView 的滚动非常慢。任何使滚动速度更快以及加载新图表
我有一个如下所示的数据框: date,time,metric_x 2016-02-27,00:00:28.0000000,31 2016-02-27,00:01:19.0000000,40 2016-
TLDR:我的微调器瞬间显示了错误的颜色。 我的微调器有问题。每当我运行应用程序时,如果 Activity 没有缓存在内存中,它有时会滞后。在我可以将其设置为正确的颜色之前,文本是默认颜色(如黑色)。
我在使用 SELECT COUNT(*) 对大型表进行 SQLite 时遇到性能问题。 由于我还没有收到可用的答案并且我做了一些进一步的测试,所以我编辑了我的问题以纳入我的新发现。 我有 2 个表:
当音频因加载数据不足(速度慢)而暂停时,我可以使用什么事件? 就像: $audio.on('suspendToLoading',function(){ alert('loading...');
这是我的 MATLAB 程序的分析模拟运行结果。我需要运行此模拟数十万次(约 100,000 次)。 因此我需要一种更快的方法来读取 Excel 文件。 规范:Excel 文件由 10000x2 个单
每当与数据透视表交互时,Excel 都非常慢,这让我感到非常困难。添加/删除字段、更改过滤器或切片器,所有这些都需要 Excel 卡住几分钟才能响应。 看来生成的 MDX 效率极低。我可以理解他们必须
我正在使用 Entity Framework 来检索大型数据集。 数据集有parent/child关系,我需要和parent同时带回child信息。 我发现 EF 最初发送一个查询以获取父对象列表,然
我有一个使用 gridview 的应用程序,它非常慢。 添加 Trace=true 后对于页面,我追踪了时间花费的地方:在 GridView 上调用 BindData() 时。 GridView连接到
我编写了一个小代码来使用 QtCreator 测试 QGraphicsView 的功能。 代码非常简单,只是创建了一个继承自 QGraphicsView 的类,上面有一个 QGraphicsScene
后期以补充作品的形式自动加入成员(member)。数据库速度较慢。有没有办法加快这个速度?用户无所谓..除了自动补码之外如何停止写?(自动补码;城市输入。成员(member)表格位于。) 注册.php
我有一个文件 (insert.sql),其中有 250k 行,没有键,没有索引: INSERT `project_383`.`entity_metrics_build_1` VALUES ('d402
我最近开发了一个应用程序(java 8、spring-boot、hibernate、maven),它通过 REST API 公开数据库。我遇到的问题是数据库调用很慢(3000 毫秒以上),只是为了获取
我正在尝试在 Canvas 上使用旋转,我现在有了它,因此每个对象都有自己的旋转。如果没有它们旋转,我可以在一台非常低端的计算机上在屏幕上显示大约 400 个对象,在一台正常库存的计算机上显示近 20
我是一名优秀的程序员,十分优秀!