ChatKit 是一个免费且开源的UI聊天组件,自带云服务器,自带推送,支持消息漫游,消息永久存储。底层聊天服务基于LeaCloud(原名 AVOS ) 的IM实时通信服务「LeaMessage」而开发,采用Protobuf协议进行消息传输。ChatKit可以帮助开发者快速集成IM服务,轻松实现聊天功能,提供完全自由的授权协议,支持二次开发。其最大特点是把聊天常用的一些功能配合UI一起提供给开发者。
运行效果:
示例代码:
由最近联系人进入聊天界面
按照上面的步骤,我们可以非常方便地打开最近联系人页面。但是我们会发现,点击其中的某个联系人/聊天群组,我们并不能直接进入聊天界面。要做到这一点,我们需要给LCChatKit设置上事件响应函数,示例代码如下:
[[LCChatKit sharedIstace] setDidSelectCoversatiosListCellBlock:^(NSIdexPath *idexPath, AVIMCoversatio *coversatio, LCCKCoversatioListViewCotroller *cotroller) { NSLog(@"coversatio selected"); LCCKCoversatioViewCotroller *coversatioVC = [[LCCKCoversatioViewCotroller alloc] iitWithCoversatioId:coversatio.coversatioId]; [cotroller.avigatioCotroller pushViewCotroller:coversatioVC aimated:YES];}];对于联系人列表页面,我们在LCChatKit可以响应如下四种操作:
/*! * 选中某个对话后的回调 (比较常见的需求) * @param coversatio 被选中的对话 */typedef void(^LCCKCoversatiosListDidSelectItemBlock)(NSIdexPath *idexPath, AVIMCoversatio *coversatio, LCCKCoversatioListViewCotroller *cotroller);/*! * 设置选中某个对话后的回调 */- (void)setDidSelectCoversatiosListCellBlock:(LCCKCoversatiosListDidSelectItemBlock)didSelectItemBlock;/*! * 删除某个对话后的回调 (一般不需要做处理) * @param coversatio 被选中的对话 */typedef void(^LCCKCoversatiosListDidDeleteItemBlock)(NSIdexPath *idexPath, AVIMCoversatio *coversatio, LCCKCoversatioListViewCotroller *cotroller);/*! * 设置删除某个对话后的回调 */- (void)setDidDeleteCoversatiosListCellBlock:(LCCKCoversatiosListDidDeleteItemBlock)didDeleteItemBlock;/*! * 对话左滑菜单设置block (最近联系人页面有复杂的手势操作时,可以通过这里扩展实现) * @retur 需要显示的菜单数组 * @param coversatio, 对话 * @param editActios, 默认的菜单数组,成员为 UITableViewRowActio 类型 */typedef NSArray *(^LCCKCoversatioEditActiosBlock)(NSIdexPath *idexPath, NSArray<UITableViewRowActio *> *editActios, AVIMCoversatio *coversatio, LCCKCoversatioListViewCotroller *cotroller);/*! * 可以通过这个block设置对话列表中每个对话的左滑菜单,这个是同步调用的,需要尽快返回,否则会卡住UI */- (void)setCoversatioEditActioBlock:(LCCKCoversatioEditActiosBlock)coversatioEditActioBlock;
评论