Flutter中实现Hero Page Route效果

在Flutter中实现Hero动画的页面路由效果,主要通过共享元素的平滑过渡来提升用户体验。以下是关键实现步骤和技术要点:

核心实现原理

  1. Hero组件 ‌:需在源页面和目标页面使用相同tag标识的Hero组件包裹共享元素(如图片或控件),系统会自动计算过渡路径并执行动画26。
  2. 路由跳转 ‌:通过Navigator.push触发页面切换,Hero动画会在路由切换过程中自动执行3。
  3. 动画控制 ‌:默认使用MaterialRectArcTween实现位置和形状的插值动画,可通过自定义PageRouteBuilder调整过渡效果67。

代码实现示例

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {

@override

Widget build(BuildContext context) {

return MaterialApp(

home: HeroSourcePage(),

);

}

}

class HeroSourcePage extends StatelessWidget {

@override

Widget build(BuildContext context) {

return Scaffold(

appBar: AppBar(title: Text('源页面')),

body: Center(

child: GestureDetector(

child: Hero(

tag: 'heroTag', // 唯一标识

child: Container(

width: 100,

height: 100,

color: Colors.blue,

),

),

onTap: () => Navigator.push(

context,

MaterialPageRoute(builder: (_) => HeroTargetPage()),

),

),

),

);

}

}

class HeroTargetPage extends StatelessWidget {

@override

Widget build(BuildContext context) {

return Scaffold(

appBar: AppBar(title: Text('目标页面')),

body: Center(

child: Hero(

tag: 'heroTag', // 与源页面相同tag

child: Container(

width: 200,

height: 200,

color: Colors.red,

  1. tag一致性 ‌:源页面和目标页面的Hero组件必须使用相同的tag,否则动画失效23。
  2. 路由配置 ‌:可通过PageRouteBuilder自定义过渡动画时长和效果,如渐隐或滑动7。
  3. 复杂场景 ‌:支持多Hero动画并行,但同一页面内的多个Hero需使用不同tag6。

高级应用

  • Dialog路由‌:Hero动画同样适用于Dialog等非全屏路由3。
  • 自定义动画 ‌:通过transitionsBuilder重写默认动画逻辑,如结合缩放和旋转效果。

完整示例可通过调整Container的子控件(如Image)实现图片缩放的动态效果

相关推荐
李少兄1 小时前
HTML 表单控件
前端·microsoft·html
学习笔记1012 小时前
第十五章认识Ajax(六)
前端·javascript·ajax
消失的旧时光-19432 小时前
Flutter 异步编程:Future 与 Stream 深度解析
android·前端·flutter
曹牧3 小时前
C# 中的 DateTime.Now.ToString() 方法支持多种预定义的格式字符
前端·c#
勿在浮沙筑高台3 小时前
海龟交易系统R
前端·人工智能·r语言
歪歪1003 小时前
C#如何在数据可视化工具中进行数据筛选?
开发语言·前端·信息可视化·前端框架·c#·visual studio
Captaincc4 小时前
AI 能帮你写代码,但把代码变成软件,还是得靠人
前端·后端·程序员
吃饺子不吃馅5 小时前
如何设计一个 Canvas 事件系统?
前端·canvas·图形学
Baklib梅梅5 小时前
无头内容管理系统:打造灵活高效的多渠道内容架构
前端·ruby on rails·前端框架·ruby
over6975 小时前
浏览器里的AI魔法:用JavaScript玩转自然语言处理
前端·javascript