Avalonia跨平台入门第十五篇之ListBox聊天窗口

本文介绍了如何使用WPF实现一个基于ListBox的聊天窗口效果,包括ListBoxItem样式、自定义消息控件的后台和样式、数据模板等。通过后台模拟生成的数据,展示了简单的文本消息展示,并鼓励读者尝试更复杂的效果。分享了编程过程中的乐趣和挑战,邀请读者提出建议和想法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在前面分享的几篇中咱已经玩耍了PopupListBox多选Grid动态分RadioButton模板控件的拖放效果控件的置顶和置底控件的锁定自定义Window样式动画效果Expander控件ListBox折叠列表;今天趁着大周末的时间接着去摸索基于ListBox的聊天窗口的效果,最终实现的效果如下图:

08df6e78191e9573be92beba4cd2c546.gif

先来看看布局吧:

c50fad1a95ccc5a11b14238db59e5a0a.png

ListBoxItem样式:

ae61cc1bc8e014f33e23f6ecba52a5d7.png

自定义消息控件的后台:

52e05cff80c1e16475ffb66dc828ce6a.png

自定义消息控件的样式:

0f0e4c924b5e451961d8e1cd8c48d070.png

ListBox的子项模板:

<!--文本消息-->
<DataTemplate DataType="Models:TextMessage">
  <Controls:ChatBubble IsRead="{Binding IsRead}" Role="{Binding Role}">
    <TextBlock Text="{Binding Content}" TextWrapping="Wrap" />
  </Controls:ChatBubble>
</DataTemplate>

后台模拟生成的数据:

08aa3273a89dd19c3d012a31c0bb5ea8.png

最终简单的效果先这样吧19c7ac766518b3759f54117af589aa86.png;以后有时间的话,可以再去摸索一下更复杂的效果a77aa3603e42ada6d8f19d6e75e20fc0.png;编程不息、Bug不止、无Bug、无生活1d1d5e0fec1d681edf2d8df170a7594b.png;改bug的冷静、编码的激情、完成后的喜悦、挖坑的激动 、填坑的兴奋;这也许就是屌丝程序员的乐趣吧;今天就到这里吧;希望自己有动力一步一步坚持下去;生命不息,代码不止;大家抽空可以看看今天分享的效果,有好的意见和想法,可以在留言板随意留言;我看到后会第一时间回复大家,多谢大家的一直默默的关注和支持!如果觉得不错,那就伸出您的小手点个赞并关注一下,多谢您的支持!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值