gpt4 book ai didi

android - Flutter:如何在触发转换之前为小部件设置动画?

转载 作者:IT王子 更新时间:2023-10-29 06:58:05 26 4
gpt4 key购买 nike

您知道我们如何在转换到新屏幕之前为小部件设置动画吗?我的意思是:

  1. 用户点击 FAB,这会打开一个新屏幕
  2. 在用户点击后,FAB 会动画缩小直到不可见(就像原生开发中的隐藏功能一样)
  3. 当 FAB 不可见时,触发新的屏幕转换

通过一个 Activity/多个 fragment 在 native 开发中实现这一点相对容易,但我找不到在 flutter 中做到这一点的方法:/

最佳答案

您需要使用 AnimationController 并为您的 FAB 配置它并附加 AnimationStatusListener。按下 FAB 后,您将启动动画,一旦动画完成,您将在状态监听器中导航到下一页。

这里我给你写了一段代码:

import 'package:flutter/animation.dart';
import 'package:flutter/material.dart';

void main() => runApp(
MaterialApp(
home: FabApp(),
),
);

class FabApp extends StatefulWidget {
_FabAppState createState() => _FabAppState();
}

class _FabAppState extends State<FabApp> with SingleTickerProviderStateMixin {
Animation<double> animation;
AnimationController controller;

@override
void initState() {
super.initState();
controller = AnimationController(
duration: const Duration(seconds: 2),
vsync: this,
);
controller.addListener(() {
setState(() {});
});
controller.addStatusListener((status) {
if (status == AnimationStatus.completed) {
Navigator.of(context).push(
MaterialPageRoute<void>(builder: (BuildContext context) {
return Scaffold(
body: Text("Hi"),
);
}),
);
}
});
animation = Tween<double>(begin: 1, end: 0).animate(controller);
}

@override
Widget build(BuildContext context) {
return Scaffold(
floatingActionButton: Transform.scale(
scale: animation.value,
child: FloatingActionButton(onPressed: () {
controller.forward();
}),
),
);
}

@override
void dispose() {
controller.dispose();
super.dispose();
}
}

关于android - Flutter:如何在触发转换之前为小部件设置动画?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54974373/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com