闪屏颤动,防止后退按钮

Splashscreen flutter, prevent back button

我制作了一个自定义启动画面,但是当我从无状态小部件按下后退按钮时,它将返回到启动画面“有状态小部件”。我试过 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 [...]
  }

}

提前致谢

一样使用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();
          },

更多关于push and pushReplacement