jjzjj

flutter - 版本更改后,Hero 小部件不能是另一个 Hero 小部件的后代

coder 2023-07-22 原文

我最近试图在 firebase fcm 中添加,但它没有工作,只是导致了几个错误,所以我将所有内容回滚到原始运行代码,但在此过程中升级了 flutter ...因为 v1.3.10 英雄不能包含其子层次结构中的另一个 Hero 小部件,但我找不到修复程序。 (理想情况下不想改回版本)

我检查了 heroTags,也找不到任何嵌套的 Hero 小部件 - 也许是因为动画构建器?

import 'package:flutter/material.dart';
import 'dart:math';
import 'package:vector_math/vector_math.dart' show radians, Vector3;
import 'package:font_awesome_flutter/font_awesome_flutter.dart';
import './Custom Icons/my_flutter_app_icons.dart' as CustomIcons;
import 'package:startoversword/liftPage.dart';
import 'package:startoversword/analWinkPage.dart';
import 'package:startoversword/lipPage.dart';
import 'package:startoversword/windscreenWiperPage.dart';
import 'package:startoversword/highHeelPage.dart';
import 'package:startoversword/rollerCoasterPage.dart';
import 'package:startoversword/notificationPage.dart';
import 'package:flutter/services.dart';

void main() async {
  await SystemChrome.setPreferredOrientations([DeviceOrientation.portraitUp]);
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Menu',
      home: _placeMyAppScaffold(),
    );
  }
}

class _placeMyAppScaffold extends StatelessWidget {
  Color defaultPink = Colors.white;
  Color pageThemeColor = Color(0xffF599E9);
  @override
  Widget build(BuildContext context) {
    // TODO: implement build
    return Scaffold(
        body: SizedBox.expand(child: RadialMenu()),
        appBar: AppBar(
          actions: <Widget>[
            FlatButton(
              child: Icon(Icons.notifications, color: Colors.white, size: 50.0),
              onPressed: () {
                print("notification pressed");
                Navigator.push(
                    context,
                    MaterialPageRoute(
                        builder: (context) => NotificationPage()));
              },
            ),
          ],
          title: Text('The S Word'),
          backgroundColor: pageThemeColor,
        ));
  }
}

class RadialMenu extends StatefulWidget {
  createState() => _RadialMenuState();
}

