HarmonyOS实战:腾讯IM之消息删除、撤回和重发(三)

本文涉及的产品
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
实时数仓Hologres,5000CU*H 100GB 3个月
实时计算 Flink 版,5000CU*H 3个月
简介: 本文详细介绍了鸿蒙 IM 聊天中实现消息撤回、删除和重发功能的方法。消息撤回支持在 120 秒内召回自己发送的消息,通过 `revokeMessage` 方法实现;消息删除使用 `deleteMessage` 方法清除本地与云端记录;消息重发则先删除失败消息再重新发送,并处理用户被拉黑的异常情况。结合状态管理,可轻松实现类似微信的功能,建议点赞收藏并动手实践!

前言

经过前面几篇文章的介绍,基本实现了鸿蒙 IM 聊天的功能,但是完整的腾讯 IM 不仅拥有发送文本的功能,还支持消息的失败重发,删除和撤回等相关功能,本篇文章将详细介绍如何实现这些功能,建议点赞收藏!

实现效果

需求分析

  • 支持消息撤回
  • 支持消息删除
  • 支持消息重发

技术实现

消息撤回

当用户发出 IM 消息后,需要支持在固定时间段内允许用户撤回已经发出的消息,这里默认为 120 秒,而且只允许自己发送的消息撤回。使用消息撤回功能需要调用revokeMessage 方法。

V2TIMManager.getMessageManager()
.revokeMessage(msg)
.then(() => {
      let index = this.messageData.getDataAll().indexOf(msg)
      this.messageData.deleteData(index)
      msg.status = V2TIMMessageStatus.V2TIM_MSG_STATUS_LOCAL_REVOKED
     this.messageData.addData(index, msg)
})
.catch((error: Error) => {
       });

通过调用接口传入被撤回的消息,撤回成功后,将该消息状态修改成撤回状态,列表根据消息状态显示提示语"您撤回了一条消息"。

消息删除

消息删除指删除用户已经发出过的消息记录,包括本地与云端消息,deleteMessage 方法可以实现消息删除,当消息删除接口回调成功后,再将消息从列表中删除即可。

let deleteMsg: Array<V2TIMMessage> = [msg]
V2TIMManager.getMessageManager().deleteMessages(deleteMsg).then(() => {
 let index = this.messageData.getDataAll().indexOf(msg)
 this.messageData.deleteData(index)
    console.log("删除消息--成功")
   }).catch((error: Error) => {
console.log("删除消息--失败")
})

消息重发

当遇到网络不好或者网络异常时,用户发送的消息会出现失败的情况,这个时候就需要重新发送消息。实现消息的重新发送时,需要先将失败的消息删除,然后重新发送,并插入到原来位置。

V2TIMManager.getMessageManager().deleteMessages([msg]).then(() => {
        }).catch((error: Error) => {
        })

这里先调用 deleteMessages 将失败的消息删除,然后发送新的消息,值得注意的是需要处理当前用户被对方拉黑的情况, 当用户被拉黑时,鸿蒙版的 IM 会直接抛出异常,需要处理拉黑情况。

V2TIMManager.getInstance().sendC2CTextMessage(msg.textElem?.text, 用户id)
.then((message: V2TIMMessage) => {
            this.messageData.pushData(message)
           
          }) .catch((error: TIMError) => {
            //用户被拉黑了
            if (error.code == 20007) {
              msg.status = V2TIMMessageStatus.V2TIM_MSG_STATUS_SEND_FAIL
              msg.msgID = "20007"
              this.messageData.pushData(msg)
            
            }
          });

总结

本篇文章详细的介绍里 鸿蒙版 IM 中实现消息时撤回,删除和重发等功能。特别是当重发时需要注意当前用户是否已经被拉黑,处理特定的 code 码。然后结合鸿蒙的状态管理很容易实现微信相同的功能,已经学会了的小伙伴,赶快动手试试吧!

