思路如下:
阅后即焚,是指对方查看你发的消息后,双方同时删除。
这个功能可以用环信的“已读”回调实现,当对方查看消息后,发送已读通知,双方同时删除就可以了。
我在文字消息里面添加了阅后即焚
message.messageType = eMessageTypeChat;
message.ext = @{@"fire":@YES};
在- (void)didReceiveHasReadResponse:(EMReceipt *)receipt这个方法里面进行判断,代码如下
self.conversation = [[EaseMob sharedInstance].chatManager conversationForChatter:receipt.conversationChatter conversationType:eConversationTypeChat];
EMMessage *message = [self.conversation loadMessageWithId:receipt.chatId];
if ([message.ext[@"fire"] boolValue]) {
//如果是阅后即焚消息,删除本地并更新UI
[self.conversation removeMessage:message];
[self.conversation removeMessageWithId:message.messageId];
self.dataArray = [[self formatMessages:self.messsagesSource] mutableCopy];
[self.tableView reloadData];
}
现在遇到的问题是判断是阅后即焚的消息后,删除会话里面的message,tableview reload并没有把该条消息删掉,关掉对话框从新进来,该条消息被删除了
方法二:
可以通过消息扩展配合已读回执进行实现。
流程如下:
A-->B 发送阅后即焚消息:
首先,如果是阅后即焚消息,需要在消息中标明,该消息是阅后即焚,这个时候,
用到了EMMessage的ext属性,
NSMutableDictionary *fireDict = [NSMutableDictionary dictionary];
message.ext = [NSDictionary
dictionaryWithObject:[NSNumber numberWithBool:YES]
forKey:@"isFire"];
[fireDict setObject:message forKey:message.messageId];
[[EaseMob sharedInstance].chatManager asyncSendMessage:message progress:nil];
到此,A构建了一个带有ext的message,其中带有isFire的key,并且将其发出给B。
同时,我本地维护了一个dict,里面的key为messageID,value为阅后即焚的message
当B实现了IChatManagerDelegate委托,会调用回调方法,收到A发来的消息
B收到消息:
-(void)didReceiveMessage:(EMMessage *)message{
// 此时收到了A发来的消息,这个时候,我们需要对这个消息进行分析,看它是否是阅后即焚的消息
BOOL isFire = [[message.ext objectForKey:@"isFire"] boolValue];
到目前为止,可以判断B收到的消息是否为阅后即焚消息。
之后的逻辑如下
如果该消息为阅后即焚,在B看过这条消息后,调用
- (void)sendHasReadResponseForMessage:(EMMessage *)message;方法,向A发送“已读”
如A实现IChatManagerDelegate委托,会调用方法:
- (void)didReceiveHasReadResponse:(EMReceiptResp *)resp;
具体处理如下,
A收到消息后:从我们的fireDict中,通过id,查找该message是否存在
EMMessage *message = [fireDict objectForKey:resp.chatId];
此时如果存在,说明该消息是阅后即焚,且B已读。
接下来就是ui处理和db处理,
EMConversation *conversation = [[EaseMob sharedInstance].chatManager
conversationForChatter:resp.from
isGroup:NO]; // 因为只有单聊中存在阅后即焚,所以isGroup始终为NO
通过resp.from 来查到message对应的conversation,
[conversation removeMessage:resp.chatId];
然后调用删除message的接口把它删掉,之后处理ui上的删除。
此时,阅后即焚功能就已经完成。