产品百科 | RTC iOS SDK 播放音效文件的接口方法

简介: 阿里云 RTC SDK 为您提供伴奏文件和音效文件的相关接口方法,您可以通过本文了解其具体的实现方法。

伴奏文件

伴奏文件的接口方法如下所示。

  • 调用 startAudioAccompanyWithFile 开始混音伴奏,调用成功返回 0,失败返回错误码。

    说明 调用该接口后,立即开始混音伴奏。
//接口方法
- (int)startAudioAccompanyWithFile:(NSString *)filePath onlyLocalPlay:(BOOL)onlyLocalPlay replaceMic:(BOOL)replaceMic loopCycles:(NSInteger)loopCycles;
//示例方法
int code = [self.engine startAudioAccompanyWithFile:@"******" onlyLocalPlay:YES replaceMic:YES loopCycles:3];
if (code != 0) {
    NSLog(@"播放失败,请检查参数配置");
}
参数 说明
filePath 伴奏文件路径
onlyLocalPlay 是否只本地播放。YES:仅本地播放;NO:本地播放和推流
replaceMic 是否替换麦克风采集,YES:替换麦克风采集,只有伴奏声;NO:与麦克风共存
loopCycles 循环次数,可以设置 - 1 或者正整数
  • 调用 pauseAudioAccompany 暂停伴奏播放,调用成功返回 0,失败返回错误码。

    说明 您需要在 startAudioAccompanyWithFile 接口之后调用。
//接口方法
- (int)pauseAudioAccompany;
//示例接口
[self.engine pauseAudioAccompany];
  • 调用 resumeAudioAccompany 恢复伴奏,调用成功返回 0,失败返回错误码。

    说明 您可以与 pauseAudioAccompany 搭配使用。
//接口方法
- (int)resumeAudioAccompany;
//示例方法
[self.engine resumeAudioAccompany];
  • 调用 stopAudioAccompany 停止伴奏,调用成功返回 0,失败返回错误码。

    说明 调用之后立刻停止伴奏播放,与 startAudioAccompanyWithFile 搭配使用。
//接口方法
- (int)stopAudioAccompany;
//示例方法
[self.engine stopAudioAccompany];
  • 设置音量的接口方法如下所示。
/**
 * @brief 设置混音音量
 * @param volume 混音音量,取值:0~100
 * @return 调用成功返回0,失败返回错误码
 * @note 设置音量需要在调用startAudioAccompanyWithFile接口后才能生效
 */
- (int)setAudioAccompanyVolume:(NSInteger)volume;
/**
 * @brief 设置混音之后推流出去的音量
 * @param volume 混音音量,取值:0~100
 * @return 调用成功返回0,失败返回错误码
 * @note 设置音量需要在调用startAudioAccompanyWithFile接口后才能生效
 */
- (int)setAudioAccompanyPublishVolume:(NSInteger)volume;
/**
 * @brief 获取推流出去的混音音量
 * @return 调用成功返回0,失败返回错误码
 */
- (int)getAudioAccompanyPublishVolume;
/**
 * @brief 设置混音之后本地播放的音量
 * @param volume 混音音量,取值:0~100
 * @return 调用成功返回0,失败返回错误码
 * @note 设置音量需要在调用startAudioAccompanyWithFile接口后才能生效
 */
- (int)setAudioAccompanyPlayoutVolume:(NSInteger)volume;
/**
 * @brief 获取混音本地播放的音量
 * @return 调用成功返回0,失败返回错误码
 */
- (int)getAudioAccompanyPlayoutVolume;

音效文件

音效文件的接口方法如下所示。

  • 调用 preloadAudioEffectWithSoundId 预加载音效文件,调用成功返回 0,失败返回错误码。
//接口方法
- (int)preloadAudioEffectWithSoundId:(NSInteger)soundId filePath:(NSString *)filePath;
//示例方法
[self.engine preloadAudioEffectWithSoundId:11235 filePath:@"*******"];
参数 类型 说明
filePath NSString * 伴奏文件路径
soundId NSInteger 指定的音效文件 ID,个数无限制,您需要通过此 ID 做后续操作
  • 调用 unloadAudioEffectWithSoundId 根据预加载的音效文件 ID 删除预加载音效,调用成功返回 0,失败返回错误码。
//接口方法
- (int)unloadAudioEffectWithSoundId:(NSInteger)soundId;
//示例方法
[self.engine unloadAudioEffectWithSoundId:11235];
  • 调用 playAudioEffectWithSoundId 开始播放音效,调用成功返回 0,失败返回错误码。

    说明 调用该接口后立即播放音效,您需要在 preloadAudioEffectWithSoundId 之后调用。
//接口方法
- (int)playAudioEffectWithSoundId:(NSInteger)soundId filePath:(NSString *)filePath cycles:(NSInteger)cycles publish:(BOOL)publish;
//示例方法
int code = [self.engine playAudioEffectWithSoundId:11235 filePath:@"******" cycles:5 publish:YES];
if (code != 0) {
    NSLog(@"播放失败,,请检查参数配置");
}
参数 类型 说明
soundId NSInteger 预加载时指定的文件 ID
filePath NSString * 音效文件路径
cycles NSInteger 循环次数,可以设置为 - 1 或者正整数
publish BOOL 是否推流,NO:不推流、仅本地播放;YES:本地播放和推流
  • 调用 pauseAudioEffectWithSoundId 暂停播放音效,调用成功返回 0,失败返回错误码。

    说明 您需要在 playAudioEffectWithSoundId 接口之后调用。
