我正在使用 TokBox 构建一个视频 session 应用程序。我想向用户说明流的表现如何。我注意到 OTSubscriberKitNetworkStatsDelegate
可以让您查看订阅者丢失了多少音频和视频数据包。尚不清楚这是否表明您的连接或他们的连接的健康状况。我假设我可以使用这个委托(delegate)来查看我自己丢弃的数据包(作为发布者和订阅者)。这是为 TokBox 计算某种带宽指标的方法吗?
更新:
很好的答案,也很快!令人印象深刻的 OpenTok 社区。在这里结束,OTNetworkTest 很棒,实际上使用 OTSubscriberKitNetworkStatsDelegate
来计算流的质量,正如我所怀疑的那样。它的唯一问题是它被设计为在您开始 session 之前运行。我需要一个可以作为现有 session 的一部分运行的测试;因此,我将去掉计算部分并创建一个使用您自己的订阅者数据的此类版本。感谢所有帮助的人。
其实有几种方法。
粗略但简单地计算帧的大小并将其乘以帧速率(真实的,未指定),然后加上声音的 kbps。您应该对实际带宽有相当准确的了解。 对于帧速率计算,请阅读 Dynamic frame rate controls
我敢打赌,一个好的用户体验解决方案不是显示一切都很糟糕,而是调整流质量,仅在完全失败的情况下指示错误(就像 Skype 一样)。看看这个:
Starting with our 2.7.0 mobile SDK release, you can start a publisher with per-determined video resolution and frames per seconds (fps). Before using the API, you should be aware of the following:
- Though HD video sounds like a good idea at first, from a practical standpoint you may run into issues with device CPU load on low to medium range devices. You may also be limited by the user’s available bandwidth. Lastly, data charges for your users could run high.
- Available on the device. The actual empirical values for these parameters will vary based on the specific device. Your selection can be seen as a maximum for the resolution and frame rate you are willing to publish.
Automatically adjusted based on various parameters like a user’s packet loss, CPU utilization, and network bandwidth/bit-rate. Rather than attempting to do this dynamically on your own, we recommend picking meaningful values and allowing OpenTok to handle the fine tuning.
Bandwidth, set your publisher video type property to “screen” instead of the default “camera” value.
取自 here
所以,您应该这样做:
首先实现
协议(protocol)。它有一个方法叫做
- (void)subscriberOTSubscriberKit *)subscriber videoNetworkStatsUpdatedOTSubscriberKitVideoNetworkStats *)stats
如您所见,其中有一个 OTSubscriberKitVideoNetworkStats
对象传递给它。
接下来,您可以从该对象中提取三个属性:
@property (readonly) uint64_t videoPacketsLost
- 此订阅者丢失的估计视频数据包数。@property (readonly) uint64_t videoPacketsReceived
- 此订阅者收到的视频数据包数。@property (readonly) uint64_t videoBytesReceived
– 此订阅者接收到的视频字节数。@property (readonly) double timestamp
– 自 Unix 纪元以来的时间戳,以毫秒为单位,用于收集这些统计信息的时间。因此,请随意使用这些值并为您的应用实现最佳解决方案。
此外,他们还发表了一篇专门针对在电话 session 中管理不同带宽的文章。 Check it out .
在我写答案时,@JaideepShah 提到了一个惊人的例子。通读 this example 的解释.有一个表格表明我上面提到的正确值的正确分辨率。
关于ios - 我可以使用 TokBox OTSubscriberKitNetworkStatsDelegate 来计算带宽吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35803911/
欢迎光临 OGeek|极客世界-中国程序员成长平台 (https://ogeek.cn/) | Powered by Discuz! X3.4 |