菊风云平台
菊风云平台多方语音通话通话过程管理

通话过程管理

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];