作为 Flutter 新手,我正在通过重新创建现有的 Android 应用程序来进行学习练习。然而,我在制作“旋转的、不断增长的主页图标”时遇到了麻烦,该图标的动画效果应与抽屉打开/关闭动画同步。
所需的抽屉/主页图标行为如下所示:
我在 Android 中通过实现实现了这个
DrawerListener.onDrawerSlide(View drawerView, float slideOffset)
Run Code Online (Sandbox Code Playgroud)
我在 Flutter 中执行此操作的简单方法是使用 ScaleTransition 和 RotationTransition 来监听打开/关闭抽屉的相同动画。
我可以看到 ScaffoldState 有一个 DrawerControllerState,但它是私有的。
final GlobalKey<DrawerControllerState> _drawerKey = new GlobalKey<DrawerControllerState>();
Run Code Online (Sandbox Code Playgroud)
即使我可以以某种方式访问 DrawerControllerState (我不知道如何访问),我也无法访问 _animationChanged() 和 _controller,因为它们都是 DrawerControllerState 的私有成员。
我觉得我的做法是错误的,而且有一种对 Flutter 更自然的更好方法,但我看不到。
请问谁能描述一下 Flutter 的实现方式吗?