Flutter 動畫使用

旋轉動畫  面試

這裏寫圖片描述

透明度變換動畫  bash

這裏寫圖片描述

在Android中,能夠經過View.animate()對視圖進行動畫處理,那在Flutter中怎樣才能對Widget進行處理  在Flutter中,能夠經過動畫庫給widget添加動畫。app

在Android中,您能夠經過XML建立動畫或在視圖上調用.animate()。在Flutter中,您能夠將widget包裝到Animation中。less

與Android類似,在Flutter中,您有一個AnimationController和一個Interpolator, 它是Animation類的擴展,例如CurvedAnimation。您將控制器和動畫傳遞到AnimationWidget中,並告訴控制器啓動動畫。ide

import 'package:flutter/material.dart';

void main() {
  runApp(new FadeAppTest());
}

class FadeAppTest extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      title: 'Fade Demo',
      theme: new ThemeData(
        primarySwatch: Colors.green,
      ),
      home: new MyFadeTest(title: 'Fade Demo'),
    );
  }
}

class MyFadeTest extends StatefulWidget {
  MyFadeTest({Key key, this.title}) : super(key: key);
  final String title;

  @override
  State createState() => new _MyFadeTest();
}

class _MyFadeTest extends State<MyFadeTest> with TickerProviderStateMixin {
  AnimationController controller;//動畫控制器
  CurvedAnimation curved;//曲線動畫,動畫插值,
  bool forward = true;

  @override
  void initState() {//初始化,噹噹前widget被插入到樹中時調用
    super.initState();
    controller = new AnimationController(
        vsync: this, duration: const Duration(seconds: 3));
    curved = new CurvedAnimation(parent: controller, curve: Curves.bounceOut);//模仿小球自由落體運動軌跡
//    controller.forward();//放在這裏開啓動畫 ,打開頁面就播放動畫
  }

  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      appBar: new AppBar(
        title: new Text('FadeTest'),
      ),
      body: new Center(
//        child: new FadeTransition(//透明度動畫
//          opacity: curved,//將動畫傳入不一樣的動畫widget
//          child: new FlutterLogo(//建立一個小部件,用於繪製Flutter徽標
//            size: 200.0,
//          ),
//        ),
        child: new RotationTransition(//旋轉動畫
          turns: curved,
          child: new FlutterLogo(
            size: 200.0,
          ),

        ),

      ),
      floatingActionButton: new FloatingActionButton(
        onPressed: () {
          if (forward)
            controller.forward();//向前播放動畫
          else
            controller.reverse();//向後播放動畫
          forward = !forward;
        },
        tooltip: 'fade',
        child: new Icon(Icons.track_changes),
      ),
    );
  }
}
複製代碼

flutter錄播.png

歡迎加入Android圈子,圈內會不定時免費更新源碼及面試資料,包括前沿技術flutter等專題資料,圈友也積極交流划水~你們共同進步學習;點贊私信 資料 便可加入羣聊 學習

flutter專題.png
相關文章
相關標籤/搜索