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

前言

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

实现效果

需求分析

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

技术实现

消息撤回

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

javascript 复制代码
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 方法可以实现消息删除,当消息删除接口回调成功后,再将消息从列表中删除即可。

javascript 复制代码
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("删除消息--失败")
})

消息重发

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

javascript 复制代码
        V2TIMManager.getMessageManager().deleteMessages([msg]).then(() => {
        }).catch((error: Error) => {
        })

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

ini 复制代码
 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 码。然后结合鸿蒙的状态管理很容易实现微信相同的功能,已经学会了的小伙伴,赶快动手试试吧!

相关推荐
anyup17 小时前
🔥2026最推荐的跨平台方案:H5/小程序/App/鸿蒙,一套代码搞定
前端·uni-app·harmonyos
Ranger09291 天前
鸿蒙开发新范式:Gpui
rust·harmonyos
Huang兄1 天前
鸿蒙-深色模式适配
harmonyos·arkts·arkui
SummerKaze3 天前
为鸿蒙开发者写一个 nvm:hmvm 的设计与实现
harmonyos
在人间耕耘5 天前
HarmonyOS Vision Kit 视觉AI实战:把官方 Demo 改造成一套能长期复用的组件库
人工智能·深度学习·harmonyos
王码码20355 天前
Flutter for OpenHarmony:socket_io_client 实时通信的事实标准(Node.js 后端的最佳拍档) 深度解析与鸿蒙适配指南
android·flutter·ui·华为·node.js·harmonyos
HarmonyOS_SDK5 天前
【FAQ】HarmonyOS SDK 闭源开放能力 — Ads Kit
harmonyos
Swift社区5 天前
如何利用 ArkUI 框架优化鸿蒙应用的渲染性能
华为·harmonyos
特立独行的猫a5 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS影视票房榜组件完整实现过程
华为·uni-app·harmonyos·轮播图·uniapp-x
盐焗西兰花5 天前
鸿蒙学习实战之路-STG系列(5/11)-守护策略管理-添加与修改策略
服务器·学习·harmonyos