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

Posted dotNET跨平台

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Avalonia跨平台入门第十五篇之ListBox聊天窗口相关的知识,希望对你有一定的参考价值。

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


先来看看布局吧:

ListBoxItem样式:

自定义消息控件的后台:

自定义消息控件的样式:

ListBox的子项模板:

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

后台模拟生成的数据:

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

以上是关于Avalonia跨平台入门第十五篇之ListBox聊天窗口的主要内容,如果未能解决你的问题,请参考以下文章

Avalonia跨平台入门第八篇之控件的拖放

Avalonia跨平台入门第二十三篇之滚动字幕

Avalonia跨平台入门第二十二篇之人脸检测

Avalonia跨平台入门第二十篇之语音播放问题

Avalonia跨平台入门第二十一篇之玩耍CEF

Avalonia跨平台入门第六篇之Grid动态分割