HarmonyOS实战:腾讯IM之聊天列表搭建(一)

本文涉及的产品
RDS DuckDB + QuickBI 企业套餐,8核32GB + QuickBI 专业版
简介: 本文详细介绍了在鸿蒙系统中实现腾讯IM聊天列表页面的过程。由于腾讯仅提供了接口而无现成UI,需自行开发。文章涵盖需求分析(如删除功能、时间排序、消息更新)、技术实现(展示会话列表、新增会话、删除会话)等内容,并附代码示例。最终实现了类似微信的聊天列表功能,建议点赞收藏以便后续参考。

前言

因日常工作需要使用鸿蒙版腾讯 IM 聊天功能,但是腾讯 IM 只提供了相关接口,并没有像安卓和 iOS 一样提供配套的 UI 页面。这点不得不吐槽一下腾讯,作为互联网巨头鸿蒙开发进度怎么就这么慢,没办法只能对比着微信自己一点点去实现相关功能,本篇文章将详细介绍聊天列表页面的搭建过程,建议点赞收藏!

实现效果

先看本文的最终实现效果如下:

需求分析

  • 支持删除功能。
  • 支持按照收到消息的时间排序。
  • 支持消息更新及插入新消息。

技术实现

展示会话列表

  1. 首先获取默认会话列表,这里根据 IM 的 SDK 提供的方法,调用 V2TIMManager.getConversationManager获取默认会话列表数据。
V2TIMManager.getConversationManager()
      .getConversationListByFilter(this.page, this.pageSize)
      .then((result: V2TIMConversationResult) => {
        
      })
  1. 得到默认会话列表数据后,需要将实现一个 List 列表展示会话列表,这里需要注意 keyGenerator 的定义。
List() {
      LazyForEach(this.dateSource, (item: V2TIMConversation, index: number) => {
        ListItem() {
          this.ItemLayout(item)
        }.swipeAction({
          end: {
            builder: () => {
              this.DeleteView(index, () => {
                this.deleteDialog.open()
              })
            }
          }
        })
      }, (item: V2TIMConversation, index: number) => index + ""+ (item!=undefined&& item.lastMessage!=undefined &&item.lastMessage.timestamp !=undefined?item.lastMessage.timestamp:""))
    }

lazyForEach 中的 keyGenerator 必须使用消息里面的时间戳作为唯一的键值,否则会报错。swipeAction 是侧滑删除功能。

新增会话

当收新联系人发来的信息或已经在列表中的联系人发来的信息时,需要将联系人插入到消息列表头部。

  1. 首先增加实时会话监听,使用ConversationTestInterfaces.addConversationListener 监听实时会话。
/**
   * 会话监听
   */
  conversationListener: V2TIMConversationListener = {
    onConversationChanged: (conversationList: V2TIMConversation[]) => {
       //实时会话
    
    },
  };
ConversationTestInterfaces.addConversationListener(this.conversationListener)
  1. 首先需要对实时收到的会话进行过滤,判断新收到的会话是否已经存在在列表中,如果存在则将会话插入到列表头部,如果已经存在则需要将会话移动到列表头部。
let newList = this.dateSource.getDataAll().filter((item, index) => {
        return conversationList[0].conversationID == item.conversationID
      })
  1. 对得到的实时会话列表进行筛选,以conversationID 作为匹配条件。如果新收到的会话不存在,则将会话插入列表中。
this.dateSource.pushData(conversationList[0])
  1. 如果新收到的会话已经存在,则需要将新的会话插入到列表头部,这里先删除旧的会话数据,然后将新的会话数据插入列表中。
let index = this.dateSource.getDataAll().indexOf(newList[0])
  this.dateSource.deleteData(index)
  this.dateSource.pushData(conversationList[0])
  1. 新的会话数据插入列表后,数据并没有位于列表头部,最后需要对数据进行排序即可,这里以会话时间作为比较。
if (this.dateSource.getDataAll().length > 1) {
        this.dateSource.getDataAll().sort((a, b) => (b!=undefined&& b.lastMessage!=undefined && b.lastMessage.timestamp!=undefined?b.lastMessage.timestamp:0 ) - (a!=undefined&& a.lastMessage!=undefined && a.lastMessage.timestamp!=undefined?a.lastMessage.timestamp:0 ))
      }

删除会话

会话删除就比较简单了,直接根据会话 ID 进行删除即可。

