- 最新动态
- 服务公告
- 产品介绍
- 快速入门
- 用户指南
- 最佳实践
- API参考
-
客户端SDK参考
- 使用前必读
- SDK概述
- 隐私声明
- 合规使用指南
- Android SDK
- iOS/macOS SDK
- All Platform C++ SDK
- Web SDK
- 接入鉴权
- 附录
- 修订记录
-
常见问题
-
产品咨询
- SparkRTC支持哪些平台?
- SparkRTC Demo怎么体验?
- 在进行Windows的Demo使用或集成SDK时,提示微软C++标准库缺失,该如何获取?
- SparkRTC支持接入微信小程序吗?
- 实时音视频是什么?
- 实时音视频和直播有什么区别?
- SparkRTC是否支持在国外使用?
- SparkRTC RoomID是什么?取值区间值是多少?
- SparkRTC最多可以同时创建多少个房间?
- SparkRTC UserID是什么?取值范围是多少?
- 怎么理解SparkRTC的角色Role?
- SparkRTC最多可以支持多少个人同时视频通话?
- 实时音视频的时延是多少?
- SparkRTC是否支持连麦互动?
- SparkRTC是否支持双向的桌面推送?
- 实时音视频支持私有化部署吗?
- PC端实时音视频支持USB摄像头吗?
- 计费购买
- Signature相关
- 录制相关
-
SDK使用
- 移动端(Android/iOS)创建一个房间,是否支持PC端(MAC/Windows)接入?
- iOS平台如何缩减安装包体积?
- Android平台如何缩减安装包体积?
- iOS端是否可以监听远端离开房间?
- 背景音乐是否支持循环播放?
- SparkRTC是否支持调整背景音乐的播放进度?
- 支持监听房间成员进出房间吗?
- 如何监测断网和重连?
- 支持首帧渲染回调吗?能否监听画面开始渲染?
- 如何设置上行视频码率、分辨率和帧率?
- 有没有推荐的画面质量(码率、分辨率、帧率)相关参数配置?
- 如何实现横屏视频通话?
- 是否支持网络测速?如何操作?
- 是否支持音量大小提示?
- 自定义渲染支持哪些格式?
- SparkRTC支持iOS后台运行吗?
- 移动端如何实现录屏(屏幕分享)?
- 多人视频会议中,移动端和Web端可以进入同一房间吗?
- SparkRTC的Web端、移动端、PC端是不是同步的?
- Android SDK是否支持自定义采集数据?
- SparkRTC支持旁路推流吗?
- Windows端如何才能采集到被分享应用播放的声音?
- SDK是否支持断线重连机制?
- 如何创建房间?
- 两台手机同时运行SparkRTC APP,为什么无法互通?
- 鉴权是如何生成的?在什么时候生成?
- onVideoStats、onAudioStatus、onSubStreamStats回调触发时为什么程序会崩溃?
- 为什么本端听筒能听到自己的声音?
- setExternalAudioCapture(音频自采集)、setExternalVideoCapture(视频自采集)、setExternalMediaFrameOutput(视频自渲染)能在进入房间后开启吗?
- SparkRTC是否支持设置镜像画面?
- SparkRTC音视频过程中的上下行码率、分辨率、丢包率、音频采样率等信息怎么获取?
- SparkRTC是否支持设置本地采集音量?是否支持设置每个远端用户的播放音量?
- enableLocalVideo和muteLocalVideo有什么区别?
- enableLocalAudioStream和muteLocalAudio有什么区别?
- SparkRTC是否支持对房间进行权限校验?
- 接入PC端是否支持屏幕分享功能?
- SparkRTC是否支持将本地视频文件分享到实时音视频中?
- SparkRTC是否支持单纯的实时音频?
- 一个房间里可以同时有多路屏幕分享吗?
- SparkRTC是否支持1080P?
- 是否支持视频画面截图功能?
- 播放背景音乐是否支持在线音乐?
- 同一个页面中,可以创建N个RTC对象,通过N个UserID,分别登录到N个房间吗?
- Web端用宽高设置的推流分辨率适用于所有浏览器吗?
- Web端SDK在使用过程中拔掉摄像头,摄像头列表里面的数据如何清除?
- Web端SDK可以获取当前音量大小吗?
- Web端支持监听远端离开房间吗?
- Web端通话过程中为什么会出现回声、杂音、噪声、声音小?
- Web端如何切换摄像头和麦克风?
- SparkRTC支持白板功能吗?
- 相同UserID支持同时进入多个房间吗?
- SparkRTC房间的生命周期是多久?
- SparkRTC多人视频通话支持蓝牙耳机吗?
- SparkRTC多人视频通话支持仅订阅2/3/4人音频吗?
- 指定窗口分享,当窗口大小变化时,视频流的分辨率会跟着变化吗?
- 视频通话支持悬浮窗、大小画面切换功能吗?
- 发送自定义消息接口能实现聊天室、弹幕等功能吗?
- 支持查询所有的UserID吗?
- Web SDK中的checkSystemRequirements接口为什么会调用异常?
- 问题排查
-
产品咨询
- 文档下载
- 通用参考
- getPlaybackDevices
- getRecordDevices
- setPlaybackDevice
- setRecordDevice
- setPlaybackDeviceVolume
- setRecordDeviceVolume
- getPlaybackDeviceVolume
- getRecordDeviceVolume
- setPlaybackDeviceMuteState
- setRecordDeviceMuteState
- getPlaybackDeviceMuteState
- getRecordDeviceMuteState
- getCurrentPlaybackDevice
- getCurrentRecordDevice
- recordingDeviceTest
- finishRecordingDeviceTest
- playbackDeviceTest
- finishPlaybackDeviceTest
- echoTest
- finishEchoTest
展开导读
链接复制成功!
音频设备管理
本章节介绍了全平台C++ SDK的IHRTCAudioDeviceManager接口详情。
接口 |
描述 |
---|---|
获取系统音频播放设备列表 |
|
获取系统音频录制设备列表 |
|
指定音频播放设备 |
|
指定音频录制设备 |
|
设置音频播放设备音量 |
|
设置音频录制设备音量 |
|
获取音频播放设备音量 |
|
获取音频录制设备音量 |
|
设置音频播放设备是否静音 |
|
设置音频录制设备是否静音 |
|
获取音频播放设备静音状态 |
|
获取音频录制设备静音状态 |
|
获取当前音频播放设备 |
|
获取当前音频录制设备 |
|
音频采集设备测试(只支持Windows和macOS) |
|
结束音频采集设备测试(只支持Windows和macOS) |
|
音频播放设备测试(只支持Windows和macOS) |
|
结束音频播放设备测试(只支持Windows和macOS) |
|
音频设备回路测试(只支持Windows和macOS) |
|
结束音频设备回路测试(只支持Windows和macOS) |
getPlaybackDevices
virtual int getPlaybackDevices(HRTCDeviceInfo *deviceInfo, unsigned int *counts)
【功能说明】
获取系统音频播放设备列表。
【请求参数】
- deviceInfo:输出参数,获取系统设备详情,包括设备标识和设备名称。具体请参见HRTCDeviceInfo。
- counts:输入输出参数,获取deviceInfo对象数量,输入值为deviceInfo的数量,将会返回小于等于counts数量的设备信息。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
getRecordDevices
virtual int getRecordDevices(HRTCDeviceInfo *deviceInfo, unsigned int *counts)
【功能说明】
获取系统音频录制设备列表。
【请求参数】
- deviceInfo:输出参数,获取系统设备详情,包括设备标识和设备名称。具体请参见HRTCDeviceInfo。
- counts:输入输出参数,获取deviceInfo对象数量,输入值为deviceInfo的数量,将会返回小于等于counts数量的设备信息。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
setPlaybackDevice
virtual int setPlaybackDevice(const char deviceId[HRTC_MAX_DEVICE_ID_LEN + 1])
【功能说明】
指定音频播放设备。
【请求参数】
deviceId:设备标识。可通过getPlaybackDevices获取。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
- 通话前没有选择任何设备,通话中使用默认设备。
- 通话前已选择指定设备,通话中直接生效。
- 通话中有多个音频设备,拨出设备会自动切换。
- 通话中无音频设备,新插入设备,需要重新调用该接口指定设备。
setRecordDevice
virtual int setRecordDevice(const char deviceId[HRTC_MAX_DEVICE_ID_LEN+ 1])
【功能说明】
指定音频录制设备。
【请求参数】
deviceId:设备标识。可通过getRecordDevices获取。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
- 通话前没有选择任何设备,通话中使用默认设备。
- 通话前已选择指定设备,通话中直接生效。
- 通话中有多个音频设备,拨出设备会自动切换。
- 通话中无音频设备,新插入设备,需要重新调用该接口指定设备。
setPlaybackDeviceVolume
virtual int setPlaybackDeviceVolume(unsigned int volume)
【功能说明】
设置音频播放设备音量。
【请求参数】
volume:播放设备音量。取值范围为[0,100]。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
setRecordDeviceVolume
virtual int setRecordDeviceVolume(unsigned int volume)
【功能说明】
设置音频录制设备音量。
【请求参数】
volume:录音设备音量。取值范围为[0,100]。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
getPlaybackDeviceVolume
virtual int getPlaybackDeviceVolume(unsigned int *volume)
【功能说明】
获取音频播放设备音量。
【请求参数】
volume:播放设备音量,取值范围为[0,100]。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
getRecordDeviceVolume
virtual int getRecordDeviceVolume(unsigned int *volume)
【功能说明】
获取音频录制设备音量。
【请求参数】
volume:输出参数,录音设备音量。取值范围为[0,100]。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
setPlaybackDeviceMuteState
virtual int setPlaybackDeviceMuteState(bool mute)
【功能说明】
设置音频播放设备是否静音。
【请求参数】
mute:true表示设备设为静音,false表示设备设为不静音。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
setRecordDeviceMuteState
virtual int setRecordDeviceMuteState(bool mute)
【功能说明】
设置音频录制设备是否静音。
【请求参数】
mute:true表示设备设为静音,false表示设备设为非静音。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
getPlaybackDeviceMuteState
virtual int getPlaybackDeviceMuteState(bool *mute)
【功能说明】
获取音频播放设备静音状态。
【请求参数】
mute:true表示已静音状态,false表示非静音状态。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
getRecordDeviceMuteState
virtual int getRecordDeviceMuteState(bool *mute)
【功能说明】
获取音频录制设备静音状态。
【请求参数】
mute:true表示已静音状态,false表示非静音状态。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
getCurrentPlaybackDevice
virtual int getCurrentPlaybackDevice(char deviceId[HRTC_MAX_DEVICE_ID_LEN + 1])
【功能说明】
获取当前音频播放设备。
【请求参数】
deviceId:输出参数,当前播放设备标识。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
getCurrentRecordDevice
virtual int getCurrentRecordDevice(char deviceId[HRTC_MAX_DEVICE_ID_LEN+ 1])
【功能说明】
获取当前音频录制设备。
【请求参数】
deviceId:输出参数,当前录制设备标识。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
recordingDeviceTest
virtual int recordingDeviceTest(int intervalInMilliseconds)
【功能说明】
音频采集设备测试。
【请求参数】
intervalInMilliseconds:音量回调周期,单位毫秒,范围100到10000。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
只支持Windows和macOS。
finishRecordingDeviceTest
virtual int finishRecordingDeviceTest()
【功能说明】
结束音频采集设备测试。
【请求参数】
无。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
只支持Windows和macOS。
playbackDeviceTest
virtual int playbackDeviceTest(const char *testAudioFilePath)
【功能说明】
音频播放设备测试。
【请求参数】
testAudioFilePath:测试音频文件,只支持WAV格式。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
只支持Windows和macOS。
finishPlaybackDeviceTest
virtual int finishPlaybackDeviceTest()
【功能说明】
结束音频播放设备测试。
【请求参数】
d无。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
只支持Windows和macOS。
echoTest
virtual int echoTest(int intervalInMilliseconds)
【功能说明】
音频设备回路测试。
【请求参数】
intervalInMilliseconds:音量回调周期,单位毫秒,范围100到10000。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
只支持Windows和macOS。
finishEchoTest
virtual int finishEchoTest()
【功能说明】
结束音频设备回路测试。
【请求参数】
无。
【返回参数】
- 0:方法调用成功。
- > 0:方法调用失败。具体请参见HRTCErrorCode。
只支持Windows和macOS。