在对质量要求高的场景下,进行通话前检测可以帮助提前识别并排查问题,保证实时通信体验。通话前检测通常可以从如下两个角度开展:
声网 SDK 提供了完备的网络探测及设备检测接口,帮助你实现如上功能,保证用户的使用体验。本文介绍如何使用相关 API 实现上述功能。
声网在 GitHub 提供了一个开源的 API-Examples iOS 示例项目,其中的 PrecallTest.swift 文件中实现了通话前检测功能。你可以直接下载体验或查看其中的源代码。
从 v2.4.0 起,声网 RTC Native SDK 提供了一个 startLastmileProbeTest
方法,支持用户在加入频道前进行网络质量探测,然后通过回调将当前网络质量的相关数据,包括往返时延、上下行丢包率、上下行网络带宽等返回给 app。
开始前请确保已在项目中实现了基本的音视频通信或直播功能。
参考如下步骤了解相关 API 的工作原理。
startLastmileProbeTest
进行网络质量探测。调用该方法时,你需要指定期望的最大上下行码率。lastmileQuality
:约两秒内返回,且每两秒触发一次。该回调通过打分反馈上下行网络质量,更贴近主观感受。lastmileProbeResult
:约 30 秒内返回。该回调通过客观数据反馈上下行网络质量,更客观。stopLastmileProbeTest
停止通话前网络质量探测。各 API 的调用时序如下图所示:
你可以参考如下示例代码实现网络质量探测功能。
// Swift
let config = AgoraLastmileProbeConfig()
// 确认进行上行网络探测
config.probeUplink = true;
// 确认进行下行网络探测
config.probeDownlink = true;
// 期望的最大上行码率,单位为 bps,取值范围 [100000,5000000]
config.expectedUplinkBitrate = 100000;
// 期望的最大下行码率,单位为 bps,取值范围 [100000,5000000]
config.expectedDownlinkBitrate = 100000;
// 调用 startLastmileProbeTest 开启网络探测
agoraKit.startLastmileProbeTest(config)
// Swift
// 调用 startLastmileProbeTest 后 2 秒内,收到 lastmileQuality 回调,了解上下行网络质量。该回调每 2 秒触发一次
func rtcEngine(_ engine: AgoraRtcEngineKit, lastmileQuality quality: AgoraNetworkQuality) {
lastmileResultLabel.text = "Quality: \(quality.description())"
}
// 调用 startLastmileProbeTest 后 30 秒内,收到 lastmileProbeResult 回调,了解更细节的网络数据
func rtcEngine(_ engine: AgoraRtcEngineKit, lastmileProbeTest result: AgoraLastmileProbeResult) {
// 往返时延
let rtt = "Rtt: \(result.rtt)ms"
// 下行带宽
let downlinkBandWidth = "DownlinkAvailableBandwidth: \(result.downlinkReport.availableBandwidth)Kbps"
// 下行网络抖动
let downlinkJitter = "DownlinkJitter: \(result.downlinkReport.jitter)ms"
// 下行网络丢包率
let downlinkLoss = "DownlinkLoss: \(result.downlinkReport.packetLossRate)%"
// 上行带宽
let uplinkBandwidth = "UplinkAvailableBandwidth: \(result.uplinkReport.availableBandwidth)Kbps"
// 上行网络抖动
let uplinkJitter = "UplinkJitter: \(result.uplinkReport.jitter)ms"
// 上行网络丢包率
let uplinkLoss = "UplinkLoss: \(result.uplinkReport.packetLossRate)%"
// 在 lastmileProbeTest 回调中获取网络探测结果数据
lastmileProbResultLabel.text = [rtt, downlinkBandwidth, downlinkJitter, downlinkLoss, uplinkBandwidth, uplinkJitter, uplinkLoss].joined(separator: "\n")
}
// Swift
// 获取网络探测数据后停止探测。
// 可以选择在 lastmileProbeResult 回调内部结束测试,也可以在其他时候结束测试。结束测试前,声网建议不要调用其他方法
agoraKit.stopLastmileProbeTest()
从 v2.4.0 起,声网 RTC Native SDK 通过一个 startEchoTestWithInterval
方法,支持用户在加入频道前,启动音频通话回路测试。该测试的目的是测试系统的音频设备(耳麦、扬声器等)和网络连接是否正常。
开始前请确保已在项目中实现了基本的音视频通信或直播功能。详见开始音视频通话或开始互动直播。
参考如下步骤了解相关 API 的工作原理。
startEchoTestWithInterval
方法。调用该方法时,你需要设置一个 interval
参数,表示获取本次测试结果的间隔时间。该参数单位为秒,取值范围为 [2,10],默认值为 10。startEchoTestWithInterval
方法后,引导用户先说一段话,如果声音在设置的时间间隔后回放出来,且用户能听到自己刚才说的话,则表示系统音频设备和网络连接都是正常的。stopEchoTest
方法停止语音通话检测,然后你可以调用 joinChannelByToken
加入频道。你可以参考如下示例代码实现音频通话回路检测功能。
// Swift
@IBAction func doEchoTest(sender: UIButton) {
agoraKit.startEchoTest(withInterval: 10, successBlock: nil)
showPopover(isValidate: false, seconds: 10) {[unowned self] in
self.showPopover(isValidate: true, seconds: 10) {[unowned self] in
self.agoraKit.stopEchoTest()
}
}
}
从 v3.5.2 起,声网 RTC Native 通过 startEchoTestWithConfig
方法,支持用户在加入频道前启动音视频通话回路测试。该测试的目的是测试系统的音频设备、视频设备、网络连接是否正常。
开始前请确保已在项目中实现了基本的音视频通信或直播功能。详见开始音视频通话或开始互动直播。
参考如下步骤了解相关 API 的工作原理。
startEchoTestWithConfig
方法。调用该方法时,你需要设置 config
参数。startEchoTestWithConfig
方法后,引导用户发出声音或面对摄像头。如果音频设备和网络连接正常,音频会在约 2 秒后播放出来;如果视频设备和网络连接正常,视频会在约 2 秒后播放出来。stopEchoTest
方法停止检测,然后你可以调用 joinChannelByToken
加入频道。// Swift
@IBAction func doEchoVideoTest(sender: UIButton) {
if(echoTesting){
agoraKit.stopEchoTest()
echoTestBtn.title = "Start Video/Audio Test".localized
echoTesting = false
}
else{
let config = AgoraEchoTestConfiguration()
echoTestBtn.title = "Stop Video/Audio Test".localized
config.channelId = "randomChannel"
config.view = self.preview
config.enableAudio = true
config.enableVideo = true
agoraKit.startEchoTest(withConfig: config)
echoTesting = true
}
}
startLastmileProbeTest
进行通话前网络质量探测时,会消耗一定的网络流量。因此调用方法后,声网建议在收到 lastmileProbeResult
回调之前不要调用其他方法,避免因 API 操作过于频繁导致其他方法无法执行。lastmileQuality
回调第一次报告的结果有一定概率是 Unknown
,可通过之后的几次回调获得结果。startEchoTestWithInterval
。startEchoTestWithInterval
开始通话测试后,必须调用对应的 stop
方法以结束测试,否则无法进行下一次测试,也不能加入频道。