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

Android?Flutter制作一個(gè)修改組件屬性的動(dòng)畫

 更新時(shí)間:2023年05月09日 16:37:06   作者:程序那些事  
flutter為我們提供了一個(gè)AnimationController來(lái)對(duì)動(dòng)畫進(jìn)行詳盡的控制,不過(guò)直接是用AnimationController是比較復(fù)雜的,如果只是對(duì)一個(gè)widget的屬性進(jìn)行修改,可以做成動(dòng)畫嗎,本文就來(lái)探討一下

簡(jiǎn)介

什么是動(dòng)畫呢?動(dòng)畫實(shí)際上就是不同的圖片連續(xù)起來(lái)形成的。flutter為我們提供了一個(gè)AnimationController來(lái)對(duì)動(dòng)畫進(jìn)行詳盡的控制,不過(guò)直接是用AnimationController是比較復(fù)雜的,如果只是對(duì)一個(gè)widget的屬性進(jìn)行修改,可以做成動(dòng)畫嗎?

答案是肯定的,一起來(lái)看看吧。

flutter中的動(dòng)畫widget

如果你只是希望動(dòng)畫展示widget的屬性的變化,比如比如長(zhǎng)度,高度,寬度或者顏色等進(jìn)行動(dòng)態(tài)變化,那么可以直接使用flutter提供的AnimatedContainer。

先來(lái)看下AnimatedContainer的定義:

class AnimatedContainer extends ImplicitlyAnimatedWidget

AnimatedContainer繼承自ImplicitlyAnimatedWidget,什么是ImplicitlyAnimatedWidget呢?翻譯過(guò)來(lái)就是隱式的動(dòng)畫widget。

這個(gè)widget會(huì)自動(dòng)根據(jù)widget屬性的變化生成對(duì)應(yīng)的動(dòng)畫。在使用上非常的簡(jiǎn)單。

AnimatedContainers使用舉例

AnimatedContainer是一個(gè)container,所以它可以包含child屬性,但是AnimatedContainer的動(dòng)畫只是針對(duì)容器本身來(lái)說(shuō)的,動(dòng)畫并不會(huì)應(yīng)用到它的child中。

所以為了展示widget本身的變化,我們可以給widget設(shè)置一個(gè)BoxDecoration,設(shè)置它的顏色跟borderRadius。

如下所示:

body: Center(
          child: AnimatedContainer(
            width: 200,
            height: 200,
            decoration: BoxDecoration(
              color: Colors.blue,
              borderRadius: BorderRadius.circular(10),
            ),
            duration: const Duration(seconds: 1),
            curve: Curves.easeInBack,
          ),
        )

上面的代碼會(huì)在界面上展示一個(gè)長(zhǎng)度和寬度都等于200的Container,它的背景是blue,還有一個(gè)圓形的borderRadius。

并且我們定義了動(dòng)畫的duration和變動(dòng)曲線的方式。

接下來(lái)我們只需要在setState方法中對(duì)AnimatedContainer中的屬性進(jìn)行變化,就會(huì)自動(dòng)觸發(fā)動(dòng)畫效果。

為了實(shí)現(xiàn)這個(gè)動(dòng)畫的功能,我們需要把width,height等屬性用動(dòng)態(tài)變量存儲(chǔ)起來(lái),這樣才可以在setState的時(shí)候?qū)傩赃M(jìn)行變動(dòng)。

我們將這些屬性放在一個(gè)StatefulWidget的State中:

  double _width = 100;
  double _height = 100;
  Color _color = Colors.blue;
  BorderRadiusGeometry _borderRadius = BorderRadius.circular(10);

這樣我們?cè)赽uild方法中使用上面定義的屬性:

        body: Center(
          child: AnimatedContainer(
            width: _width,
            height: _height,
            decoration: BoxDecoration(
              color: _color,
              borderRadius: _borderRadius,
            ),
            duration: const Duration(seconds: 1),
            curve: Curves.easeInBack,
          ),
        )

然后在floatingActionButton的onPressed中修改這些屬性,從而實(shí)現(xiàn)widget屬性變化的動(dòng)畫功能:

