让你的切换丝滑起来,Hero animations的介绍

Hero动画是什么

在页面跳转过程中给用户加以引导是非常有用的。实现引导的一种通用做法是在页面切换时为某个组件加上转场动画,从而在两个页面间建立视觉上的锚定关联。

标准Hero动画如何实现

标准Hero动画的实现涉及两个主要步骤:

  1. 定义Hero元素:在需要动画效果的两个页面上定义具有相同tag的Hero元素。这个tag可以是任意的字符串,但在两个页面中必须一致。

  2. 页面过渡动画:在页面导航时,Flutter会自动识别具有相同tag的Hero元素,并生成平滑的过渡动画。

以下是一个简单的示例:

dart 复制代码
import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Hero Animation Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: FirstPage(),
    );
  }
}

class FirstPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('First Page'),
      ),
      body: Center(
        child: GestureDetector(
          onTap: () {
            Navigator.push(
              context,
              MaterialPageRoute(builder: (context) => SecondPage()),
            );
          },
          child: Hero(
            tag: 'hero-tag',
            child: Icon(
              Icons.star,
              size: 50.0,
            ),
          ),
        ),
      ),
    );
  }
}

class SecondPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Second Page'),
      ),
      body: Center(
        child: Hero(
          tag: 'hero-tag',
          child: Icon(
            Icons.star,
            size: 150.0,
          ),
        ),
      ),
    );
  }
}

在这个示例中,我们在两个页面上定义了具有相同tag的Hero元素。当用户点击第一个页面上的星形图标时,Flutter会自动生成平滑的过渡动画,将图标从一个页面"飞"到另一个页面。

Hero的函数原型是什么

在Flutter中,Hero类的构造函数原型如下:

dart 复制代码
Hero({
  Key? key,
  required Object tag,
  required Widget child,
  CreateRectTween? createRectTween,
  HeroFlightShuttleBuilder? flightShuttleBuilder,
  HeroPlaceholderBuilder? placeholderBuilder,
  bool transitionOnUserGestures = false,
})
  • key:Hero元素的唯一标识符。
  • tag:用来匹配两个页面之间Hero元素的标记。
  • child:Hero元素的子Widget。
  • createRectTween:自定义矩形动画的函数。
  • flightShuttleBuilder:自定义飞行期间的Widget。
  • placeholderBuilder:自定义占位符的Widget。
  • transitionOnUserGestures:是否在用户手势操作时触发过渡动画。

径向Hero动画实现

径向Hero动画是一种特殊的Hero动画,它将Hero元素的过渡路径定义为径向路径。为了实现这种效果,我们需要自定义RectTween

首先,我们需要一个自定义的RectTween类:

dart 复制代码
class CircularRectTween extends RectTween {
  CircularRectTween({required Rect begin, required Rect end}) : super(begin: begin, end: end);

  @override
  Rect lerp(double t) {
    double centerX = lerpDouble(begin!.center.dx, end!.center.dx, t)!;
    double centerY = lerpDouble(begin!.center.dy, end!.center.dy, t)!;
    double width = lerpDouble(begin!.width, end!.width, t)!;
    double height = lerpDouble(begin!.height, end!.height, t)!;
    return Rect.fromCenter(center: Offset(centerX, centerY), width: width, height: height);
  }
}

接下来,我们在Hero中使用这个自定义的RectTween

dart 复制代码
class FirstPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('First Page'),
      ),
      body: Center(
        child: GestureDetector(
          onTap: () {
            Navigator.push(
              context,
              MaterialPageRoute(builder: (context) => SecondPage()),
            );
          },
          child: Hero(
            tag: 'hero-tag',
            createRectTween: (begin, end) {
              return CircularRectTween(begin: begin!, end: end!);
            },
            child: Icon(
              Icons.star,
              size: 50.0,
            ),
          ),
        ),
      ),
    );
  }
}

class SecondPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Second Page'),
      ),
      body: Center(
        child: Hero(
          tag: 'hero-tag',
          child: Icon(
            Icons.star,
            size: 150.0,
          ),
        ),
      ),
    );
  }
}

通过自定义RectTween,我们可以实现径向Hero动画,使过渡路径看起来更加自然和圆滑。

结语

Hero动画不仅可以增强用户体验,还能让应用程序看起来更具吸引力和互动性。无论是标准Hero动画还是自定义径向Hero动画,Flutter都提供了强大的工具和灵活的接口,让我们能够轻松实现各种酷炫的动画效果。希望这篇博客能帮助你更好地理解和实现Hero动画。

相关推荐
RaidenLiu2 小时前
从 Provider 迈向 Riverpod 3:核心架构与迁移指南
前端·flutter
叽哥2 小时前
Flutter面试:Dart基础2
flutter·面试·dart
tangweiguo030519875 小时前
Android原生(Kotlin)与Flutter混合开发 - 设备控制与状态同步解决方案
android·flutter
江上清风山间明月1 天前
Flutter AlwaysScrollableScrollPhysics详解
flutter·滚动·scrollable·scrollphysics
普罗米拉稀1 天前
Flutter 复用艺术:Mixin 与 Abstract 的架构哲学与线性化解密
flutter·ios·面试
yangshuo12811 天前
AI编程工具对决:Kilo vs Augment 开发Flutter俄罗斯方块游戏实战对比
flutter·游戏·ai编程
tangweiguo030519871 天前
Flutter 自定义 Switch 切换组件完全指南
flutter
笔沫拾光2 天前
iOS 正式包签名指南
flutter·ios·ios签名
森之鸟2 天前
flutter项目适配鸿蒙
flutter·华为·harmonyos
傅里叶2 天前
Flutter在OrangePi 5 Plus上视频播放锁死问题
前端·flutter