class _RadialMenuState extends State<RadialMenu>
    with SingleTickerProviderStateMixin {
  AnimationController controller;

  @override
  void initState() {
    super.initState();
    controller =
        AnimationController(duration: Duration(milliseconds: 900), vsync: this);
  }

  @override
  Widget build(BuildContext context) {
    return RadialAnimation(controller: controller);
  }

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

class RadialAnimation extends StatelessWidget {
  RadialAnimation({Key key, this.controller})
      : translation = Tween<double>(
          begin: 0.0,
          end: 100.0,
        ).animate(
          CurvedAnimation(parent: controller, curve: Curves.elasticOut),
        ),
        scale = Tween<double>(
          begin: 1.5,
          end: 0.0,
        ).animate(
          CurvedAnimation(parent: controller, curve: Curves.fastOutSlowIn),
        ),
        rotation = Tween<double>(
          begin: 0.0,
          end: 360.0,
        ).animate(
          CurvedAnimation(
            parent: controller,
            curve: Interval(
              0.0,
              0.7,
              curve: Curves.decelerate,
            ),
          ),
        ),
        super(key: key);

  final AnimationController controller;
  final Animation<double> rotation;
  final Animation<double> translation;
  final Animation<double> scale;

  @override
  Widget build(BuildContext context) {
    Color defaultPink = Color(0xffF599E9);
    return AnimatedBuilder(
        animation: controller,
        builder: (context, widget) {
          return Transform.rotate(
              angle: radians(rotation.value),
              child: Stack(alignment: Alignment.center, children: <Widget>[
                Hero(
                  tag: "liftScreenButton",
                  child: Container(
                    child: _buildButton(
                      30,
                      color: Color(0xfff665c6),
                      icon: CustomIcons.YoniFonts.lift,
                      context: context,
                      nextScreen: 'LiftScreen',
                    ),
                  ),
                ),
                Hero(
                  tag: "winkScreenButton",
                  child: Container(
                    child: _buildButton(
                      90,
                      color: Color(0xffe654be),
                      icon: CustomIcons.YoniFonts.dot_circled,
                      context: context,
                      nextScreen: 'winkScreen',
                    ),
                  ),
                ),
                Hero(
                  tag: "lipScreenButton",
                  child: Container(
                    child: _buildButton(
                      150,
                      color: Color(0xffd643b7),
                      icon: CustomIcons.YoniFonts.lips,
                      context: context,
                      nextScreen: 'lipScreen',
                    ),
                  ),
                ),
                Hero(
                  tag: "windscreenWiperScreenButton",
                  child: Container(
                    child: _buildButton(
                      210,
                      color: Color(0xffc632b0),
                      icon: CustomIcons.YoniFonts.car,
                      context: context,
                      nextScreen: 'WindscreenWiperScreen',
                    ),
                  ),
                ),
                Hero(
                  tag: "highHeelScreenButton",
                  child: Container(
                    child: _buildButton(
                      270,
                      color: Color(0xffb621a9),
                      icon: CustomIcons.YoniFonts.high_heels,
                      context: context,
                      nextScreen: 'HighHeelScreen',
                    ),
                  ),
                ),
                Hero(
                  tag: "rollerCoasterScreenButton",
                  child: Container(
                    child: _buildButton(
                      330,
                      color: Color(0xffa711a2),
                      icon: CustomIcons.YoniFonts.roller_coaster,
                      context: context,
                      nextScreen: 'rollerCoasterScreen',
                    ),
                  ),
                ),
                Transform.scale(
                  scale: scale.value - 1,
                  child: FloatingActionButton(
                      child: Icon(CustomIcons.YoniFonts.upsideDownYoni),
                      heroTag: "upsideDownYoni",
                      onPressed: _close,
                      backgroundColor: defaultPink),
                ),
                Transform.scale(
                  scale: scale.value,
                  child: FloatingActionButton(
                    heroTag: "initalYoni",
                    child: Icon(CustomIcons.YoniFonts.yoni),
                    onPressed: _open,
                    backgroundColor: defaultPink,
                  ),
                )
              ]));
        });
  }

  _open() {
    controller.forward();
  }

  _close({context, String nextScreen}) {
    controller.reverse();
    if (nextScreen == 'LiftScreen') {
      print("NEXT SCREEN IS LIFTPAGE");
      Navigator.push(
          context, MaterialPageRoute(builder: (context) => LiftPage()));
    } else if (nextScreen == "winkScreen") {
      print("NEXT SCREEN IS WINKPAGE");
      Navigator.push(
          context, MaterialPageRoute(builder: (context) => WinkPage()));
    } else if (nextScreen == "lipScreen") {
      print("NEXT SCREEN IS LIP PAGE");
      Navigator.push(
          context, MaterialPageRoute(builder: (context) => LipPage()));
    } else if (nextScreen == "WindscreenWiperScreen") {
      print("NEXT SCREEN IS WINDSCREENWIPERPAGE");
      Navigator.push(context,
          MaterialPageRoute(builder: (context) => WindScreenWiperPage()));
    } else if (nextScreen == "HighHeelScreen") {
      print("NEXT SCREEN IS HIGHHEELPAGE");
      Navigator.push(
          context, MaterialPageRoute(builder: (context) => HighHeelPage()));
    } else if (nextScreen == "rollerCoasterScreen") {
      print("NEXT SCREEN IS ROLLERCOASTERPAGE");
      Navigator.push(context,
          MaterialPageRoute(builder: (context) => RollerCoasterPage()));
    } else {
      return;
    }
    ;
  }

  _buildButton(double angle,
      {Color color, IconData icon, context, String nextScreen}) {
    final double rad = radians(angle);
    return Transform(
        transform: Matrix4.identity()
          ..translate(
              (translation.value) * cos(rad), (translation.value) * sin(rad)),
        child: FloatingActionButton(
            child: Icon(icon),
            heroTag: nextScreen,
            backgroundColor: color,
            onPressed: () => _close(context: context, nextScreen: nextScreen),
            elevation: 0));
  }
}

错误信息指向

_buildButton(double angle,
      {Color color, IconData icon, context, String nextScreen}) {
    final double rad = radians(angle);
    return Transform(
        transform: Matrix4.identity()
          ..translate(
              (translation.value) * cos(rad), (translation.value) * sin(rad)),
        child: FloatingActionButton(
            child: Icon(icon),
            heroTag: nextScreen, //error here
            backgroundColor: color,
            onPressed: () => _close(context: context, nextScreen: nextScreen),
            elevation: 0));
  }
}

