WPF|C# Lottie 动画播放【感觉好牛】

网友投稿 883 2022-11-18

WPF|C# Lottie 动画播放【感觉好牛】

WPF|C# Lottie 动画播放【感觉好牛】

Lottie 动画是一种以 json 文件保存的动画文件. 相比 gif 在文件体积和动画流畅度上有很大的优势,而且是图形是矢量的,放大不会糊.

Lottie 的官方提供了web,android,iOS 的实现, 微软提供了 UWP 的实现 Lottie-Windows. WPF 则没有找到可用的实现.下有 sharpDx,不知道如何解决.

那么作为 WPF 开发者,想要使用 Lottie 动画看来还是要自己动手.

想要在 WPF 上使用 Lottie 动画,主要需要攻克以下问题:

解析 Lottie 的 json 文件,了解其中所有数据的意义,也就是得到需要绘制的图形对象,包括各种圆形,矩形,颜色,模糊效果,遮罩,缓动,轨迹,关键帧等.将上面得到的数据转换为具体的绘图参数.在 WPF 中进行高帧率的绘制.

截至2022-02-10,觉得可行的方案为:

微软提供的 UWP 的实现中,有现成的解析模块,可直接将 Json 文件读取为一个数据类,且该模块并没有依赖 UWP,所以可以直接拿来用.虽然还有一些 Bug(测试了几十个动画文件,有3个无法正常播放),但当前该库还比较活跃,可以期待其改进.SkiaSharp 的功能非常全面,覆盖 Lottie 动画所需的功能应该不成问题,而且其跨平台,所以按照数据要求使用 SkiaSharp 进行绘制即可.SkiaSharp 官方提供的 WPF 画布即使开启 GPU 绘图模式,其速度依然无法达到1080p 60帧,不过之前进行其它项目时对 GLWpfControl 进行了改进,实测 2k 144 帧占会用 RTX 2070 23%,达到可用程度,虽然有少量内存泄漏,但问题不大.

如果成功实现的话,应该可以同时支持  WinForm WPF UnoPlatform(GTK) Avalonia Blazor(Wasm) 以及所有 SkiaSharp 和 .Net Core 3.0+ 可以运行的平台上.

当前仍然处于探索验证阶段,无实用价值.

当前处于预览状态, 示例: lottie 特性

2022-02-10 选了几个简单的动画进行测试.

​​PolyStar 的数据解析,所以缺少黄色的星星,只能等待 Lottie-Windows 继续实现

路径动画.

​​PreCompLayer,LayerCollectionAsset

​​Lottie Viewer 提示需要 UAP11,我已经升级到 Windows10 21H2了 依然无法播放,不清楚具体原因.

​​(+模式)

​​https://lottiefiles.com/88967-food-delivery-service​​

蒙版(-模式)

​​https://lottiefiles.com/83667-arty-chat​​

​​https://lottiefiles.com/99804-backend-blue​​

遮罩(+模式)

​​https://lottiefiles.com/96957-lock​​

​​https://lottiefiles.com/89881-smiling-star​​

2020-04-01

​​https://lottiefiles.com/83395-addland-heatfav-v2​​

​​https://lottiefiles.com/96939-files​​

2022-04-17

​​https://lottiefiles.com/96245-success​​

​​https://lottiefiles.com/88282-rocket​​

​​https://github.com/CommunityToolkit/Lottie-Windows/files/8182417/Lottie.Animation.zip​​

​​https://lottiefiles.com/102516-growth​​

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Ubuntu18配置dns
下一篇:使用 C# 读取 zip 压缩包解压文件的方法及注意事项
相关文章

 发表评论

暂时没有评论,来抢沙发吧~