Flutter:AnimatedSwitcher当子元素改变时,触发动画

devtools/2024/11/23 20:53:24/
AnimatedSwitcher中的子元素
由:CircularProgressIndicator()
改变为:Image.network('https://cdn.uviewui.com/uview/swiper/1.jpg')
则会触发动画
class _MyHomePageState extends State<MyHomePage> {bool flag = true;@overrideWidget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('标题'),),body: Center(child: Container(alignment: Alignment.center,width: 400,height: 200,color: Colors.yellowAccent,child: AnimatedSwitcher(duration: const Duration(milliseconds: 500),child: flag ? const CircularProgressIndicator() : Image.network('https://cdn.uviewui.com/uview/swiper/1.jpg'),),),),floatingActionButton: FloatingActionButton(onPressed: (){flag = !flag;setState(() {});},child: const Icon(Icons.add),),);}
}

在这里插入图片描述

AnimatedSwitcher中通过添加transitionBuilder修改动画效果

// 添加1个缩放动画
child: AnimatedSwitcher(
transitionBuilder:((child, animation){ // 改变动画效果return ScaleTransition( // 缩放scale: animation,child: child,);}),duration: const Duration(milliseconds: 500),child: flag ? const CircularProgressIndicator() : Image.network('https://cdn.uviewui.com/uview/swiper/1.jpg'),
),// 动画也可以叠加使用,在添加一个淡入淡出
child: AnimatedSwitcher(transitionBuilder:((child, animation){ // 改变动画效果return ScaleTransition( // 缩放scale: animation,child: FadeTransition(opacity: animation,child: child,), // 淡入淡出);}),duration: const Duration(milliseconds: 500),child: flag ? const CircularProgressIndicator() : Image.network('https://cdn.uviewui.com/uview/swiper/1.jpg'),
),

在这里插入图片描述

AnimatedSwitcher里如果是改变同样的组件,如何触发动画

// 相同组件,只是内容更换,需要加key: UniqueKey()唯一的
child: Text(flag ? "你好Flutter" : "改变内容",key: UniqueKey()
),

http://www.ppmy.cn/devtools/136380.html

相关文章

Elasticsearch 开放推理 API 增加了对 IBM watsonx.ai Slate 嵌入模型的支持

作者&#xff1a;来自 Elastic Saikat Sarkar 使用 Elasticsearch 向量数据库构建搜索 AI 体验时如何使用 IBM watsonx™ Slate 文本嵌入。 Elastic 很高兴地宣布&#xff0c;通过集成 IBM watsonx™ Slate 嵌入模型&#xff0c;我们的开放推理 API 功能得以扩展&#xff0c;这…

android general boot loader(rust安装后的build过程)

按照ahttps://cs.android.com/android/platform/superproject/main//main:bootable/libbootloader/gbl/的guide做android general boot loader下载以及build 注意事项&#xff1a; 1. bazel-bootstrap 安装参考 https://zhuanlan.zhihu.com/p/661422615 2. 根据实际情况确认…

自动语音识别(ASR)与文本转语音(TTS)技术的应用与发展

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…

泛微E9与金蝶云星空的集成方案:实现审批流程与财务管理的无缝对接

泛微E9与金蝶云星空的集成方案&#xff1a;实现审批流程与财务管理的无缝对接 背景介绍&#xff1a; 在企业日常运营中&#xff0c;泛微OA-E9和金蝶云星空是两个关键的系统。泛微OA-E9是一款广受企业青睐的办公自动化软件&#xff0c;它通过流程管理、文档管理、协同办公等模…

如何利用Java爬虫获得1688店铺详情

在数字化时代&#xff0c;数据已成为企业决策的重要依据。对于电商平台而言&#xff0c;获取竞争对手的店铺详情对于市场分析、产品定位等具有重要意义。本文将详细介绍如何利用Java编写爬虫&#xff0c;获取1688店铺详情&#xff0c;并提供实际的代码示例。 1. 背景介绍 1688…

桥接模式 (Bridge Pattern)

桥接模式 (Bridge Pattern) 桥接模式是一种 结构型设计模式&#xff0c;用于将抽象部分与实现部分分离&#xff0c;使它们可以独立变化。它通过组合的方式取代继承&#xff0c;将不同维度的变化解耦&#xff0c;从而提高系统的灵活性。 原理 核心思想&#xff1a;将一个对象的…

大模型基本能力评测---知识利用

文章目录 闭卷问答开卷问答知识补全主要问题知识利用(Knowledge Utilization)能力对于大语言模型非常关键,它赋予了模型执行知识密集型任务的能力,如回答常识性问题或基于知识信息进行相关推理。为了充分发挥这一能力,大语言模型需要在预训练阶段学习到丰富的世界语义知识…

RHCE 函数与数组

第六章、函数和数组 6.1 函数 函数几乎是学习所有的程序设计语言时都必须过的一关。对于学习过其他的程序语言的用户来说&#xff0c;函数可能并不陌生。但是Shell中的函数与其他的程序设计语言的函数有许多不同之处。为了使用户了解Shell中的函数&#xff0c;本节将介绍函数…