感兴趣的是这里的完整输出

I/flutter (20678): #431    ComponentElement.mount 
package:flutter/…/widgets/framework.dart:3911
I/flutter (20678): #432    Element.inflateWidget 
package:flutter/…/widgets/framework.dart:3093
I/flutter (20678): #433    Element.updateChild 
package:flutter/…/widgets/framework.dart:2896
I/flutter (20678): #434    RenderObjectToWidgetElement._rebuild 
package:flutter/…/widgets/binding.dart:940
I/flutter (20678): #435    RenderObjectToWidgetElement.mount 
package:flutter/…/widgets/binding.dart:911
I/flutter (20678): #436    RenderObjectToWidgetAdapter.attachToRenderTree.<anonymous closure> 
package:flutter/…/widgets/binding.dart:857
I/flutter (20678): #437    BuildOwner.buildScope 
package:flutter/…/widgets/framework.dart:2320
I/flutter (20678): #438    RenderObjectToWidgetAdapter.attachToRenderTree 
package:flutter/…/widgets/binding.dart:856
I/flutter (20678): #439    _WidgetsFlutterBinding&BindingBase&GestureBinding&ServicesBinding&SchedulerBinding&PaintingBinding&SemanticsBinding&RendererBinding&WidgetsBinding.attachRootWidget 
package:flutter/…/widgets/binding.dart:737
I/flutter (20678): #440    runApp 
package:flutter/…/widgets/binding.dart:787
I/flutter (20678): #441    main 
package:startoversword/main.dart:21
I/flutter (20678): #452    SystemChrome.setPreferredOrientations (package:flutter/src/services/system_chrome.dart)
I/flutter (20678): #463    OptionalMethodChannel.invokeMethod (package:flutter/src/services/platform_channel.dart)
I/flutter (20678): #474    MethodChannel.invokeMethod (package:flutter/src/services/platform_channel.dart)
I/flutter (20678): (elided 46 frames from class _AssertionError, package dart:async, and package dart:async-patch)
I/flutter (20678):
I/flutter (20678): ════════════════════════════════════════════════════════════════════════════════════════════════════
I/flutter (20678): Another exception was thrown: A Hero widget cannot be the descendant of another Hero widget.
I/chatty  (20678): uid=10088(com.oxspines.talkingsword) 1.ui identical 3 lines
I/flutter (20678): Another exception was thrown: A Hero widget cannot be the descendant of another Hero widget.
I/OpenGLRenderer(20678): Davey! duration=865ms; Flags=0, IntendedVsync=76957734745126, Vsync=76957768078458, OldestInputEvent=9223372036854775807, NewestInputEvent=0, HandleInputStart=76957769369260, AnimationStart=76957769756360, PerformTraversalsStart=76957774959760, DrawStart=76957778308860, SyncQueued=76957778894960, SyncStart=76957788359860, IssueDrawCommandsStart=76957793180660, SwapBuffers=76957809783260, FrameCompleted=76958609467060, DequeueBufferDuration=116998000, QueueBufferDuration=12148000,
I/Choreographer(20678): Skipped 57 frames!  The application may be doing too much work on its main thread.
I/OpenGLRenderer(20678): Davey! duration=1061ms; Flags=0, IntendedVsync=76957801411790, Vsync=76958751411752, OldestInputEvent=9223372036854775807, NewestInputEvent=0, HandleInputStart=76958769243160, AnimationStart=76958772853660, PerformTraversalsStart=76958779455160, DrawStart=76958795072260, SyncQueued=76958796183260, SyncStart=76958889098460, IssueDrawCommandsStart=76958889855560, SwapBuffers=76958893194360, FrameCompleted=76958955694360, DequeueBufferDuration=35517000, QueueBufferDuration=4901000,

最佳答案

那是因为 FloatingActionButton 已经有一个 Hero 小部件包装它(查看其源代码)。 在您的代码中,您将 FAB 嵌入到另一个 Hero 小部件中。

