【Flutter 专题】131 图解 AnimatedList 动画列表
小菜在使用列表加载数据项时,为了提高用户浏览体验,在增加删除 Item 项时适当增加一点小动画,于是小菜通过 AnimatedList 简单尝试一下;
AnimatedList
源码分析
AnimatedList 作为可以在子 Item 数据发生变化时提供简单过渡动画的一类 List;通过 AnimatedListState 用于动态的增加或删除 Item;提供了 itemBuilder & initialItemCount 与 ListView.builder 方式类似;
简单分析源码可得,AnimatedListState 已混入 TickerProviderStateMixin,因此我们的开发的 Page 页可以略去状态混入,可以通过 insertItem & removeItem 为数据增删时调整过渡动画;
案例尝试
1. itemBuilder & initialItemCount
AnimatedList 通过 Builder 方式构建的一个优势就是列表项仅在滚动到视图内时才会构建;而 AnimatedListState 需要 GlobalKey 用于与列表交互的媒介,小菜理解每个 Item 都是单独区分开的;小菜先尝试一个 FadeTransition 淡入淡出动画效果;
其中在增加和删除 Item 时通过 AnimatedListState 提供的方法进行操作,并非直接对 AnimatedList 数据进行的更新,需要手动更新;
2. reverse & primary & physics
AnimatedList 与 ListView.builder 方式基本一致,但需要注意的是,不管是 ListView 还是 AnimatedList 默认都是会填充整个布局,在设置 reverse 时会发现是从屏幕最底部作为起始位的;
3. animation
AnimatedList 的过度动画是通过 AnimatedListItemBuilder 构造器中提供的 Animation<double> 来进行构建的,默认时常是 300ms,小菜多尝试一下其他的过渡动画;
3.1 SlideTransition -> 左入左出
3.2 SlideTransition & SizeTransition -> 上入上出 & 尺寸渐变
3.3 SlideTransition & SizeTransition & FadeTransition -> 上入上出 & 尺寸 & 透明度渐变
小菜对 AnimatedList 的尝试还很少,主要尝试了过渡渐变的小动画;如有错误,请多多指导!
来源: 阿策小和尚
版权声明: 本文为 InfoQ 作者【阿策小和尚】的原创文章。
原文链接:【http://xie.infoq.cn/article/87da11916baa082b98e2c2701】。文章转载请联系作者。
评论