明天的干货分享是对于“浏览回执”性能,这是一个很广泛的性能,然而针对应用融云的 SDK 去实现,还是有些坑在等着咱们的,上面就开始分(bì)享(kēng)喽~
分享之前先做一些筹备工作,先找到咱们须要调用的接口文档
- 文档:https://docs.rongcloud.cn/v4-...
- 官网:https://www.rongcloud.cn/
依据不同的会话类型以及音讯的发送方和接管方,要别离解决
单聊
接管方 :在浏览音讯后,调用 RCIMClient 类的发送浏览回执接口,参数如下:
conversationType 单聊会话类型
targetId 音讯的会话 ID
time 会话最初一条音讯的发送工夫(sentTime)
/*! 发送某个会话中音讯浏览的回执 @param conversationType 会话类型 @param targetId 会话 ID @param timestamp 该会话中已浏览的最初一条音讯的发送工夫戳 @param successBlock 发送胜利的回调 @param errorBlock 发送失败的回调[nErrorCode: 失败的错误码] @discussion 此接口只反对单聊, 如果应用 IMLib 能够注册监听 RCLibDispatchReadReceiptNotification 告诉,应用 IMKit 间接设置RCIM.h 中的 enabledReadReceiptConversationTypeList。 @warning 目前仅反对单聊。 @remarks 高级性能 */
targetId:(NSString *)targetId time:(long long)timestamp success:(void (^)(void))successBlock error:(void (^)(RCErrorCode nErrorCode))errorBlock; ``` **发送方**:监听上面这个告诉,在接管后批改音讯的展现 ```objective-c /*! @const 收到已读回执的 Notification @discussion 收到音讯已读回执之后,IMLib 会散发此告诉。 Notification 的 object 为 nil,userInfo 为 NSDictionary 对象, 其中 key 值别离为 @"cType"、@"tId"、@"messageTime", 对应的 value 为会话类型的 NSNumber 对象 、会话的 targetId 、已浏览的最初一条音讯的 sendTime。 如: NSNumber *ctype = [notification.userInfo objectForKey:@"cType"]; NSNumber *time = [notification.userInfo objectForKey:@"messageTime"]; NSString *targetId = [notification.userInfo objectForKey:@"tId"]; NSString *fromUserId = [notification.userInfo objectForKey:@"fId"]; 收到这个音讯之后能够更新这个会话中 messageTime 以前的音讯 UI 为已读(底层数据库音讯状态曾经改为已读)。 @remarks 事件监听 */ FOUNDATION_EXPORT NSString *const RCLibDispatchReadReceiptNotification; ```
群聊
发送方:
在发送音讯 A 后,须要针对该音讯发送回执申请,message 传之前发的音讯 A
/*! 申请音讯浏览回执 @param message 要求浏览回执的音讯 @param successBlock 申请胜利的回调 @param errorBlock 申请失败的回调[nErrorCode: 失败的错误码] @discussion 通过此接口,能够要求浏览了这条音讯的用户发送浏览回执。 @remarks 高级性能 */
success:(void (^)(void))successBlock error:(void (^)(RCErrorCode nErrorCode))errorBlock; ``` 设置上面代理函数,在接管到发送方发来的浏览回执响应后,批改音讯的展现 ```objective-c /*! IMlib音讯接管的监听器 @discussion 设置IMLib的音讯接管监听器请参考RCIMClient的setReceiveMessageDelegate:object:办法。 @warning 如果您应用IMlib,能够设置并实现此Delegate监听音讯接管; 如果您应用IMKit,请应用RCIM中的RCIMReceiveMessageDelegate监听音讯接管,而不要应用此监听器,否则会导致IMKit中无奈自动更新UI! */ @protocol RCIMClientReceiveMessageDelegate <NSObject> /*! 音讯已读回执响应(收到浏览回执响应,能够依照 messageUId 更新音讯的阅读数) @param messageUId 申请已读回执的音讯ID @param conversationType conversationType @param targetId targetId @param userIdList 已读userId列表 */ - (void)onMessageReceiptResponse:(RCConversationType)conversationType targetId:(NSString *)targetId messageUId:(NSString *)messageUId readerList:(NSMutableDictionary *)userIdList; ``` **接管方**: 设置上面代理函数,在接管到音讯 A 后,还会接管到针对音讯 A 的浏览回执申请 ```objective-c /*! IMlib音讯接管的监听器 @discussion 设置IMLib的音讯接管监听器请参考RCIMClient的setReceiveMessageDelegate:object:办法。 @warning 如果您应用IMlib,能够设置并实现此Delegate监听音讯接管; 如果您应用IMKit,请应用RCIM中的RCIMReceiveMessageDelegate监听音讯接管,而不要应用此监听器,否则会导致IMKit中无奈自动更新UI! */ @protocol RCIMClientReceiveMessageDelegate <NSObject> /*! 申请音讯已读回执(收到须要浏览时发送回执的申请,收到此申请后在会话页面曾经展现该 messageUId 对应的音讯或者调用 getHistoryMessages 获取音讯的时候,蕴含此 messageUId 的音讯,须要调用 sendMessageReadReceiptResponse 接口发送音讯浏览回执) @param messageUId 申请已读回执的音讯ID @param conversationType conversationType @param targetId targetId */ - (void)onMessageReceiptRequest:(RCConversationType)conversationType targetId:(NSString *)targetId messageUId:(NSString *)messageUId; ``` 在代理办法中,调用上面接口发送浏览回执响应给发送方 ```objective-c /*! 发送浏览回执 @param conversationType 会话类型 @param targetId 会话 ID @param messageList 曾经浏览了的音讯列表 @param successBlock 发送胜利的回调 @param errorBlock 发送失败的回调[nErrorCode: 失败的错误码] @discussion 当用户浏览了须要浏览回执的音讯,能够通过此接口发送浏览回执,音讯的发送方即可间接晓得那些人曾经浏览。 @remarks 高级性能 */ - (void)sendReadReceiptResponse:(RCConversationType)conversationType targetId:(NSString *)targetId messageList:(NSArray<RCMessage *> *)messageList success:(void (^)(void))successBlock error:(void (^)(RCErrorCode nErrorCode))errorBlock; ```
### 总结
浏览回执须要辨别会话类型解决,且单聊的浏览回执是针对会话的,群聊的浏览回执是针对某一条音讯的:
单聊:接管方浏览某个会话的音讯后,发送浏览回执 ——发送方接到浏览回执,更新 UI
群聊:发送方发送音讯 A, 针对该音讯,发送浏览回执申请 —— 接管方实现监听代理,接管到音讯 A 的浏览回执申请 —— 接管方发送浏览回执响应 —— 发送方收到浏览回执响应,更新 UI