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

相关推荐
海石2 小时前
📱随时随地大小编:TraeSolo 移动端初体验
前端·ai编程·trae
爱滑雪的码农4 小时前
详细说说React大型项目结构以及日常开发核心语法
前端·javascript·react.js
七牛开发者4 小时前
HTML is the new Markdown:来自 Claude Code 团队的实践
前端·人工智能·语言模型·html
@大迁世界5 小时前
43.HTML 事件处理和 React 事件处理有什么区别?
前端·javascript·react.js·html·ecmascript
CloneCello5 小时前
AI时代程序员认知调整指南
前端
ZC跨境爬虫6 小时前
跟着 MDN 学 HTML day_38:(DocumentFragment 文档片段接口详解)
前端·javascript·ui·html·音视频
@大迁世界7 小时前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
千叶风行7 小时前
Text-to-SQL 技术设计与注意事项
前端·人工智能·后端
软件开发技术深度爱好者7 小时前
HTML5+JavaScript读取DOCX 文档完整内容
前端·html5
幽络源小助理8 小时前
苹果CMS V10 MXPro V4.5模版下载, 自适应视频主题源码, 幽络源源码
前端·开源·源码·php源码