版本更改后,一个 Hero widget 不能是另一个 Hero widget 的后代。
创始人
2024-11-20 18:00:44
0

在Flutter的版本更新后,一个 Hero widget不能是另一个Hero widget的后代。在此情况下,可以使用 HeroController 类自定义 Hero 动画。

以下是一个使用 HeroController 自定义 Hero 动画的示例:

import 'package:flutter/material.dart';

class CustomHeroController extends HeroController {
  @override
  Animation createHeroAnimation(
      {required String tag,
      required Animation fromHero,
      required Animation toHero}) {
    return Tween(
      begin: fromHero.value,
      end: toHero.value,
    ).animate(CurvedAnimation(
      parent: super.createHeroAnimation(tag: tag, fromHero: fromHero, toHero: toHero),
      curve: Curves.easeInOut,
    ));
  }
}

class HomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Custom Hero'),
      ),
      body: Center(
        child: GestureDetector(
          onTap: () {
            Navigator.push(
              context,
              MaterialPageRoute(
                builder: (context) => DetailPage(),
              ),
            );
          },
          child: Hero(
            tag: 'hero',
            createRectTween: (begin, end) {
              return RectTween(
                begin: begin,
                end: end,
              );
            },
            child: Container(
              width: 100,
              height: 100,
              color: Colors.blue,
            ),
          ),
        ),
      ),
    );
  }
}

class DetailPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Detail Page'),
      ),
      body: Center(
        child: GestureDetector(
          onTap: () {
            Navigator.pop(context);
          },
          child: Hero(
            tag: 'hero',
            createRectTween: (begin, end) {
              return RectTween(
                begin: begin,
                end: end,
              );
            },
            child: Container(
              width: 200,
              height: 200,
              color: Colors.red,
            ),
          ),
        ),
      ),
    );
  }
}

void main() {
  runApp(MaterialApp(
    home: HomePage(),
    theme: ThemeData(
      heroController: CustomHeroController(),
    ),
  ));
}

在这个示例中,我们自定义了一个 CustomHeroController 类来处理 Hero 动画。在 CustomHeroController 中,我们重写了 createHeroAnimation 方法来创建自定义的动画。然后,我们在 main 方法中将 CustomHeroController 设置为主题数据的一部分。

HomePage 中,我们使用 GestureDetector 包装 Hero,以便在点击时导航到 DetailPageHerotag 属性用于标识 Hero,以便在页面切换时进行匹配。

DetailPage 中,我们也使用了一个 GestureDetector 包装 Hero,并使用相同的 tag 属性。这样,在页面切换时,Hero 将根据 CustomHeroController 中定义的动画进行过渡。

这样,我们就成功地解决了Flutter版本更新后 Hero 的后代问题,并自定义了 Hero 的动画效果。

相关内容

热门资讯

两分钟辅助!开心泉州小程序开挂... 两分钟辅助!开心泉州小程序开挂有什么技巧,原来真的是有辅助插件(有挂教学)开心泉州小程序开挂有什么技...
七分钟辅助!奇迹脚本辅助,真是... 七分钟辅助!奇迹脚本辅助,真是有辅助软件(确实有挂)1、超多福利:超高返利,海量正版游戏,奇迹脚本辅...
一分钟辅助!天天贵阳智能辅助器... 一分钟辅助!天天贵阳智能辅助器,原来是有辅助脚本(真的有挂)亲,关键说明,天天贵阳智能辅助器透视脚本...
3分钟辅助!一起宁德钓蟹黑科技... 3分钟辅助!一起宁德钓蟹黑科技辅助软件推荐,其实真的有辅助挂(有挂存在)1、玩家可以在一起宁德钓蟹黑...
第二分钟辅助!大菠萝789辅助... 第二分钟辅助!大菠萝789辅助器下载,原来存在有辅助挂(存在有挂)运大菠萝789辅助器下载辅助工具,...
3分钟辅助!科乐填坑辅助,原来... 3分钟辅助!科乐填坑辅助,原来真的是有辅助器(有挂方略)1、下载好科乐填坑辅助透视辅助下载之后点击打...
3分钟辅助!潮友会透视辅助教程... 3分钟辅助!潮友会透视辅助教程,果然存在有辅助器(有挂辅助)亲,关键说明,潮友会透视辅助教程透视脚本...
4分钟辅助!福建兄弟十三冰修改... 4分钟辅助!福建兄弟十三冰修改器,本来真的是有辅助app(有挂讲解)1、游戏颠覆性的策略玩法,独创攻...
第二分钟辅助!wepoker插... 第二分钟辅助!wepoker插件程序,真是是真的有辅助技巧(有挂细节)1、不需要AI权限,帮助你快速...
1分钟辅助!悠悠互娱辅助,真是... 1分钟辅助!悠悠互娱辅助,真是是有辅助神器(有挂解密)悠悠互娱辅助透视方法中分为三种模型:悠悠互娱辅...