前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Avalonia 后台代码简单播放动画示例

Avalonia 后台代码简单播放动画示例

作者头像
林德熙
发布2024-08-20 11:14:42
690
发布2024-08-20 11:14:42
举报
文章被收录于专栏:林德熙的博客

本文将演示如何在 Avalonia 的后台代码里面创建 Animation 执行播放

本文演示的内容是将界面里面的一个 TextBlock 控件,通过修改控件的 RenderTransform 的 TranslateTransform 执行平移

为了方便演示,先在 MainView.axaml 里面添加一个 TextBlock 控件,如下面代码。大家可以在本文末尾找到本文所有的代码的下载方法

代码语言:javascript
复制
  <TextBlock Text="{Binding Greeting}" HorizontalAlignment="Center" VerticalAlignment="Center">
      <TextBlock.RenderTransform>
          <TranslateTransform X="700"/>
      </TextBlock.RenderTransform>
  </TextBlock>

接下来演示如何在后台代码里面创建动画和播放动画

演示的代码放在 Loaded 事件里面,强行使用 Task.Delay 模拟业务的延迟。当然了,如果只是动画本身期望延迟,可以使用 Animation 的 Delay 属性执行延迟

代码语言:javascript
复制
public partial class MainView : UserControl
{
    public MainView()
    {
        InitializeComponent();

        Loaded += MainView_Loaded;
    }

    private async void MainView_Loaded(object? sender, Avalonia.Interactivity.RoutedEventArgs e)
    {
        // 这里的延迟换成 Animation 的 Delay 也对的,且换成 Animation 的更好。这里的延迟非必须
        await Task.Delay(100);

        ... // 忽略其他代码
    }

先创建 Animation 对象,设置动画的过程时间,如下面代码所示

代码语言:javascript
复制
        var animation = new Animation()
        {
            Duration = TimeSpan.FromSeconds(10),
            ... // 忽略其他代码
        };

接着添加核心的逻辑,通过关键帧动画,设置 TranslateTransform 的 XProperty 在第 0 秒的时候从 0 开始,在第 10 秒的时候为 500d 的值。如此即可作出平缓的动画,实现 TranslateTransform 的 X 从 0 移动到 500 的值,且过程动画用 10 秒

代码语言:javascript
复制
        var animation = new Animation()
        {
            Duration = TimeSpan.FromSeconds(10),
            IterationCount = new IterationCount(5),
            PlaybackDirection = PlaybackDirection.Alternate,
            Children =
            {
                new KeyFrame()
                {
                    Setters =
                    {
                        new Setter(TranslateTransform.XProperty, 0d),
                    },
                    KeyTime = TimeSpan.FromSeconds(0)
                },
                new KeyFrame()
                {
                    Setters =
                    {
                        new Setter(TranslateTransform.XProperty, 500d),
                    },
                    KeyTime = TimeSpan.FromSeconds(10)
                }
            }
        };

这里需要小心一个细节,那就是 XProperty 是定义了 double 类型的属性,要求传入的参数也是 double 类型的。如果这里没有写 0d 而是写 0 将会在后续播放动画步骤啥都没有发生。我认为这里是 Avalonia 的一个设计缺陷,应该在框架层做好转换类型逻辑

完成动画定义之后,现在动画还没附加在某个控件进行播放,咱就从用户控件里面获取刚才界面定义的控件,例子代码如下

代码语言:javascript
复制
        var content = Content;
        var textBlock = (TextBlock)content!;

拿到控件之后,使用 Animation 的 RunAsync 方法进行播放,这个方法可以不等待返回值。只有在期望等待到动画播放结束的时候,才需要等待返回值的 Task 完成

在 Avalonia 里面存在一个设计缺陷是没有提供和 WPF 一样的故事板,如果有多个控件同时播放动画只好多次调用 RunAsync 方法,且多次调用之间不要加上 await 等待

代码语言:javascript
复制
        _ = animation.RunAsync(textBlock);

全部的后台创建和播放动画代码如下

代码语言:javascript
复制
        var content = Content;
        var textBlock = (TextBlock)content!;

        var animation = new Animation()
        {
            Duration = TimeSpan.FromSeconds(10),
            IterationCount = new IterationCount(5),
            PlaybackDirection = PlaybackDirection.Alternate,
            Children =
            {
                new KeyFrame()
                {
                    Setters =
                    {
                        new Setter(TranslateTransform.XProperty, 0d),
                    },
                    KeyTime = TimeSpan.FromSeconds(0)
                },
                new KeyFrame()
                {
                    Setters =
                    {
                        new Setter(TranslateTransform.XProperty, 500d),
                    },
                    KeyTime = TimeSpan.FromSeconds(10)
                }
            }
        };

        _ = animation.RunAsync(textBlock);

本文代码放在 githubgitee 上,可以使用如下命令行拉取代码。我整个代码仓库比较庞大,使用以下命令行可以进行部分拉取,拉取速度比较快

先创建一个空文件夹,接着使用命令行 cd 命令进入此空文件夹,在命令行里面输入以下代码,即可获取到本文的代码

代码语言:javascript
复制
git init
git remote add origin https://gitee.com/lindexi/lindexi_gd.git
git pull origin 77ef3ad873b021c71c80ca08cfbff5cadda5e3fc

以上使用的是国内的 gitee 的源,如果 gitee 不能访问,请替换为 github 的源。请在命令行继续输入以下代码,将 gitee 源换成 github 源进行拉取代码。如果依然拉取不到代码,可以发邮件向我要代码

代码语言:javascript
复制
git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git
git pull origin 77ef3ad873b021c71c80ca08cfbff5cadda5e3fc

获取代码之后,进入 AvaloniaIDemo/QarnahedajaceYawemcehem 文件夹,即可获取到源代码

更多 AvaloniaI 博客,请参阅 博客导航

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档