直播 App 有时需要展示当前用户列表。单个 AVChatRoom 本身支持的用户数量无上限,但是只能够获取到部分群成员列表,最多为300个成员。
AVChatRoom 的人数统计并不是实时的,有1分钟左右的时延。App 管理后台通过 REST API 接口获取当前群人数
云通信的消息原生支持文本、图片、语音、表情等。如果 App 存在一些特殊的消息需求(例如点赞消息、红包消息等),可以通过云通信的自定义消息实现。
AVChatRoom的缺点——为了更好支持大型直播,AVChatRoom 在一些次要功能点上做了让步,包括只能拉取到部分成员列表(最多300人)、不能移除成员(可以通过禁言来实现近似目的)、不能邀请用户入群(创建时也不能邀请,只能由用户主动申请入群)、不能修改群成员资料、不能设置管理员、不能获取完整成员列表、不能拉取历史消息。
公开群/聊天室/互动直播聊天室:后台不会回收群组,除非群主解散,或者所有成员都退出群组
iOS杀掉进程后,>90S,后台自动关闭房间
用户加入 AVChatRoom 后,如果发生异常登出(logout)或者 App 进程崩溃(crash)的情况,在重新上线(login)或者重启 App 进程后,需要再次调用申请加群才能继续在原来的 AVChatRoom 中收发消息。
主要包括:ImSDK.framework、IMCore.framework、TLSSDK.framework、QALSDK.framework。各个包的说明如下:
必选SDK:必须是一个版本成套使用,不同版本不可混用
* ImSDK.framework IM接口SDK
* QALSDK.framework 网络SDK
* TLSSDK.framework 登录SDK
可选SDK:
* IMCore.framework IM核心功能
* 如果使用IM聊天必须加入,如果只用登录功能(如只使用音视频的情况,可不加入)
* 如果不加入IMCore.framework,使用时需 #import "ImSDK/ImSDKSimple.h",不要包含其他头文件,否则可能会引起编译错误
* IMSDKBugly.framework Crash上报功能
* 如无特殊需要,推荐使用,在控制台页面可以查看Crash率等信息
* 如果不加入此SDK,需要调用 [TIMManager sharedInstance] disableCrashReport]; 禁用功能
其他SDK:
* QALHttpSDK.framework 网络透传SDK
* 只有用到网络透传功能时使用
消息:ImSDK中消息(Message)表示要发送给对方的内容,消息包括若干属性,如是否自己已读,是否已经发送成功,发送人帐号,消息产生时间等;一条消息由若干Elem组合而成,每种Elem可以是文本、图片、表情等等,消息支持多种Elem组合发送。
[holdView HandleMessageFromArray:allArray];
IMAConversation *conv = (IMAConversation *)_showItem;
IMAConversationManager
conversationMgr
onNewMessage
NSArray *conversationList = [[TIMManager sharedInstance] getConversationList];
/**
* 获取会话(TIMConversation*)列表
*
* @return 会话列表
*/
-(NSArray*) getConversationList;
/**
* 获取会话
*
* @param type 会话类型,TIM_C2C 表示单聊 TIM_GROUP 表示群聊
* @param receiver C2C 为对方用户 identifier, GROUP 为群组Id
*
* @return 会话对象
*/
-(TIMConversation*) getConversation: (TIMConversationType)type receiver:(NSString *)receiver;