更新时间:2024-09-23 GMT+08:00
分享

房间功能

joinRoom

- (int)joinRoom:(HWRtcJoinParam * _Nonnull)joinParam;

功能说明

加入房间。该方法让用户加入通话房间。如果已在通话中,用户必须调用leaveRoom退出当前通话,才能进入下一个房间。

请求参数

joinParam:用户信息,具体请参见HWRtcJoinParam

返回参数
  • 0:方法调用成功。
  • > 0:方法调用失败。具体请参见HWRtcErrorCode

会触发以下回调:

changeUserRole

- (int)changeUserRole:(HWRtcRole)role signature:(NSString *)authorization ctime:(long long)ctime;

功能说明

设置用户在当前房间内的角色类型,角色切换时使用。

请求参数

  • role:用户角色类型,joiner类型和player类型,具体请参见HWRtcRole
  • authorization:预留参数,填null。
  • ctime:预留参数,填0。

返回参数

  • 0:方法调用成功。
  • > 0:方法调用失败。具体请参见HWRtcErrorCode
  • 加入房间前,可以通过joinRoom的userRole参数确认角色信息。
  • 加入指定房间后才可以在指定房间内进行角色切换,当前仅支持joiner和player角色切换。跨房场景下,通过对应connection连接下的changeUserRole接口实现在跨入房间中的角色类型切换。
  • 切换成功触发onUserRoleChange回调。切换失败会触发onError回调,错误码HWRtcErrorCode :HWRtcErrorCodeUserRoleChangeFail。
  • 同一时间不同房间最多只能有一个joiner,player切换joiner的时候,需要将其他房间的joiner先切换成player。
  • 不支持缺省用户昵称入会。

renewAuthorization

- (int)renewAuthorization:(NSString *_Nonnull)signature time:(long long)time;

功能说明

鉴权签名过期,收到onAuthorizationExpired签名鉴权过期回调后,更新鉴权签名。

请求参数
  • signature:鉴权签名字串。
  • time:过期时间。
返回参数
  • 0:方法调用成功。
  • > 0:方法调用失败。具体请参见HWRtcErrorCode

leaveRoom

- (int)leaveRoom;

功能说明

离开房间。

请求参数

返回参数
  • 0:方法调用成功。
  • > 0:方法调用失败。具体请参见HWRtcErrorCode
  • 必须调用leaveRoom结束通话后才可以开始下一次通话。
  • 会触发以下回调:

changeUserName

- (int)changeUserName:(NSString *)userName;

功能说明

房间内设置用户自己的昵称。

请求参数

userName:变更的昵称。

返回参数
  • 0:方法调用成功。
  • > 0:方法调用失败。具体请参见HWRtcErrorCode
  • 该接口仅支持房间内调用,更改的昵称会被实时同步到房间内其他用户的用户列表,退出房间不会保存,再次加入房间变更为加入房间时设置的昵称(参考joinRoom接口注意事项)。
  • 会触发用户名变更通知的回调onUserNameChangedNotify

createConnection

- (HWRtcConnection *_Nullable)createConnection:(NSString *_Nullable)roomId;

功能说明

根据房间ID,创建HWRtcConnection对象,为跨房做准备。

通过此接口创建一个与房间关联的HWRtcConnection连接对象。

该方法支持多次调用,创建多个HWRtcConnection连接对象,调用每个对象中的joinRoom方法,可以同时加入到多个房间。在每个房间中,可以分别订阅和选看房间中的用户。

具体请参见事件回调(HWRtcConnection)有关接口和回调。

请求参数

roomid:房间ID。

返回参数

HWRtcConnection:成功返回连接对象指针,失败返回为空。

  • 同一时间最多只能创建4个连接对象,每个连接对象对应的房间ID必须互不相同。
  • 如果使用HWRtcConnection对象加入房间,则加入房间的房间ID不能和已创建连接对象对应的房间ID相同。
  • 同一时间只能以JOINER角色加入某一个房间。

addMultiRoomMediaRelay

- (int)addMultiRoomMediaRelay:(HWRtcMultiRoomMediaRelayConfiguration *)roomMediaRelayConfiguration;

功能说明

添加单个跨房。

请求参数

roomMediaRelayConfiguration:跨房信息,具体请参见HRTCMultiRoomMediaRelayConfiguration

返回参数
  • 0:方法调用成功。
  • > 0:方法调用失败。具体请参见HWRtcErrorCode

removeMultiRoomMediaRelay

- (int)removeMultiRoomMediaRelay:(HWRtcMultiRoomMediaRelayConfiguration *)roomMediaRelayConfiguration;

功能说明

删除单个跨房。

请求参数

roomMediaRelayConfiguration:跨房信息,具体请参见HRTCMultiRoomMediaRelayConfiguration

返回参数
  • 0:方法调用成功。
  • > 0:方法调用失败。具体请参见HWRtcErrorCode

stopMultiRoomMediaRelay

- (int)stopMultiRoomMediaRelay;

功能说明

停止所有跨房。

请求参数

返回参数
  • 0:方法调用成功。
  • > 0:方法调用失败。具体请参见HWRtcErrorCode

相关文档