欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Flutter利用SizeTransition實現(xiàn)組件飛入效果

 更新時間:2022年04月13日 08:50:19   作者:島上碼農  
本文將為大家介紹SizeTransition,SizeTransition用于更改子組件的尺寸來實現(xiàn)動畫,支持垂直方向或水平方向修改動畫。本文將利用其實現(xiàn)組件飛入效果,需要的可以參考一下

前言

繼續(xù) Transition 系列動畫組件的介紹,本篇來介紹 SizeTransition。SizeTransition 用于更改子組件的尺寸來實現(xiàn)動畫。支持垂直方向或水平方向修改動畫,同時尺寸更改的起始位置可以從頂部、中部、底部(垂直方向)或左側、中間、右側(水平方向)開始。通過這些特性,我們可以構建組件飛入的效果。

SizeTransition 介紹

SizeTransition 的構造方法定義如下。

const?SizeTransition({
??Key??key,
??this.axis?=?Axis.vertical,
??required?Animation<double>?sizeFactor,
??this.axisAlignment?=?0.0,
??this.child,
})?

參數(shù)對應的說明如下:

axis:枚舉,vertical 標識縱向更改組件尺寸,即更改組件高度;horizontal 表示橫向更改組件尺寸,即更改組件寬度。

sizeFactor:即控制組件尺寸變化的 Animation 對象。實際上在動畫過程中就是組件尺寸的寬度(horizontal)或高度(vertical)乘以**Animation**的值。

axisAlignment:即動畫過程中,子組件的對齊位置,默認為0.0,是從中間開始更改尺寸;當axisvertical時,-1.0代表頂部對齊開始動畫(即尺寸從上到下開始變大);當 axis 為horizontal 時,開始的方向和文本的反向有關(TextDirection.ltr 還是 TextDirection.rtl),當文本為從左到右時(TextDirection.ltr,默認),-1.0表示從左側開始動畫(即尺寸從左到右開始變大)。

應用

對于我們的飛入動畫來說,我們要實現(xiàn)從左向右飛入動畫效果,因此需要設置 axis 為水平方向,然后 axisAligment 為右側。對于圖片,找一個橫向飛行的超人,然后加上動畫后就可以實現(xiàn)超人飛入的效果了。完整源碼如下:

class?SizeTransitionDemo?extends?StatefulWidget?{
??SizeTransitionDemo({Key??key})?:?super(key:?key);

??@override
??_SizeTransitionDemoState?createState()?=>?_SizeTransitionDemoState();
}

class?_SizeTransitionDemoState?extends?State<SizeTransitionDemo>
????with?SingleTickerProviderStateMixin?{
??late?AnimationController?_controller?=
??????AnimationController(duration:?const?Duration(seconds:?3),?vsync:?this)
????????..repeat();

??//使用自定義曲線動畫過渡效果
??late?Animation<double>?_animation?=?CurvedAnimation(
??????parent:?_controller,?curve:?Curves.fastLinearToSlowEaseIn);

??@override
??Widget?build(BuildContext?context)?{
????return?Scaffold(
??????appBar:?AppBar(
????????title:?Text('SizeTransition'),
????????brightness:?Brightness.dark,
????????backgroundColor:?Colors.blue,
??????),
??????body:?SizeTransition(
????????child:?Center(
??????????child:?Image.asset(
????????????'images/superman.png',
????????????width:?300.0,
????????????height:?300.0,
??????????),
????????),
????????sizeFactor:?_animation,
????????axis:?Axis.horizontal,
????????axisAlignment:?1.0,
??????),
????);
??}

??@override
??void?dispose()?{
????_controller.stop();
????_controller.dispose();
????super.dispose();
??}
}

使用 SizeTransition 實現(xiàn)其他動畫效果

我們可以設置動畫從中間開始,這樣會有一種卷軸打開的效果,比如我們找一幅卷軸畫來看看效果。

這個動畫的實現(xiàn)代碼如下:

Widget?build(BuildContext?context)?{
??return?Scaffold(
????appBar:?AppBar(
??????title:?Text('SizeTransition'),
??????brightness:?Brightness.dark,
??????backgroundColor:?Colors.blue,
????),
????body:?Container(
??????alignment:?Alignment.center,
??????child:?SizeTransition(
????????child:?Image.asset(
??????????'images/juanzhou.png',
????????),
????????sizeFactor:?_animation,
????????axis:?Axis.horizontal,
????????axisAlignment:?0.0,
??????),
????),
??);
}

總結

本篇介紹了使用 SizeTransition 控制組件尺寸更改來實現(xiàn)飛入或展開的動畫效果。SizeTransition 也可以用于那種滑入滑出的動畫場合,比如列表元素的插入使用下滑入,列表元素的刪除使用上滑出。

以上就是Flutter利用SizeTransition實現(xiàn)組件飛入效果的詳細內容,更多關于Flutter組件飛入的資料請關注腳本之家其它相關文章!

相關文章

  • Android截屏保存png圖片的實例代碼

    Android截屏保存png圖片的實例代碼

    這篇文章主要介紹了Android截屏保存png圖片的小例子,可以在應用提供這個小功能,很實用的
    2013-11-11
  • 你用不慣 RxJava,只因缺了這把鑰匙(推薦)

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

    這篇文章主要介紹了RxJava操作符,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • Android基于OpenCV實現(xiàn)Harris角點檢測

    Android基于OpenCV實現(xiàn)Harris角點檢測

    角點就是極值點,即在某方面屬性特別突出的點。當然,你可以自己定義角點的屬性(設置特定熵值進行角點檢測)。角點可以是兩條線的交叉處,也可以是位于相鄰的兩個主要方向不同的事物上的點。本文介紹如何基于OpenCV實現(xiàn)Harris角點檢測
    2021-06-06
  • Android實現(xiàn)朋友圈評論回復列表

    Android實現(xiàn)朋友圈評論回復列表

    這篇文章主要為大家詳細介紹了Android實現(xiàn)朋友圈評論回復列表,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Android實現(xiàn)選擇相冊圖片并顯示功能

    Android實現(xiàn)選擇相冊圖片并顯示功能

    這篇文章主要為大家詳細介紹了Android實現(xiàn)選擇相冊圖片并顯示功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • android獲取當前運行Activity名字的方法

    android獲取當前運行Activity名字的方法

    這篇文章主要介紹了android獲取當前運行Activity名字的方法,對比分析了兩種實現(xiàn)方法供大家選擇,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • Flutter路由的幾種用法小結

    Flutter路由的幾種用法小結

    這篇文章主要介紹了Flutter路由的幾種用法,包括基本路由跳轉和路由跳轉傳參方法,本文結合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • 怎樣實現(xiàn)android http-post方法實例說明

    怎樣實現(xiàn)android http-post方法實例說明

    android http-post方法在開發(fā)中如何實現(xiàn),具體代碼如下,感興趣的朋友可以參考下哈,希望對大家有所幫助
    2013-06-06
  • Android ListView position詳解及實例代碼

    Android ListView position詳解及實例代碼

    這篇文章主要介紹了Android ListView position的相關資料,在開發(fā)Android 應用的時候你真的用對了嗎?這里給大家徹底解釋下,需要的朋友可以參考下
    2016-10-10
  • Android 序列化的存儲和讀取總結及簡單使用

    Android 序列化的存儲和讀取總結及簡單使用

    這篇文章主要介紹了Android 序列化的存儲和讀取總結及簡單使用的相關資料,Serializable接口和Parcelable接口,本文對這兩種方式進行簡單的總結和使用,需要的朋友可以參考下
    2016-12-12

最新評論