空间音频
clearRemotePositions:
enableSpatialAudio:
启用或关闭空间音效。
- (int)enableSpatialAudio:(BOOL)enabled NS_SWIFT_NAME(enableSpatialAudio(_:));
你可以在加入频道前或加入频道后调用该方法。启用空间音效后,可以调用 setRemoteUserSpatialAudioParams:params: 设置远端用户的空间音效参数。
- 该方法依赖空间音效动态库 AgoraSpatialAudioExtension.xcframework(iOS)或
AgoraSpatialAudioExtension.framework(macOS)。如果该动态库被删除,该功能将无法正常启用。
参数
- enabled
- 是否启用空间音效:
- YES:启用空间音效。
- NO:关闭空间音效。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
sharedLocalSpatialAudioWithConfig:
初始化 AgoraLocalSpatialAudioKit 实例。
+ (instancetype _Nonnull)sharedLocalSpatialAudioWithConfig:(AgoraLocalSpatialAudioConfig*)config NS_SWIFT_NAME(sharedLocalSpatialAudio(with:));
- 每个 App 仅支持创建一个 AgoraLocalSpatialAudioKit 实例。
参数
- config
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
muteAllRemoteAudioStreams:
停止或恢复订阅所有远端用户的音频流。
- (int)muteAllRemoteAudioStreams:(BOOL)mute NS_SWIFT_NAME(muteAllRemoteAudioStreams(_:));
调用该方法后,你将停止或恢复订阅所有远端用户的音频流,包括后续加入频道的用户。
- 请在调用
joinChannelByToken方法后再调用此方法。 - 使用空间音效时,如需设置是否停止订阅所有远端用户的音频流,声网建议调用此方法,而非 muteAllRemoteAudioStreams: 方法。
- 调用此方法后,你需要调用
updateSelfPosition和updateRemotePosition方法更新本地用户和远端用户的空间位置,否则该方法的设置不会生效。
参数
- mute
- 是否停止订阅所有远端用户的音频流:
- YES:停止订阅所有远端用户的音频流。
- NO:订阅所有远端用户的音频流。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
muteLocalAudioStream:
停止或恢复发布本地音频流。
- (int)muteLocalAudioStream:(BOOL)mute NS_SWIFT_NAME(muteLocalAudioStream(_:));
你可以通过该方法停止或恢复发布本地音频流。 该方法不会影响任何正在进行的音频录制,因为它不会禁用音频采集设备。 使用空间音效时,如果你需要设置是否停止订阅指定用户的音频流,声网推荐你调用该方法,而不是 AgoraRtcEngine 下的同名方法。
调用时机
请在加入频道后调用该方法。
相关回调
该方法成功调用后会触发远端的 rtcEngine:didAudioMuted:byUid: 和 rtcEngine:remoteAudioStateChangedOfUid:state:reason:elapsed: 回调。
参数
- mute
- 是否停止发布本地音频流:
- YES:停止发布本地音频流。
- NO:发布本地音频流。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
muteRemoteAudioStream:mute:
停止或恢复订阅指定用户的音频流。
- (int)muteRemoteAudioStream:(NSUInteger)uid mute:(BOOL)mute NS_SWIFT_NAME(muteRemoteAudioStream(_:mute:));
参数
- uid
- 用户 ID。该参数必须与用户加入频道时传入的用户 ID 相同。
- mute
- 是否订阅指定远端用户的音频流。
- YES:停止订阅指定用户的音频流。
- NO(默认):订阅指定用户的音频流。SDK 会根据本地用户与远端用户之间的距离决定是否订阅。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
destroy
销毁 AgoraLocalSpatialAudioKit 实例。
+ (void)destroy NS_SWIFT_NAME(destroy());
该方法会释放 AgoraLocalSpatialAudioKit 下的所有资源。当你不再需要使用空间音效时,可以调用该方法释放资源。调用该方法后,将无法再使用 AgoraLocalSpatialAudioKit 下的任何 API。如需再次使用空间音效,需等待 destroy 方法执行完成后,再调用 sharedLocalSpatialAudioWithConfig: 创建新的 AgoraLocalSpatialAudioKit 实例。
removeRemotePosition:
移除指定远端用户的空间位置。
- (int)removeRemotePosition:(NSUInteger)uid NS_SWIFT_NAME(removeRemotePosition(_:));
调用该方法后,你将不再听到该远端用户的声音。离开频道后,为避免浪费计算资源,建议调用该方法删除指定远端用户的空间位置信息。否则,该用户的空间位置信息将持续保留。当远端用户数量超过通过 setMaxAudioRecvCount: 设置的可接收音频流数量时,系统会根据相对距离自动取消订阅距离最远用户的音频流。
参数
- uid
uid。该参数必须与用户加入频道时传入的用户 ID 相同。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
setAudioRecvRange:
setDistanceUnit:
设置游戏引擎中每个单位距离对应的米数。
- (int)setDistanceUnit:(float)unit NS_SWIFT_NAME(setDistanceUnit(_:));
声网的空间音效算法中,距离以米为单位进行测量。SDK 默认将游戏引擎中的每个单位距离转换为 1 米。你可以调用 setDistanceUnit: 方法将游戏引擎中的每个单位距离转换为指定的米数。
参数
- unit
- 游戏引擎中每个单位距离对应的米数。该参数的值必须大于 0.00,默认值为 1.00(默认)。例如,将
unit设置为 2.00 表示游戏引擎中每个单位距离等于 2 米。值越大,当远端用户远离你时,你听到的声音衰减得越快。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
setHeadphoneEQParameters:highGain:
设置耳机均衡器的低频和高频参数。
- (int)setHeadphoneEQParameters:(int)lowGain highGain:(int)highGain NS_SWIFT_NAME(setHeadphoneEQParameters(_:highGain:));
如果你调用 setHeadphoneEQPreset: 方法后未达到预设的耳机均衡效果,可以通过调用该方法进一步调整耳机均衡效果。
参数
- lowGain
- 耳机均衡器的低频参数。取值范围为 [-10, 10]。值越大,声音越浑厚。
- highGain
- 耳机均衡器的高频参数。取值范围为 [-10, 10]。值越大,声音越清晰。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
- -1:发生通用错误(无明确原因)。
setHeadphoneEQPreset:
设置预设的耳机均衡效果。
- (int)setHeadphoneEQPreset:(AgoraHeadphoneEQPreset)preset NS_SWIFT_NAME(setHeadphoneEQPreset(_:));
该方法主要用于空间音效场景。你可以选择预设的耳机均衡器来聆听音频,以实现预期的音频体验。
参数
- preset
- 预设的耳机均衡效果,详见 AgoraHeadphoneEQPreset。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
- -1:发生通用错误(无具体原因)。
setMaxAudioRecvCount:
setPlayerAttenuation:playerId:forceSet:
设置媒体播放器的声音衰减属性。
- (int)setPlayerAttenuation:(double)attenuation playerId:(NSUInteger)playerId forceSet:(BOOL)forceSet NS_SWIFT_NAME(setPlayerAttenuation(_:playerId:forceSet:));
参数
- attenuation
- 远端用户或媒体播放器的声音衰减系数,取值范围为 [0,1]。具体取值说明如下:
- 0:广播模式,音量和音色不会随距离衰减,听到的音量和音色不会因距离变化而变化。
- (0, 0.5):弱衰减模式,音量和音色在传播过程中仅有轻微衰减,声音传播距离比真实环境更远。
- 0.5:(默认)模拟真实环境中的音量衰减效果,等效于未设置
speaker_attenuation参数。 - (0.5, 1]:强衰减模式,音量和音色在传播过程中迅速衰减。
- playerId
- 媒体播放器的 ID。你可以通过调用 getMediaPlayerId 获取设备 ID。
- forceSet
- 是否强制设置媒体播放器的声音衰减效果:
- YES:强制使用
attenuation设置媒体播放器的衰减效果,此时在 AgoraSpatialAudioZone 中通过audioAttenuation设置的隔音区衰减系数对媒体播放器无效。 - NO:不强制使用
attenuation设置媒体播放器的声音衰减效果,具体如下:- 如果声源和听众分别位于隔音区内外,声音衰减效果由 AgoraSpatialAudioZone 中的
audioAttenuation决定。 - 如果声源和听众位于同一隔音区内,或都在隔音区外,声音衰减效果由本方法中的
attenuation参数决定。
- 如果声源和听众分别位于隔音区内外,声音衰减效果由 AgoraSpatialAudioZone 中的
- YES:强制使用
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
setRemoteAudioAttenuation:uid:forceSet:
设置指定用户的声音衰减效果。
- (int)setRemoteAudioAttenuation:(double)attenuation uid:(NSUInteger)uid forceSet:(BOOL)forceSet NS_SWIFT_NAME(setRemoteAudioAttenuation(_:uid:forceSet:));
参数
- attenuation
- 用户的声音衰减系数,取值范围为 [0,1]。具体取值说明如下:
- 0:广播模式,音量和音色不会随距离衰减,你听到的音量和音色不会因距离变化而变化。
- (0, 0.5):弱衰减模式,音量和音色在传播过程中仅有轻微衰减,声音传播距离比真实环境更远。
- 0.5:(默认)模拟真实环境中的音量衰减效果,等效于未设置
speaker_attenuation参数。 - (0.5, 1]:强衰减模式,音量和音色在传播过程中快速衰减。
- uid
- 用户 ID。该参数必须与你加入频道时传入的用户 ID 相同。
- forceSet
- 是否强制设置该用户的声音衰减效果:
- YES:强制使用
attenuation设置该用户的声音衰减效果,此时 AgoraSpatialAudioZone 中audioAttenuation设置的隔音区衰减系数对该用户无效。 - NO:不强制使用
attenuation设置该用户的声音衰减效果,具体如下:- 若声源和接收者分别位于隔音区内外,衰减效果由 AgoraSpatialAudioZone 中的
audioAttenuation决定; - 若声源和接收者位于同一隔音区内或同一隔音区外,衰减效果由本方法中的
attenuation决定。
- 若声源和接收者分别位于隔音区内外,衰减效果由 AgoraSpatialAudioZone 中的
- YES:强制使用
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
setRemoteUserSpatialAudioParams:params:
设置远端用户的空间音效参数。
- (int)setRemoteUserSpatialAudioParams:(NSUInteger)uid
params:(AgoraSpatialAudioParams* _Nonnull)params NS_SWIFT_NAME(setRemoteUserSpatialAudioParams(_:params:));
调用 enableSpatialAudio: 方法后,使用该方法设置远端用户的空间音效参数。成功设置后,你可以听到具有空间感的远端用户的声音。
参数
- uid
- 用户 ID。该参数必须与用户加入频道时传入的用户 ID 相同。
- params
- 空间音效参数。详见 AgoraSpatialAudioParams。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
setSpatialAudioParams:
启用或关闭媒体播放器的空间音效。
- (int)setSpatialAudioParams:(AgoraSpatialAudioParams* _Nonnull)params NS_SWIFT_NAME(setSpatialAudioParams(_:));
成功设置媒体播放器的空间音效参数后,SDK 会为媒体播放器启用空间音效。若需关闭媒体播放器的空间音效,请将 params 参数设为 nil。
参数
- params
- 媒体播放器的空间音效参数。详见 AgoraSpatialAudioParams。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
setZones:
设置声源隔音区域。
- (int)setZones:(NSArray<AgoraSpatialAudioZone*> * _Nullable)zones NS_SWIFT_NAME(setZones(_:));
- 当声源(可以是用户或媒体播放器)和接收者分别处于隔音区域的内外部时,声音的衰减效果由 AgoraSpatialAudioZone 中的声音衰减系数决定。
- 如果用户或媒体播放器处于同一个隔音区域内,则不受 AgoraSpatialAudioZone 的影响,声音衰减效果由 setPlayerAttenuation:playerId:forceSet: 或
setRemoteAudioAttenuation:userId:forceSet:中的attenuation参数决定。如果你未调用上述方法,SDK 默认的声音衰减系数为 0.5,用于模拟真实环境中的声音衰减。 - 如果声源和接收者分别处于两个不同的隔音区域内,接收者将无法听到声源的声音。
参数
- zones
- 隔音区域设置。当该参数设置为 nil 时,表示清除所有隔音区域。详见 AgoraSpatialAudioZone。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
updatePlayerPositionInfo:positionInfo:
更新媒体播放器的空间位置。
- (int)updatePlayerPositionInfo:(NSInteger)playerId positionInfo:(AgoraRemoteVoicePositionInfo* _Nonnull)positionInfo NS_SWIFT_NAME(updatePlayerPositionInfo(_:positionInfo:));
调用时机
你可以在加入频道前或后调用该方法。
参数
- playerId
- 媒体播放器的 ID。你可以通过调用 getMediaPlayerId 获取设备 ID。
- positionInfo
- 媒体播放器的空间位置信息,详见 AgoraRemoteVoicePositionInfo。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
updateRemotePosition:positionInfo:
更新指定远端用户的空间位置。
- (int)updateRemotePosition:(NSUInteger)uid positionInfo:(AgoraRemoteVoicePositionInfo*)posInfo NS_SWIFT_NAME(updateRemotePosition(_:positionInfo:));
成功调用该方法后,SDK 会根据本地用户与远端用户之间的相对位置计算空间音效参数。
joinChannelByToken 方法后再调用此方法。参数
- uid
- 远端用户 ID。该参数必须与用户加入频道时传入的用户 ID 相同。
- posInfo
- 远端用户的空间位置。详见 AgoraRemoteVoicePositionInfo。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。
updateSelfPosition:axisForward:axisRight:axisUp:
更新本地用户的空间位置。
- (int)updateSelfPosition:(simd_float3)position axisForward:(simd_float3)axisForward axisRight:(simd_float3)axisRight axisUp:(simd_float3)axisUp NS_SWIFT_NAME(updateSelfPosition(_:axisForward:axisRight:axisUp:));
你需要将该方法与 updateRemotePosition:positionInfo: 方法配合使用。SDK 会根据这两个方法中的参数设置计算本地用户与远端用户之间的相对位置,并据此计算空间音效参数。
参数
- position
- 世界坐标系中的坐标。该参数为长度为 3 的数组,三个值依次表示前、右、上的坐标。
- axisForward
- 坐标系中 x 轴的单位向量。该参数为长度为 3 的数组,三个值依次表示前、右、上的坐标。
- axisRight
- 坐标系中 y 轴的单位向量。该参数为长度为 3 的数组,三个值依次表示前、右、上的坐标。
- axisUp
- 坐标系中 z 轴的单位向量。该参数为长度为 3 的数组,三个值依次表示前、右、上的坐标。
返回值
- 0:方法调用成功。
- < 0:方法调用失败。详见错误码了解详情和解决建议。