Flutter Reusable Lottie Animations技巧
正文
你是否想要在app里面新增一些炫酷的动画,但是呢?虽然Flutter提供了很多的动画,但是自己绘制吧,要么效果调整上过于耗费时间了,要么效果不尽人意。
专业的事情交给专业的人,如果动画是设计师提供并且能拿来使用,那就太好了!!!
曾经使用过gif,现在发现lottie动画,太香了~
封装相关加载数据使用的lottie动画
下面是我封装的有关加载数据使用的lottie动画
用关键值在枚举中定义动画,每个值都是磁盘上动画文件的名字。
enum LottieAnimation { dataNotFound(name: 'data_not_found'), empty(name: 'empty'), loading(mame: 'loading'), error(name: 'error'), smallError(name: 'small_error'); final String name; const LottieAnimation({ required this.name, }); }
创建一个基类,所有其他动画类都从该基类派生。这个类完全负责使用磁盘上的assets来呈现lottie动画。
在build方法里面,我们通过Lottie.asset返回一个实际的小部件。
class LottieAnimationView extends StatelessWidget { final LottieAnimation animation; final bool repeat; final bool reverse; const LottieAnimationView({ super.key, required this.animation, this.repeat = true, this.reverse = false, }); @override Widget build(BuildContext context) => Lottie.asset( animation.fullPath, reverse: reverse, repeat: repeat, ); }
给LottieAnimation增加一个拓展,获取文件全路径
extension GetFullPath on LottieAnimation { String get fullPath => 'assets/animationss/$name.json'; }
然后定义子类,只把lottie动画的名字传递给父类,你就可以开始是了!
class EmptyContentsAnimationView extends LottieAnimationView { const EmptyContentssAnimationView({super.key}) : super( animation: LottieAnimation.empty, ); }
测试一下
class HomePage extends StatelessWidget { const HomePage({Key? key}) : super(key: key); @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: const Text('Home Page'), ), body: const EmptyCOntentsAnimationView(), ); } }
搞定,接下来我得研究研究 如何制作一个lottie动画了,更多关于Flutter Lottie Animations的资料请关注脚本之家其它相关文章!
相关文章
Android打开GPS导航并获取位置信息返回null解决方案
最近在做一个 Android 项目,需要用到GPS获取位置信息,从 API 查了一下,发现获取位置信息仅需极其简单的一句即可getLastKnownLocation(LocationManager.GPS_PROVIDER)郁闷的是一直为null,于是搜集整理下,晒出来与大家分享2013-01-01Android WebView开发之自定义WebView工具框
在WebView页面长按时会弹出一个复制框,有的时候里面的item不是我们想要,这个时候我们就可以自定义一个工具框。本文就将介绍如何通过WebView自定义工具框,需要的朋友可以参考一下2021-12-12Android实现EventBus登录界面与传值(粘性事件)
这篇文章主要为大家详细介绍了Android实现EventBus登录界面与传值,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-11-11
最新评论