大佬教程收集整理的这篇文章主要介绍了如何在 Overlay/PopupRoute 中制作 Hero Widget 动画,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个设置页面,其中的选项在单击时会显示一个弹出窗口,因为它无法放入一个小容器中。我使用 Overlay 来显示弹出窗口 (Overlay.of(context).insert(OverlayEntry());
)。问题是它只会在没有动画的情况下弹出。
然后我尝试了另一种方法并遵循了这篇文章https://medium.com/flutter-community/flutter-route-animations-6ea071be5168。问题是我不想使用 Fade、Scale 等过渡。我有一个都包含在 Hero 小部件中,所以我希望设置在单击时展开并在弹出时收缩。
在应用程序的欢迎页面上,我有类似的内容:Welcome Page Screen Recording 我使用此代码实现了这一点:
onpressed: () => Navigator.of(context).push(
PageRouteBuilder(
TransitionDuration:
Duration(milliseconds: 600),pageBuilder: (BuildContext context,Animation<double> animation,Animation<double> secondaryAnimation) {
return LogInmock();
},TransitionsBuilder: (BuildContext context,Animation<double> secondaryAnimation,Widget child) {
return Align(
child: FadeTransition(
opacity: animation,child: child,),);
},
两个容器具有相同的英雄标签和非常相似的结构。
我尝试使用 PopupRoute(来自上面的中型文章)执行此操作,但它会在没有 Hero 动画的情况下淡入:SetTings Page Screen Recording。我使用相同的小部件,因此它具有相同的结构和 Hero 标签。为了确保我的小部件没有问题,我制作了一个用 Hero 包裹的容器,我得到了相同的结果。
这是 PopupRoute 导航代码:
Navigator.push(
context,CustomPopupRoute(
pageBuilder: (BuildContext context,Animation<double> secondaryAnimation) {
return test();
},Widget child) {
return FadeTransition(
opacity: animation,);
},);
以上是大佬教程为你收集整理的如何在 Overlay/PopupRoute 中制作 Hero Widget 动画全部内容,希望文章能够帮你解决如何在 Overlay/PopupRoute 中制作 Hero Widget 动画所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。