通话过程管理
1. 通话状态更新
1.1 成员状态更新回调
如果频道中的成员状态发生了改变,比如开启或关闭发送音频数据、开启本地静音等,其他成员会收到 onParticipantUpdate 的回调
/**
* @brief 成员更新回调
* @param participant 成员对象
* @param participantChangeParam 变化标识集合
*/
-(void)onParticipantUpdate:(JCMediaChannelParticipant*)participant participantChangeParam:(JCMediaChannelParticipantChangeParam *)participantChangeParam;
1.2 新成员加入回调
如果有新成员加入了频道,其他成员会收到成员加入的回调
/**
* @brief 新成员加入回调
* @param participant 成员对象
*/
-(void)onParticipantJoin:(JCMediaChannelParticipant*)participant;
1.3 成员离开回调
如果有成员离开了频道,其他成员会收到成员离开的回调
/**
* @brief 成员离开回调
* @param participant 成员对象
*/
-(void)onParticipantLeft:(JCMediaChannelParticipant*)participant
1.4 自身状态变化回调
如果成员自身状态发生了改变会收到 onMediaChannelStateChange 的回调
/**
* @brief 自身状态变化回调
* @param state 当前状态值
* @param oldState 变化前状态
* @see JCMediaChannelState
*/
-(void)onMediaChannelStateChange:(JCMediaChannelState)state oldState:(JCMediaChannelState)oldState;
其中,自身状态(JCMediaChannelState)有
名称 | 描述 |
---|---|
JCMediaChannelStateIdle | 空闲状态 |
JCMediaChannelStateJoining | 加入中 |
JCMediaChannelStateJoined | 已加入 |
JCMediaChannelStateLeaving | 离开中 |
1.5 成员声音变化回调
/**
* @brief 成员声音变化
*
* @param participant 变化成员
*/
-(void)onParticipantVolumeChange:(JCMediaChannelParticipant*)participant;
2. 通话过程控制
2.1 开启/关闭音频输出
在通话中可以通过下面的方法开启或者关闭音频输出,当 enable 值为 false 时,您将听不到其他成员的声音
/**
* @brief 开启关闭音频输出,可实现静音功能,建议每次join前设置
* @param enable 是否开启音频输出
* @return 返回 true 表示正常执行调用流程,false 表示调用异常
*/
-(bool)enableAudioOutput:(bool)enable;
2.2 开启/关闭发送本地音频流
如果想开启或关闭发送本地音频流,可以调用下面方法,当 enable 值为 false ,将会关闭发送本地音频流,此时其他成员将听不到您的声音,从而实现静音功能
/**
* @brief 开启关闭发送本地音频流
* 1.在频道中将会与服务器进行交互,服务器会更新状态并同步给其他用户
* 2.未在频道中则标记是否上传音频流,在join时生效
* 3.建议每次join前设置
* @param enable 是否开启本地音频流
* @return 返回 true 表示正常执行调用流程,false 表示调用异常
*/
-(bool)enableUploadAudioStream:(bool)enable;
示例代码
// 开启音频输出
[mediaChannel enableAudioOutput:true];
// 发送本地音频流
[mediaChannel enableUploadAudioStream:true];