zoukankan      html  css  js  c++  java
  • flutter 路由动画

    import 'package:flutter/material.dart';
    import 'package:flutter_app/pages/FirstPage.dart';
    
    void main() => runApp(MyApp());
    
    class MyApp extends StatelessWidget {
    
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          title: 'Flutter Demo',
          theme: ThemeData(
            primarySwatch: Colors.green,  //定义主题风格    primarySwatch
          ),
          home: FirstPage(),
        );
      }
    
    }
    import 'package:flutter/material.dart';
    import 'package:flutter_app/CustomRoute.dart';
    import 'package:flutter_app/pages/SecondPage.dart';
    
    
    class FirstPage extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return Scaffold(
            backgroundColor: Colors.blue,
            appBar:AppBar(
              title:Text('FirstPage',style: TextStyle(fontSize: 36.0)),
              elevation: 0.0,
            ),
            body:Center(
              child: MaterialButton(
                child: Icon(
                  Icons.navigate_next,
                  color:Colors.white,
                  size:64.0,
                ),
                onPressed: (){
                  Navigator.of(context).push(
                      CustomRoute(SecondPage())); //使用自定义路由动画
    
                },
              ),
            )
        );
      }
    }
    import 'package:flutter/material.dart';
    class SecondPage extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return Scaffold(
            backgroundColor: Colors.pinkAccent,
            appBar: AppBar(
              title: Text('SecondPage',style:TextStyle(fontSize:36.0),),
              backgroundColor: Colors.pinkAccent,
              leading:Container(),
              elevation: 0.0,
            ),
            body:Center(
              child: MaterialButton(
                child: Icon(
                    Icons.navigate_before,
                    color:Colors.white,
                    size:64.0
                ),
                onPressed: ()=>Navigator.of(context).pop(),
              ),
            )
        );
      }
    }
    import 'package:flutter/material.dart';
    
    class CustomRoute extends PageRouteBuilder {
      final Widget widget;
    
      CustomRoute(this.widget)
          : super(
                transitionDuration: const Duration(seconds: 1),
                pageBuilder: (BuildContext context, Animation<double> animation1,
                    Animation<double> animation2) {
                  return widget;
                },
                transitionsBuilder: (BuildContext context,
                    Animation<double> animation1,
                    Animation<double> animation2,
                    Widget child) {
                  //缩放
    //        return ScaleTransition(
    //            scale:Tween(begin:0.0,end:1.0).animate(CurvedAnimation(
    //                parent:animation1,
    //                curve: Curves.fastOutSlowIn
    //            )),
    //            child:child
    //        );
                  //旋转+缩放路由动画
    //        return RotationTransition(
    //            turns:Tween(begin:0.0,end:1.0)
    //                .animate(CurvedAnimation(
    //                parent: animation1,
    //                curve: Curves.fastOutSlowIn
    //            )),
    //            child:ScaleTransition(
    //              scale:Tween(begin: 0.0,end:1.0)
    //                  .animate(CurvedAnimation(
    //                  parent: animation1,
    //                  curve:Curves.fastOutSlowIn
    //              )),
    //              child: child,
    //            )
    //        );
                  //左右滑动路由动画
    //              return SlideTransition(
    //                position: Tween<Offset>(
    //                        begin: Offset(-1.0, 0.0), end: Offset(0.0, 0.0))
    //                    .animate(CurvedAnimation(
    //                        parent: animation1, curve: Curves.fastOutSlowIn)),
    //                child: child,
    //              );
    
            return FadeTransition(
              opacity: Tween(begin:0.0,end :1.0).animate(CurvedAnimation(
                  parent:animation1,
                  curve:Curves.fastOutSlowIn
              )),
              child: child,
            );
                });
    }

    效果:

  • 相关阅读:
    Qt QListWidgetItem的添加与删除
    Qt QListWidget中实现每个单元项显示文字在上图片在下
    Qt QListWiget的Item的icon大小设置
    Qt 控制Widget窗体大小方法
    装饰模式(Decorator)C++实现
    C++ 结构型模式
    Qt 创建一个excel文件(通过save as 方法)
    深度学习之 YOLO v1,v2,v3详解
    Qt excel 操作使用说明
    “云钉一体”背后,阿里云希望改变什么?
  • 原文地址:https://www.cnblogs.com/loaderman/p/11350141.html
Copyright © 2011-2022 走看看