V2TIMManager.getConversationManager()
            .deleteConversation(conversation.conversationID)
            .then(() => {
               //更新列表
            })
            .catch((error: Error) => {
            });

总结

腾讯 IM 功能十分复杂,本篇文章仅仅实现了会话列表功能,所有代码逻辑都需要自己动手处理,鸿蒙版的 IM SDK 只提供了接口,所以在实际实现过程中肯定会遇到很多问题需要自己克服,最终实现和微信相同的功能。下篇文章开始搭建聊天详情功能,需要接入鸿蒙 IM 的小伙伴赶紧收藏起来吧 !

目录
相关文章
|
存储 UED 开发者
30.[HarmonyOS NEXT Column案例八(上)] 构建现代聊天界面:层叠布局与消息列表的实现
在HarmonyOS NEXT应用开发中,聊天界面是一种常见且复杂的界面类型,它需要展示消息列表、输入区域以及各种交互元素。本教程将详细讲解如何使用Column组件作为主容器,结合Stack组件实现层叠布局,创建一个现代化的聊天界面。通过ChatPage组件的实际案例,我们将展示如何构建包含消息列表和输入区域的复合布局,帮助开发者掌握复杂布局的实现技巧。
207 5
|
前端开发 JavaScript 网络安全
Web网页端即时通讯源码/IM聊天源码RainbowChat-Web
RainbowChat-Web是一套基于MobileIMSDK-Web的网页端IM系统。不同于市面上某些开源练手或淘宝售卖的demo级代码,RainbowChat-Web的产品级代码演化自真正运营过的商业产品,其所依赖的通信层核心SDK已在数年内经过大量客户及其辐射的最终用户的使用和验证。RainbowChat-Web同时也是移动端IM应用RainbowChat的姊妹产品。
433 0
|
容器
49.[HarmonyOS NEXT RelativeContainer案例六] 智能屏障布局:打造自适应聊天气泡界面
在现代移动应用开发中,聊天界面是最常见的交互场景之一。一个优秀的聊天界面需要能够适应不同长度的消息内容,保持布局的一致性和美观性。HarmonyOS NEXT的RelativeContainer组件提供了强大的屏障(Barrier)功能,能够根据内容动态调整布局,非常适合实现聊天气泡这类需要自适应内容边界的UI元素。本教程将详细讲解如何利用RelativeContainer的屏障功能实现一个自适应的聊天气泡界面。
285 70
HarmonyOS实战:腾讯IM之消息删除、撤回和重发(三)
本文详细介绍了鸿蒙 IM 聊天中实现消息撤回、删除和重发功能的方法。消息撤回支持在 120 秒内召回自己发送的消息,通过 `revokeMessage` 方法实现;消息删除使用 `deleteMessage` 方法清除本地与云端记录;消息重发则先删除失败消息再重新发送,并处理用户被拉黑的异常情况。结合状态管理,可轻松实现类似微信的功能,建议点赞收藏并动手实践!
613 3
HarmonyOS实战:腾讯IM之消息删除、撤回和重发(三)
|
数据库 UED 索引
129. [HarmonyOS NEXT 实战案例四:SideBarContainer] 侧边栏容器实战:音乐播放器侧边栏 - 播放列表与歌单管理 基础篇
在现代音乐播放器应用中,侧边栏是展示播放列表和歌单的重要界面元素。通过HarmonyOS NEXT的`SideBarContainer`组件,我们可以轻松实现一个功能完善的音乐播放器侧边栏,为用户提供流畅的音乐浏览和播放体验。
222 5
|
数据可视化 UED 容器
130. [HarmonyOS NEXT 实战案例四:SideBarContainer] 侧边栏容器实战:音乐播放器侧边栏 - 播放列表与歌单管理 进阶篇
在基础篇中,我们学习了如何使用HarmonyOS NEXT的`SideBarContainer`组件创建音乐播放器的基本侧边栏布局。本篇教程将深入探讨如何为音乐播放器添加更多交互功能和状态管理,提升用户体验。
299 4
|
11月前
|
人工智能 自然语言处理 监控
生成式AI客服实战:智能客服机器人5大自动化能力处理80%高频咨询,释放60%客服人力
生成式AI驱动的智能客服机器人通过五大核心能力自动化处理80%高频咨询,释放60%客服人力。以合力亿捷方案为例,融合大模型与业务知识图谱,实现服务精准化、决策智能化,推动企业服务成本下降超40%。
813 0