产品百科 | 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

相关文章
|
4月前
|
数据采集 监控 API
移动端性能监控探索:iOS RUM SDK 技术架构与实践
阿里云 RUM SDK 作为一款性能体验监控采集工具,可以作为辅助 App 运维的强有力助手,提升您的问题排查效率。
346 51
|
开发工具 iOS开发 计算机视觉
|
开发工具 iOS开发 容器
【Azure Blob】关闭Blob 匿名访问,iOS Objective-C SDK连接Storage Account报错
【Azure Blob】关闭Blob 匿名访问,iOS Objective-C SDK连接Storage Account报错
205 0
|
开发工具 图形学 iOS开发
Unity与IOS⭐Unity接入IOS SDK的流程图
Unity与IOS⭐Unity接入IOS SDK的流程图
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
iOS开发 开发者
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
806 67
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
|
JavaScript 搜索推荐 Android开发
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
475 8
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
404 66
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
1524 11
|
12月前
|
人工智能 程序员 API
iOS|记一名 iOS 开发新手的前两次 App 审核经历
啥,这玩意也有新手保护期?
389 0