Flutter:TweenAnimationBuilder自定义隐式动画

1、修改组件的大小触发:自定义动画

js 复制代码
class _MyHomePageState extends State<MyHomePage>{
  bool flag = true;
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('标题'),
      ),
      body: Column(
        children: [
          Container(
            child: TweenAnimationBuilder(
                // 当改变Tween的end参数时,Icon就会触发动画,size接收double类型begin和end要加.0
                tween: Tween(begin: 60.0,end: flag ? 100.0 : 200.0),
                duration: const Duration(milliseconds: 500),
                builder: ((context,value,child){
                  // 当更改flag时,会把end的值,赋值给value,Icon就会执行这个动画
                  // size接收double类型,但是value是Object类型,需要用 as double 转换一下
                  return Icon(Icons.star,size: value as double);
                })
            ),
          ),
          ElevatedButton(onPressed: (){
            setState(() {
              flag = !flag;
            });
          }, child: const Text('修改Icon大小')),
        ],
      ),
    );
  }
}

2、组件透明度变化触发:自定义动画

js 复制代码
body: Column(
 children: [
   Container(
     child: TweenAnimationBuilder(
       // 当改变Tween的end参数时,就会触发动画
       tween: Tween(begin: 1.0,end: flag ? 1.0 : 0.0),
       duration: const Duration(milliseconds: 500),
       builder: ((context,value,child){
         return Opacity(
           opacity: value as double,
           child: Container(
             width: 200,
             height: 200,
             color: Colors.red,
           ),
         );
       }),
     ),
   ),
   ElevatedButton(onPressed: (){
     setState(() {
       flag = !flag;
     });
   }, child: const Text('修改Opacity')),
 ],
),
相关推荐
代码轨迹1 小时前
flutter项目构建常见问题
flutter
ybilss1 小时前
初识flutter1
flutter
早起的年轻人1 小时前
Flutter 3.29.0 版本对颜色Color做出的改动 Display P3你了解吗
flutter
B.-1 小时前
在已有的原生 App 里嵌入 Flutter 页面的方法
开发语言·flutter·macos·cocoa
Neo Evolution1 小时前
每天一个Flutter开发小项目 (6) : 表单与验证的专业实践 - 构建预约应用
android·开发语言·前端·javascript·flutter
火炎焱燚-1 小时前
Flutter - 布局Widget
flutter
仙魁XAN2 小时前
Flutter 学习之旅 之 flutter 使用 webview_flutter 进行网页加载显示
flutter·web·webview·网页显示·webview_flutter
pengyu4 小时前
系统化掌握Flutter组件之“核按钮系统探秘”
android·flutter·dart
一人前行5 小时前
Flutter_学习记录_iOS 模拟器用Charles抓包
flutter
l软件定制开发工作室1 天前
Flutter系列教程之(5)——常用控件Widget的使用示例
flutter