iOS 融云自定义消息类型、消息 cell以及出现的头像问题

本文介绍了如何在iOS项目中使用融云实现聊天功能,包括集成SDK、自定义会话列表和会话界面,以及解决头像显示、键盘遮挡等问题。还探讨了自定义消息类型和消息cell的实现步骤,强调了消息编码解码、注册消息类型和cell的重要性。此外,文中提及了与安卓端对接时的数据格式问题和使用融云过程中遇到的头像、用户名显示问题及解决方案。
摘要由CSDN通过智能技术生成

1.前言

之前做过一个项目的聊天是是基于 XMPP 协议,所有的东西都是自己写的,工程量大,而且会出现各种各样得问题,丢失消息的问题,所以新进入一家公司之后重新做一个项目给老板推荐聊天使用第三方的,最后权衡选择了融云即时通讯。

2.融云聊天的实现

关于在融云上创建自己的应用、集成 SDK、初始化等一些基本的我们在这就不多说了,按照他的教程可以很容易的完成。

①会话列表的实现

会话列表的实现其实也很简单,就是创建一个继承于RCConversationListViewController的控制器,然后重写 init 的方法,这个里边我们需要设定需要显示的会话类型。

-(id)init{
self = [super init];
/**
<设置会话列表头像为圆形>
**/
[self setConversationAvatarStyle:RC_USER_AVATAR_CYCLE];
if (self) {
//设置需要显示哪些类型的会话
[self setDisplayConversationTypes:@[@(ConversationType_PRIVATE),
@(ConversationType_DISCUSSION),
@(ConversationType_CHATROOM),
@(ConversationType_GROUP),
@(ConversationType_APPSERVICE),
@(ConversationType_SYSTEM)]];
//设置需要将哪些类型的会话在会话列表中聚合显示
[self setCollectionConversationType:@[@(ConversationType_DISCUSSION),
@(ConversationType_SYSTEM)]];

}
return self;

}
然后就是在- (void)viewWillAppear:(BOOL)animated写一些界面将要显示的时候的一些逻辑操作,比如提示新消息的小圆点或者消息数等。

  • (void)viewWillAppear:(BOOL)animated{
    [super viewWillAppear:animated];
    /更新底部红点状态 点击cell读取消息后 要刷新底部红点/
    [[TJNotification sharedTJNotification]refreshNotificationPrompt];
    }
    之后再viewDidLoad里边设定一些会话列表界面的一些属性,设定刷新菊花、没有消息时候的背景视图、需要置顶的会话等等

  • (void)viewDidLoad {
    [super viewDidLoad];
    /设置默认属性/
    self.conversationListTableView.separatorStyle = UITableViewCellSeparatorStyleSingleLine;
    self.conversationListTableView.backgroundColor = [UIColor tj_mainColor];
    self.edgesForExtendedLayout = UIRectEdgeNone;
    UIView *footerView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, SCREEN_WIDTH, 150)];
    footerView.backgroundColor = [UIColor tj_mainColor];
    self.conversationListTableView.tableFooterView = footerView;
    self.emptyConversationView = self.noMessage;
    //置顶特定UID 的会话
    [[RCIMClient sharedRCIMClient] setConversationToTop:6 targetId:@”tanjie_user_1.0_2017” isTop:YES];
    }
    然后就是融云自己的一些方法根据我们的功能需要需要我们自己重写,下面我就列举两个比较重要的,如果自己需要这些逻辑的话就可以重写这些方法,

/*!
即将加载列表数据源的回调

@param dataSource 即将加载的列表数据源(元素为RCConversationModel对象)
@return 修改后的数据源(元素为RCConversationModel对象)

@discussion 您可以在回调中修改、添加、删除数据源的元素来定制显示的内容,会话列表会根据您返回的修改后的数据源进行显示。
数据源中存放的元素为会话Cell的数据模型,即RCConversationModel对象。
*/
- (NSMutableArray )willReloadTableData:(NSMutableArray )dataSource;

/*!
即将显示Cell的回调

@param cell 即将显示的Cell
@param indexPath 该Cell对应的会话Cell数据模型在数据源中的索引值

@discussion 您可以在此回调中修改Cell的一些显示属性。
*/
- (void)willDisplayConversationTableCell:(RCConversationBaseCell *)cell
atIndexPath:(NSIndexPath *)indexPath;
紧接着我们需要点击会话跳转到会话界面,我们需要重写这个方法。

  • (void)onSelectedTableRow:(RCConversationModelType)conversationModelType conversationModel:(RCConversationModel )model atIndexPath:(NSIndexPath )indexPath
    {
    //我们把我们自己设定的两个客服消息聚合到了一个会话里边,所以这里根据消息类型跳转不同的界面
    if (conversationModelType == RC_CONVERSATION_MODEL_TYPE_COLLECTION){
    TJChatListViewController *chatListVC = [[TJChatListViewController alloc]init];
    NSArray *array = [NSArray arrayWithObject:[NSNumber numberWithInt:model.conversationType]];
    [chatListVC setDisplayConversationTypes:array];
    [chatListVC setCollectionConversationType:nil];
    chatListVC.isEnteredToCollectionViewC

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值