floatingActionButton: FloatingActionButton(
          onPressed: () {
            setState(() {
              final random = Random();
              _width = random.nextInt(200).toDouble();
              _height = random.nextInt(200).toDouble();
              _color = Color.fromRGBO(
                random.nextInt(256),
                random.nextInt(256),
                random.nextInt(256),
                1,
              );
              _borderRadius =
                  BorderRadius.circular(random.nextInt(10).toDouble());
            });
          }

最后實(shí)現(xiàn)的效果如下:

總結(jié)

如果你只是希望使用簡(jiǎn)單的widget動(dòng)畫,那么AnimatedContainer可能是你最好的選擇。

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

到此這篇關(guān)于Android Flutter制作一個(gè)修改組件屬性的動(dòng)畫的文章就介紹到這了,更多相關(guān)Android Flutter動(dòng)畫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Android LayoutParams使用案例詳解

    Android LayoutParams使用案例詳解

    這篇文章主要介紹了Android LayoutParams使用案例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • Android 基于agora 開發(fā)視頻會(huì)議的代碼

    Android 基于agora 開發(fā)視頻會(huì)議的代碼

    這篇文章主要介紹了Android 基于agora 開發(fā)視頻會(huì)議,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • Android Studio使用小技巧:提取方法代碼片段

    Android Studio使用小技巧:提取方法代碼片段

    這篇文章主要介紹了Android Studio使用小技巧:提取方法代碼片段,本文分享了一個(gè)快速?gòu)?fù)制粘貼方法代碼片段的小技巧,并用GIF圖演示,需要的朋友可以參考下
    2015-05-05
  • Android 仿余額寶數(shù)字跳動(dòng)動(dòng)畫效果完整代碼

    Android 仿余額寶數(shù)字跳動(dòng)動(dòng)畫效果完整代碼

    這篇文章主要介紹了Android 仿余額寶數(shù)字跳動(dòng)動(dòng)畫效果完整代碼,需要的朋友可以參考下
    2017-11-11
  • Android多點(diǎn)觸控技術(shù)實(shí)戰(zhàn) 針對(duì)圖片自由縮放和移動(dòng)

    Android多點(diǎn)觸控技術(shù)實(shí)戰(zhàn) 針對(duì)圖片自由縮放和移動(dòng)

    這篇文章主要為大家詳細(xì)介紹了Android多點(diǎn)觸控技術(shù)實(shí)戰(zhàn),自由地對(duì)圖片進(jìn)行縮放和移動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • Android實(shí)現(xiàn)3D標(biāo)簽云效果

    Android實(shí)現(xiàn)3D標(biāo)簽云效果

    這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)3D標(biāo)簽云效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • 在不同Activity之間傳遞數(shù)據(jù)的四種常用方法

    在不同Activity之間傳遞數(shù)據(jù)的四種常用方法

    這篇文章主要介紹了在不同Activity之間傳遞數(shù)據(jù)的四種常用方法 的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • Jetpack?Compose入門基礎(chǔ)全面精講

    Jetpack?Compose入門基礎(chǔ)全面精講

    開始布局部分。這部分我個(gè)人感覺(jué)沒(méi)有必要每個(gè)組件、屬性都詳細(xì)說(shuō)到,否則篇幅會(huì)很長(zhǎng)。建立起Compose中的組件與?Android?Views的一個(gè)對(duì)應(yīng)關(guān)系就夠了。具體還是需要在實(shí)際的使用中去熟悉
    2022-10-10
  • 利用Flutter繪制出3D效果動(dòng)畫

    利用Flutter繪制出3D效果動(dòng)畫

    本文主要介紹了Flutter繪圖的Path的應(yīng)用。Flutter的Path類提供了一個(gè)三維空間的變換方法,可以實(shí)現(xiàn)路徑在三維空間的平移、旋轉(zhuǎn)等操作,從而可以實(shí)現(xiàn)3D繪制的效果,感興趣的可以了解一下
    2022-08-08
  • Android中為activity創(chuàng)建菜單

    Android中為activity創(chuàng)建菜單

    這篇文章主要為大家詳細(xì)介紹了Android中為activity創(chuàng)建菜單的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02

最新評(píng)論