目录
相关文章
|
25天前
|
缓存 自然语言处理 监控
基于通义大模型的智能客服系统构建实战:从模型微调到API部署
本文详细解析了基于通义大模型的智能客服系统构建全流程,涵盖数据准备、模型微调、性能优化及API部署等关键环节。通过实战案例与代码演示,展示了如何针对客服场景优化训练数据、高效微调大模型、解决部署中的延迟与并发问题,以及构建完整的API服务与监控体系。文章还探讨了性能优化进阶技术,如模型量化压缩和缓存策略,并提供了安全与合规实践建议。最终总结显示,微调后模型意图识别准确率提升14.3%,QPS从12.3提升至86.7,延迟降低74%。
255 14
|
1月前
|
定位技术 UED
70. [HarmonyOS NEXT 实战案例九] 旅游景点网格布局(下)
在上一篇教程中,我们学习了如何使用GridRow和GridCol组件实现基本的旅游景点网格布局。本篇教程将在此基础上,深入探讨如何优化布局、添加交互功能,以及实现更多高级特性,打造一个功能完善的旅游景点应用。
60 1
|
1月前
|
容器
69.[HarmonyOS NEXT 实战案例九] 旅游景点网格布局(上)
本教程将详细讲解如何使用HarmonyOS NEXT中的GridRow和GridCol组件实现旅游景点网格布局。通过网格布局,我们可以以美观、规整的方式展示各种旅游景点信息,为用户提供良好的浏览体验。
57 1
|
1月前
|
UED
68.[HarmonyOS NEXT 实战案例八] 电影票务网格布局(下)
在上一篇教程中,我们学习了如何使用GridRow和GridCol组件实现基本的电影票务网格布局。本篇教程将在此基础上,深入探讨如何优化布局、添加交互功能,以及实现更多高级特性,打造一个功能完善的电影票务应用。
55 1
|
1月前
|
开发者 容器
67.[HarmonyOS NEXT 实战案例八] 电影票务网格布局(上)
在移动应用开发中,电影票务应用是一个常见的场景,用户可以通过应用查看正在热映的电影信息,并进行选座购票等操作。本教程将详细讲解如何使用HarmonyOS NEXT的GridRow和GridCol组件实现电影票务应用中的电影列表网格布局,帮助开发者掌握网格布局的基本用法和实现技巧。
58 1
|
1月前
|
UED
66.[HarmonyOS NEXT 实战案例七] 健身课程网格布局(下)
在上一篇教程中,我们学习了如何使用GridRow和GridCol组件实现基本的健身课程网格布局。本篇教程将在此基础上,深入探讨如何优化布局、添加交互功能,以及实现更多高级特性,打造一个功能完善的健身课程应用。
59 1
|
1月前
|
设计模式 UED
65. [HarmonyOS NEXT 实战案例七] 健身课程网格布局(上)
本教程将介绍如何使用HarmonyOS NEXT的GridRow和GridCol组件实现健身课程的网格布局展示。健身课程网格布局是一种常见的UI设计模式,适用于展示各种健身课程信息,包括课程名称、教练信息、课程时长、难度级别等。通过网格布局,用户可以快速浏览多个课程,并根据自己的需求选择合适的课程。
59 1
|
1月前
|
设计模式 容器
61.[HarmonyOS NEXT 实战案例五] 社交应用照片墙网格布局(上)
社交应用中的照片墙是一种常见的UI设计模式,它以网格形式展示用户的照片集合,让用户可以浏览、分享和互动。本教程将详细讲解如何使用HarmonyOS NEXT的GridRow和GridCol组件实现一个美观、灵活的社交应用照片墙网格布局。 在本教程中,我们将学习如何设计照片墙的数据结构、如何使用GridRow和GridCol组件创建网格布局、如何实现照片卡片,以及如何处理不同尺寸的照片。通过本教程,你将掌握使用GridRow和GridCol组件实现复杂网格布局的技巧。
56 1
|
1月前
|
C++ 容器
57.[HarmonyOS NEXT 实战案例三] 音乐专辑网格展示(上)
HarmonyOS NEXT提供了强大的布局组件,其中GridRow和GridCol组件非常适合实现网格布局。在音乐应用中,专辑展示通常采用网格布局,以便用户可以直观地浏览各种音乐专辑。本教程将详细讲解如何使用GridRow和GridCol组件实现音乐专辑的网格展示布局。
61 1
|
1月前
64.[HarmonyOS NEXT 实战案例六] 餐饮菜单网格布局(下)
在上一篇教程中,我们学习了如何使用GridRow和GridCol组件实现基本的餐饮菜单网格布局。本篇教程将在此基础上,深入探讨如何优化布局、添加交互功能,以及实现更多高级特性,打造一个功能完善的餐饮菜单应用。
61 0