欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

在Flutter中给widget添加动画

程序员文章站 2022-03-27 11:32:45
在Android中,可以通过通过XML创建动画或在视图上调用View.animate()对视图进行动画处理。在flutter中,可以通过动画库给widget添加动画,将widget包装到Animation中。与Android相似,在Flutter中,有一个AnimationController控制器和一个Interpolator, 它是Animation类的扩展,如CurvedAnimation。将控制器和动画传递到AnimationWidget中,并告诉控制器启动动画。如一个FadeTransitio...

在Android中,可以通过通过XML创建动画或在视图上调用View.animate()对视图进行动画处理。在flutter中,可以通过动画库给widget添加动画,将widget包装到Animation中。

与Android相似,在Flutter中,有一个AnimationController控制器和一个Interpolator, 它是Animation类的扩展,如CurvedAnimation。将控制器和动画传递到AnimationWidget中,并告诉控制器启动动画。
如一个FadeTransition,当按下时会淡入一个logo:

class _MyHomeAppSate extends State<StatefulWidget> with TickerProviderStateMixin{
  AnimationController controller;
  CurvedAnimation curve;
  @override
  void initState() {
    super.initState();
    controller = new AnimationController(duration: const Duration(milliseconds: 2000), vsync: this);
    curve = new CurvedAnimation(parent: controller, curve: Curves.easeIn);
  }


  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      home: new Scaffold(
        appBar: new AppBar(
          title: new Text("Hello"),
        ),
        body: Center(child: Container(child: FadeTransition(opacity: curve,child: FlutterLogo(size: 100.0,),),),),
        floatingActionButton: new FloatingActionButton(
          tooltip: 'Fade',
          child: new Icon(Icons.brush),
          onPressed: (){
            controller.forward();
          },
        ),
      ),
    );
  }
}

本文地址:https://blog.csdn.net/weixin_40763897/article/details/108166027