【问题标题】:Splashscreen flutter, prevent back button启动画面颤动,防止返回按钮
【发布时间】:2022-01-01 05:25:17
【问题描述】:

我已经制作了一个自定义 Splashscreen,但是当我从 statless 小部件按下返回按钮时,它会返回 Splashcreen“有状态小部件”。我已经尝试过 WillPopBack 但它不起作用,或者至少我无法使用它。如何防止无状态小部件返回有状态小部件? 这是我的代码:

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

class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);

  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(primarySwatch: Colors.blue, fontFamily: 'Monserrat'),
      home: const MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  const MyHomePage({Key? key, required this.title}) : super(key: key);

  final String title;

  @override
  State<MyHomePage> createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> with TickerProviderStateMixin {
  @override
  void initState() {
    super.initState();
    Future.delayed(Duration(seconds: 4), () {
      Navigator.of(context).push(
        PageRouteBuilder(
          transitionDuration: Duration(milliseconds: 1000),
          pageBuilder: (BuildContext context, Animation<double> animation,
              Animation<double> secondaryAnimation) {
            return MainScreen();
          },
          transitionsBuilder: (BuildContext context,
              Animation<double> animation,
              Animation<double> secondaryAnimation,
              Widget child) {
            return Align(
              child: FadeTransition(
                opacity: animation,
                child: child,
              ),
            );
          },
        ),
      );
    });
  }

  @override
  Widget build(BuildContext context) {
    return [...]
  }
}

class MainScreen extends StatelessWidget {

  @override
  Widget build(BuildContext context) {
    return [...]
  }

}

提前致谢

【问题讨论】:

    标签: android ios flutter splash-screen


    【解决方案1】:

    使用pushReplacement 代替push 喜欢

      super.initState();
        Future.delayed(Duration(seconds: 4), () {
          Navigator.of(context).pushReplacement( //< this
            PageRouteBuilder(
              transitionDuration: Duration(milliseconds: 1000),
              pageBuilder: (BuildContext context, Animation<double> animation,
                  Animation<double> secondaryAnimation) {
                return MainScreen();
              },
    

    更多关于pushpushReplacement

    【讨论】:

      猜你喜欢
      • 2021-02-16
      • 2011-12-29
      • 2021-12-24
      • 2019-01-15
      • 2018-09-15
      • 2023-04-02
      • 2011-03-20
      • 1970-01-01
      相关资源
      最近更新 更多