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

相关推荐
可视之道16 小时前
前端大屏适配方案:rem、vw/vh、scale 到底选哪个?
前端
小码哥_常16 小时前
别在Android ViewModel里处理异常啦,真的很坑!
前端
05大叔16 小时前
RAG开发
java·服务器·前端
console.log('npc')16 小时前
在 React 中,useRef、ref 属性以及 forwardRef 是处理“引用”(访问 DOM 节点或组件实例)的核心概念
前端·react.js·前端框架
小小小小宇16 小时前
语法全景对照
前端
weixin_7042660517 小时前
Spring Boot 入门了解
前端·firefox
冲浪中台17 小时前
如何实现低代码源码级交付和私有化部署
前端·低代码·私有化部署·源代码管理
炒毛豆17 小时前
Vue 3 公共组件从封装到全局注册的极简指南
前端·javascript·vue.js
踩着两条虫17 小时前
VTJ.PRO 在线应用开发平台前端架构
前端·vue.js·ai编程
踩着两条虫17 小时前
VTJ.PRO 在线应用开发平台部署与运维
前端·vue.js·人工智能