//接口方法
- (int)pauseAudioEffectWithSoundId:(NSInteger)soundId;
//示例方法
[self.engine pauseAudioEffectWithSoundId:11235];
  • 调用 resumeAudioEffectWithSoundId 恢复播放音效,调用成功返回 0,失败返回错误码。

    说明 该接口可以和 pauseAudioEffectWithSoundId 搭配使用。
//接口方法
- (int)resumeAudioEffectWithSoundId:(NSInteger)soundId;
//示例方法
[self.engine resumeAudioEffectWithSoundId:11235];
  • 调用 stopAudioEffectWithSoundId 停止播放音效,调用成功返回 0,失败返回错误码。

    说明 调用该接口之后立刻停止播放音效,可以与 playAudioEffectWithSoundId 搭配使用。
//接口方法
- (int)stopAudioEffectWithSoundId:(NSInteger)soundId;
//示例方法
[self.engine stopAudioEffectWithSoundId:11235];
  • 设置音效音量接口方法如下所示。
/**
 * @brief 设置音效推流音量
 * @param soundId 音效文件ID
 * @param volume 混音音量,取值:0~100
 * @return 调用成功返回0,失败返回错误码
 */
- (int)setAudioEffectPublishVolumeWithSoundId:(NSInteger)soundId volume:(NSInteger)volume;
/**
 * @brief 获取推流音效音量
 * @param soundId 音效文件ID
 * @return 调用成功返回0~100音量,失败返回错误码
 */
- (int)getAudioEffectPublishVolumeWithSoundId:(NSInteger)soundId;
/**
 * @brief 设置音效本地播放音量
 * @param soundId 音效文件ID
 * @param volume 混音音量,取值:0~100
 * @return 调用成功返回0,失败返回错误码
 */
- (int)setAudioEffectPlayoutVolumeWithSoundId:(NSInteger)soundId volume:(NSInteger)volume;
/**
 * @brief 获取音效本地播放音量
 * @param soundId 音效文件分配ID
 * @return 调用成功返回0~100音量,失败返回错误码
 */
- (int)getAudioEffectPlayoutVolumeWithSoundId:(NSInteger)soundId;


「视频云技术」你最值得关注的音视频技术公众号,每周推送来自阿里云一线的实践技术文章,在这里与音视频领域一流工程师交流切磋。

image.png

相关文章
|
分布式计算 DataWorks Java
DataWorks操作报错合集之在使用MaxCompute的Java SDK创建函数时,出现找不到文件资源的情况,是BUG吗
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
203 0
|
6月前
|
数据采集 监控 API
移动端性能监控探索:iOS RUM SDK 技术架构与实践
阿里云 RUM SDK 作为一款性能体验监控采集工具,可以作为辅助 App 运维的强有力助手,提升您的问题排查效率。
386 59
|
Java Apache 开发工具
【Azure 事件中心】 org.slf4j.Logger 收集 Event Hub SDK(Java) 输出日志并以文件形式保存
【Azure 事件中心】 org.slf4j.Logger 收集 Event Hub SDK(Java) 输出日志并以文件形式保存
292 1
|
开发工具 iOS开发 计算机视觉
|
网络安全 开发工具 Python
【Azure事件中心】使用Python SDK(Confluent)相关方法获取offset或lag时提示SSL相关错误
【Azure事件中心】使用Python SDK(Confluent)相关方法获取offset或lag时提示SSL相关错误
153 1
|
消息中间件 分布式计算 DataWorks
DataWorks产品使用合集之如何使用Python和阿里云SDK读取OSS中的文件
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
开发工具 iOS开发 容器
【Azure Blob】关闭Blob 匿名访问,iOS Objective-C SDK连接Storage Account报错
iOS Objective-C 应用连接Azure Storage时,若不关闭账号的匿名访问,程序能正常运行。但关闭匿名访问后,上传到容器时会出现错误:“Public access is not permitted”。解决方法是将创建容器时的公共访问类型从`AZSContainerPublicAccessTypeContainer`改为`AZSContainerPublicAccessTypeOff`,以确保通过授权请求访问。
276 0
【Azure Blob】关闭Blob 匿名访问,iOS Objective-C SDK连接Storage Account报错
|
Linux 调度 开发工具
云桌面系统镜像文件快速分发方案分享SDK
为了解决云桌面环境下批量升级系统镜像的效率问题,传统的1对多FTP/HTTP方式因服务器带宽限制导致传输慢。一种基于优化的Bittorrent协议的P2P解决方案被提出,利用P2P技术将文件切块并让终端互相分享,提高下载速度,尤其适合大文件如256GB分区镜像的分发。通过自定义IO接口、跳过校验、超大分块、多分块支持及局域网自建Tracker等功能,实现更快的传输和镜像更新,适用于系统镜像、游戏更新等领域。该方案已广泛应用于各行业,可根据不同场景定制优化。
410 1
|
开发工具 iOS开发 容器
【Azure Blob】关闭Blob 匿名访问,iOS Objective-C SDK连接Storage Account报错
【Azure Blob】关闭Blob 匿名访问,iOS Objective-C SDK连接Storage Account报错
236 0
|
API 网络安全 开发工具
【Azure Developer - 密钥保管库 】使用 Python Azure SDK 实现从 Azure Key Vault Certificate 中下载证书(PEM文件)
【Azure Developer - 密钥保管库 】使用 Python Azure SDK 实现从 Azure Key Vault Certificate 中下载证书(PEM文件)
242 0