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)实现图片缩放的动态效果

相关推荐
幼儿园技术家5 分钟前
Hydration Mismatch 原理详解:SSR 项目中最容易踩的坑
前端
June bug19 分钟前
【Vue】EACCES: permission denied 错误
前端·javascript·vue.js
陈随易20 分钟前
PostgreSQL v18发布,新增AIO uuidv7 OAuth等功能
前端·后端·程序员
一只小阿乐24 分钟前
react 中的组件性能优化
前端·javascript·react.js·react组件性能优化
柯南二号30 分钟前
【大前端】【iOS】iOS 真实项目可落地目录结构方案
前端·ios
肉清35 分钟前
linux自用命令
linux·服务器·前端
weibkreuz42 分钟前
初始React@1
前端·react.js·前端框架
Coder_Boy_1 小时前
前端和后端软件系统联调经典问题汇总
java·前端·驱动开发·微服务·状态模式
小皮虾1 小时前
别再封装 Axios 了!用 RPC 像调用本地函数一样写接口(支持 Vue/React/Node)
前端·rpc·全栈
PieroPC1 小时前
NiceGUI .classes() 完整列表教程
前端