亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Flutter使用AnimationController實現(xiàn)控制動畫

 更新時間:2023年05月17日 14:14:08   作者:程序那些事  
這篇文章主要想帶大家來嘗試一下Flutter如何使用AnimationController實現(xiàn)一個拖拽圖片,然后返回原點的動畫,感興趣的可以了解一下

簡介

之前我們提到了flutter提供了比較簡單好用的AnimatedContainer和SlideTransition來進行一些簡單的動畫效果,但是要完全實現(xiàn)自定義的復雜的動畫效果,還是要使用AnimationController。

今天我們來嘗試使用AnimationController來實現(xiàn)一個拖拽圖片,然后返回原點的動畫。

構(gòu)建一個要動畫的widget

在本文的例子中,我們希望能夠讓一個圖片可以實現(xiàn)拖拽然后自動返回原來位置的效果。

為了實現(xiàn)這個功能,我們首先構(gòu)建一個放在界面中間的圖片。

      child: Align(
        alignment: Alignment.center,
        child: Card(
          child: Image(image: AssetImage('images/head.jpg'))
        ),
      )

這里使用了Align組件,將一個圖片對象放在界面中間。

接下來我們希望這個widget可以拖拽,那么把這個child放到一個GestureDetector中,這樣就可以相應拖拽對應的響應。

 Widget build(BuildContext context) {
    final size = MediaQuery.of(context).size;
    return GestureDetector(
      onPanUpdate: (details) {
        setState(() {
          _animateAlign += Alignment(
            details.delta.dx / (size.width / 2),
            details.delta.dy / (size.height / 2),
          );
        });
      },
      child: Align(
        alignment: _animateAlign,
        child: Card(
          child: widget.child,
        ),
      ),
    );
  }

為了能實現(xiàn)拖動的效果,我們需要在GestureDetector的onPanUpdate方法中對Align的位置進行修改,所以我們需要調(diào)用setState方法。

在setState方法中,我們根據(jù)手勢的位置來調(diào)整Alignment的位置,所以這里需要用到MediaQuery來獲取屏幕的大小。

但是現(xiàn)在實現(xiàn)的效果是圖像隨手勢移動而移動,我們還需要實現(xiàn)在手放開之后,圖像自動回復到原來位置的動畫效果。

讓圖像動起來

因為這次需要變動的是Alignment,所以我們先定義一個包含Alignment的Animation屬性:

  late Animation<Alignment> _animation;

接下來我們需要定義一個AnimationController,用來控制動畫信息,并且指定我們需要的動畫起點和終點:

  late AnimationController _controller;
      _animation = _controller.drive(
      AlignmentTween(
        begin: _animateAlign,
        end: Alignment.center,
      ),
    );

我們動畫的起點位置就是當前image所在的Alignment,終點就在Alignment.center。

Alignment有一個專門表示位置信息的類叫做AlignmentTween,如上代碼所示。

有了起點和終點, 我們還需要指定從起點移動到終點的方式,這里模擬使用彈簧效果,所以使用SpringSimulation。

SpringSimulation需要提供對spring的描述,起點距離,結(jié)束距離和初始速度。

    const spring = SpringDescription(
      mass: 30,
      stiffness: 1,
      damping: 1,
    );
    final simulation = SpringSimulation(spring, 0, 1, -1);

我們使用上面創(chuàng)建的simulation,來實現(xiàn)動畫:

    _controller.animateWith(simulation);

最后我們需要在手勢結(jié)束的時候來執(zhí)行這個動畫即可:

      onPanEnd: (details) {
        _runAnimation();
      },

最后,運行效果如下所示:

總結(jié)

AnimationController是一個很強大的組件,但是使用起來也不是那么的復雜, 我們只需要定義好起點和終點,然后指定動畫效果即可。

本文的例子:github.com/ddean2009/learn-flutter

以上就是Flutter使用AnimationController實現(xiàn)控制動畫的詳細內(nèi)容,更多關于Flutter AnimationController的資料請關注腳本之家其它相關文章!

相關文章

  • Android?高德地圖POI定位地址搜索功能

    Android?高德地圖POI定位地址搜索功能

    這篇文章主要介紹了Android?高德地圖POI定位地址搜索功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-02-02
  • Android中沒有插入SD情況下的文件寫入和讀取方法

    Android中沒有插入SD情況下的文件寫入和讀取方法

    在Android開發(fā)時會遇到如下一種場合希望應用下載到當前應用的根目錄下,而非SD卡中然后可以隨時被該應用或其他應用訪問這個文件,即具有被全局讀取的權(quán)限
    2012-11-11
  • 你用不慣 RxJava,只因缺了這把鑰匙(推薦)

    你用不慣 RxJava,只因缺了這把鑰匙(推薦)

    這篇文章主要介紹了RxJava操作符,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • Android 自定義Dialog 實例

    Android 自定義Dialog 實例

    本篇文章主要介紹Android自定義Dialog,在Android開發(fā)中,出于美觀系統(tǒng)自帶的Dialog一般都會被重新,這里給大家寫個小實例,大家可以參考下
    2016-07-07
  • Android AndFix熱修復原理詳情

    Android AndFix熱修復原理詳情

    這篇文章主要介紹了Android AndFix熱修復原理詳情,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值嗎,需要的小伙伴可以參考一下
    2022-08-08
  • android?scrollview頂部漸漸消失實現(xiàn)實例詳解

    android?scrollview頂部漸漸消失實現(xiàn)實例詳解

    這篇文章主要為大家介紹了android?scrollview頂部漸漸消失實現(xiàn)實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Kotlin協(xié)程開發(fā)之Flow的融合與Channel容量及溢出策略介紹

    Kotlin協(xié)程開發(fā)之Flow的融合與Channel容量及溢出策略介紹

    這篇文章主要介紹了Kotlin協(xié)程:Flow的融合、Channel容量、溢出策略,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-09-09
  • Android實現(xiàn)網(wǎng)易新聞客戶端首頁效果

    Android實現(xiàn)網(wǎng)易新聞客戶端首頁效果

    這篇文章主要為大家詳細介紹了Android實現(xiàn)網(wǎng)易新聞客戶端首頁效果的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • MTK Android平臺開發(fā)流程

    MTK Android平臺開發(fā)流程

    這篇文章主要介紹了MTK在Android平臺開發(fā)的流程,一共分析了44個步驟,需要的朋友學習下吧。
    2017-12-12
  • Flutter利用注解生成可自定義的路由的實現(xiàn)

    Flutter利用注解生成可自定義的路由的實現(xiàn)

    這篇文章主要介紹了Flutter利用注解生成可自定義的路由的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08

最新評論