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

在前面分享的几篇中咱已经玩耍了PopupListBox多选Grid动态分RadioButton模板控件的拖放效果控件的置顶和置底控件的锁定自定义Window样式动画效果Expander控件ListBox折叠列表聊天窗口ListBox图片消息窗口抖动语音发送语音播放;今晚加个班来解决上一篇遗留的语音播放问题,先看Bug(多次播放语音动画失效):

be54e6970a3b0e4b223b12cc6629d33a.gif

解决后的效果:

b663ad342b7975e3100484443c1a17d6.gif

1、前台Rectangle的样式绑定:

<Rectangle Name="RecOverLayer" Margin="{Binding Role,Converter={StaticResource ChatRoleTypeToRectangleMarginConverter}}"
                   Width="35" Height="35"
                   Fill="{Binding Role,Converter={StaticResource ChatRoleTypeToRectangleFillConverter}}"
                   Classes.MyAnimation="{Binding IsStartPlay,Mode=TwoWay}">
    <Rectangle.Styles>
        <!--FillMode="None"-->
        <Style Selector="Rectangle.MyAnimation">
            <Style.Animations>
                <Animation Duration="0:0:1"
               IterationCount="{Binding Duration,Converter={StaticResource PlayDurationToIterationCountConverter}}"
               FillMode="None"
               PlaybackDirection="Reverse">
                    <KeyFrame Cue="100%">
                        <Setter Property="Margin" Value="0"/>
                    </KeyFrame>
                </Animation>
            </Style.Animations>
            </Style>
    </Rectangle.Styles>
</Rectangle>

2、后台播放的相关逻辑:

Task.Factory.StartNew(new System.Action(() =>
  {
      baseMessage.IsStartPlay = true;
      //去播放语音
      Playback.PlayVoice(path);
      //这里必须重新设置IsStartPlay = false
      //不然的话,下次点击的时候动画没效果
      baseMessage.IsStartPlay = false;
  }));

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值