要修复它,您只需将 FAB 中的“heroTag”属性设置为“null”,或者删除围绕该 FAB 的包装 Hero 小部件,只保留默认的。

关于flutter - 版本更改后,Hero 小部件不能是另一个 Hero 小部件的后代,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57075921/

有关flutter - 版本更改后,Hero 小部件不能是另一个 Hero 小部件的后代的更多相关文章

  1. ruby-on-rails - Ruby on Rails 迁移,将表更改为 MyISAM - 2

    如何正确创建Rails迁移,以便将表更改为MySQL中的MyISAM?目前是InnoDB。运行原始执行语句会更改表,但它不会更新db/schema.rb,因此当在测试环境中重新创建表时,它会返回到InnoDB并且我的全文搜索失败。我如何着手更改/添加迁移,以便将现有表修改为MyISAM并更新schema.rb,以便我的数据库和相应的测试数据库得到相应更新? 最佳答案 我没有找到执行此操作的好方法。您可以像有人建议的那样更改您的schema.rb,然后运行:rakedb:schema:load,但是,这将覆盖您的数据。我的做法是(假设

  2. ruby - 使用 Vim Rails,您可以创建一个新的迁移文件并一次性打开它吗? - 2

    使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta

  3. ruby-on-rails - Rails - 一个 View 中的多个模型 - 2

    我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何

  4. ruby-on-rails - 渲染另一个 Controller 的 View - 2

    我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>

  5. ruby-on-rails - 项目升级后 Pow 不会更改 ruby​​ 版本 - 2

    我在我的Rails项目中使用Pow和powifygem。现在我尝试升级我的ruby​​版本(从1.9.3到2.0.0,我使用RVM)当我切换ruby​​版本、安装所有gem依赖项时,我通过运行railss并访问localhost:3000确保该应用程序正常运行以前,我通过使用pow访问http://my_app.dev来浏览我的应用程序。升级后,由于错误Bundler::RubyVersionMismatch:YourRubyversionis1.9.3,butyourGemfilespecified2.0.0,此url不起作用我尝试过的:重新创建pow应用程序重启pow服务器更新战俘

  6. ruby-on-rails - 如果 Object::try 被发送到一个 nil 对象,为什么它会起作用? - 2

    如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象

  7. ruby - Capistrano 3 在任务中更改 ssh_options - 2

    我尝试使用不同的ssh_options在同一阶段运行capistranov.3任务。我的production.rb说:set:stage,:productionset:user,'deploy'set:ssh_options,{user:'deploy'}通过此配置,capistrano与用户deploy连接,这对于其余的任务是正确的。但是我需要将它连接到服务器中配置良好的an_other_user以完成一项特定任务。然后我的食谱说:...taskswithoriginaluser...task:my_task_with_an_other_userdoset:user,'an_othe

  8. ruby - 为什么 SecureRandom.uuid 创建一个唯一的字符串? - 2

    关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?

  9. ruby-on-rails - 在 ruby​​ .gemspec 文件中,如何指定依赖项的多个版本? - 2

    我正在尝试修改当前依赖于定义为activeresource的gem:s.add_dependency"activeresource","~>3.0"为了让gem与Rails4一起工作,我需要扩展依赖关系以与activeresource的版本3或4一起工作。我不想简单地添加以下内容,因为它可能会在以后引起问题:s.add_dependency"activeresource",">=3.0"有没有办法指定可接受版本的列表?~>3.0还是~>4.0? 最佳答案 根据thedocumentation,如果你想要3到4之间的所有版本,你可以这

  10. ruby-on-rails - Rails - 从另一个模型中创建一个模型的实例 - 2

    我有一个正在构建的应用程序,我需要一个模型来创建另一个模型的实例。我希望每辆车都有4个轮胎。汽车模型classCar轮胎模型classTire但是,在make_tires内部有一个错误,如果我为Tire尝试它,则没有用于创建或新建的activerecord方法。当我检查轮胎时,它没有这些方法。我该如何补救?错误是这样的:未定义的方法'create'forActiveRecord::AttributeMethods::Serialization::Tire::Module我测试了两个环境:测试和开发,它们都因相同的错误而失败。 最佳答案

随机推荐