AntdUI教程#1ChatList交互(vb.net)

本教程主要是针对ChatList的扩展功能:比如高亮选择消息、删除高亮消息等Demo没有的功能,并且最新的2.3.1作者更新了ScrollBar的bug这就香了

ChatList支持文字、图片、还有流生成模式,本教程主要为ChatList的交互扩展

全局变量声明:

vbnet 复制代码
Dim ID As Long
Dim rects As New List(Of Rectangle)
Dim ids As New List(Of Long)

1、我方、对方发送消息(部分摘自Demo)

对方:

vbnet 复制代码
Dim tci As New AntdUI.Chat.TextChatItem("你好!最近怎么样?", Image.FromFile("D:\AE素材\yu.jpg"), "朋友")
tci.SetID(ID)
tci.SetTime(Date.Now)
Chat.AddToBottom(tci)
ID += 1

我方:

vbnet 复制代码
Dim tci As New AntdUI.Chat.TextChatItem("还不错,项目进展顺利 🚀", Image.FromFile("D:\AE素材\yu.jpg"), "我")
tci.SetMe(True)
tci.SetID(ID)
tci.SetTime(Date.Now)
Chat.AddToBottom(tci)
ID += 1

注意到我方有SetMe的一个方法,并且有注意到每一个对话都设置了一个ID ,由于ID上限不详细,因此ID的类型为Long长整型

2、模拟加载历史信息,类似微信或者QQ的加载历史消息

Chat List与普通List相似,可以在指定Index插入值或一段值

vbnet 复制代码
 Dim OldChatList As New List(Of TextChatItem)
 For i = 0 To 9
     Dim tci As New TextChatItem("这是补充的文字", Image.FromFile("D:\AE素材\yu.jpg"), "我")
     tci.SetID(ID)
     OldChatList.Add(tci)
     ID += 1
 Next
 Chat.Items.InsertRange(0, OldChatList.ToArray)

3、高亮选择

由于Chat List并没有提供SelectedItem方法,但是在ChatList内部有一个事件为Chat.ItemClick,可以精准定位点击的对象,而且Chat List没有给出ContextMenuStrip的空位,那么就直接写在item点击事件中

vbnet 复制代码
Private Sub Chat_ItemClick(sender As Object, e As ChatItemEventArgs) Handles Chat.ItemClick

    Select Case e.Button
        Case MouseButtons.Left
            Dim tci As TextChatItem = e.Item
            Dim rect As Rectangle = tci.rect

            If rects.Contains(rect) Or ids.Contains(tci.ID) Then
                rects.Remove(rect)
                ids.Remove(tci.ID)
            Else
                rects.Add(rect)
                ids.Add(tci.ID)
            End If
        Case MouseButtons.Right
            ContextMenu.Show(Chat, e.Location)
    End Select

End Sub

为了高亮显示和兼容滚动条的滑动我们还需要获取滚动条的ValueY

我们在ChatList的Paint事件里面重绘:

vbnet 复制代码
Private Sub Chat_Paint(sender As Object, e As PaintEventArgs) Handles Chat.Paint
    Dim g = e.Graphics
    For Each rect In rects
        rect.Location = New Point(rect.Location.X, rect.Location.Y - Chat.ScrollBar.ValueY)
        g.FillRectangle(New SolidBrush(Color.FromArgb(128, 255, 0, 0)), rect)
        g.DrawRectangle(New Pen(Color.FromArgb(255, 0, 0)), rect)
    Next
End Sub

其中:

vbnet 复制代码
New Point(rect.Location.X, rect.Location.Y - Chat.ScrollBar.ValueY)

在滚动滚动条时可以跟着项目位置一起绘制,而不至于导致绘制错位

4、删除高亮对话

vbnet 复制代码
Private Sub Button6_Click(sender As Object, e As EventArgs) Handles Button6.Click
    Chat.SuspendLayout()

    For Each itm As TextChatItem In Chat.Items.Cast(Of TextChatItem).ToList()
        If ids.Contains(itm.ID) Then
            Chat.Items.Remove(itm)
        End If
    Next

    Chat.ResumeLayout()

    rects.Clear()
    ids.Clear()
End Sub

这里解释一下为什么要使用,因为一次性删除多个会导致一直处于重新绘制状态导致资源消耗卡顿

vbnet 复制代码
Chat.SuspendLayout()
'''

'''
Chat.ResumeLayout()

这里解释一下为什么不直接操作源列表,因为操作了源列表会导致移除数据错乱,即Index错位

故使用一个影子列表,这样在遍历的过程中不会影响到源数据的区域(这样解释不知道大家懂不懂):

vbnet 复制代码
Chat.Items.Cast(Of TextChatItem).ToList()

在遍历list时直接按 index 删除元素,会导致 后面的元素 index 变化,所以删除结果不对。

5、插入图片

ChatList采用的是Base64图片的方法

vbnet 复制代码
Private Sub Button5_Click(sender As Object, e As EventArgs) Handles Button5.Click
    Dim tci As New AntdUI.Chat.TextChatItem("这是图片" & GetImageString("C:\Users\Administrator\Pictures\屏幕截图 2026-03-05 224508.png"), Image.FromFile("D:\AE素材\yu.jpg"), "我")
    tci.SetMe(True)
    tci.SetID(ID)
    tci.SetTime(Date.Now)
    ID += 1
    Chat.AddToBottom(tci)
End Sub

Function GetImageString(path As String) As String
    Return "data:image/png;base64," & Convert.ToBase64String(File.ReadAllBytes(path))
End Function

交互效果图:

相关推荐
LinXunFeng5 小时前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
乘风gg9 小时前
为什么AI 时代来临,大部分人吃不到红利
前端·ai编程·claude
恋猫de小郭10 小时前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
IT_陈寒10 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
恋猫de小郭10 小时前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
Hyyy11 小时前
理解LLM的基本工作原理:预训练、微调、推理的区别
前端
Gatlin11 小时前
前端逆向与反逆向:一场猫鼠游戏的底层逻辑与实战
前端
Pedantic12 小时前
本地通知(Local Notifications)学习笔记
前端
森蓝情丶12 小时前
我给 AI 搭了个法庭:一个前端仔的 LangGraph 实战全记录
前端·后端
爱勇宝12 小时前
干了近 8 年,一夜之间被裁:AI 时代,程序员最该害怕的不是 AI
前端·后端·程序员