Android?Flutter制作一個(gè)修改組件屬性的動(dòng)畫
簡介
什么是動(dòng)畫呢?動(dòng)畫實(shí)際上就是不同的圖片連續(xù)起來形成的。flutter為我們提供了一個(gè)AnimationController來對動(dòng)畫進(jìn)行詳盡的控制,不過直接是用AnimationController是比較復(fù)雜的,如果只是對一個(gè)widget的屬性進(jìn)行修改,可以做成動(dòng)畫嗎?
答案是肯定的,一起來看看吧。
flutter中的動(dòng)畫widget
如果你只是希望動(dòng)畫展示widget的屬性的變化,比如比如長度,高度,寬度或者顏色等進(jìn)行動(dòng)態(tài)變化,那么可以直接使用flutter提供的AnimatedContainer。
先來看下AnimatedContainer的定義:
class AnimatedContainer extends ImplicitlyAnimatedWidget
AnimatedContainer繼承自ImplicitlyAnimatedWidget,什么是ImplicitlyAnimatedWidget呢?翻譯過來就是隱式的動(dòng)畫widget。
這個(gè)widget會(huì)自動(dòng)根據(jù)widget屬性的變化生成對應(yīng)的動(dòng)畫。在使用上非常的簡單。
AnimatedContainers使用舉例
AnimatedContainer是一個(gè)container,所以它可以包含child屬性,但是AnimatedContainer的動(dòng)畫只是針對容器本身來說的,動(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è)長度和寬度都等于200的Container,它的背景是blue,還有一個(gè)圓形的borderRadius。
并且我們定義了動(dòng)畫的duration和變動(dòng)曲線的方式。
接下來我們只需要在setState方法中對AnimatedContainer中的屬性進(jìn)行變化,就會(huì)自動(dòng)觸發(fā)動(dòng)畫效果。
為了實(shí)現(xiàn)這個(gè)動(dòng)畫的功能,我們需要把width,height等屬性用動(dòng)態(tài)變量存儲(chǔ)起來,這樣才可以在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);
這樣我們在build方法中使用上面定義的屬性:
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é)
如果你只是希望使用簡單的widget動(dòng)畫,那么AnimatedContainer可能是你最好的選擇。
本文的例子:github.com/ddean2009/learn-flutter
到此這篇關(guān)于Android Flutter制作一個(gè)修改組件屬性的動(dòng)畫的文章就介紹到這了,更多相關(guān)Android Flutter動(dòng)畫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android自定義View實(shí)現(xiàn)QQ運(yùn)動(dòng)積分轉(zhuǎn)盤抽獎(jiǎng)功能
這篇文章主要為大家詳細(xì)介紹了Android自定義View實(shí)現(xiàn)QQ運(yùn)動(dòng)積分轉(zhuǎn)盤抽獎(jiǎng)功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10
Android實(shí)現(xiàn)拖動(dòng)小球跟隨手指移動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)拖動(dòng)小球跟隨手指移動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03
Android實(shí)現(xiàn)老虎機(jī)小游戲代碼示例
大家好,本篇文章主要講的是Android實(shí)現(xiàn)老虎機(jī)小游戲代碼示例,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12
Android自定義View實(shí)現(xiàn)水面上漲效果
這篇文章給大家介紹了利用Android自定義View實(shí)現(xiàn)水面上漲效果,對大家日常開發(fā)很有幫助,有需要的朋友們可以參考借鑒。2016-09-09
Android使用百度地圖出現(xiàn)閃退及定位時(shí)顯示藍(lán)屏問題的解決方法
這篇文章主要介紹了Android使用百度地圖出現(xiàn)閃退及定位時(shí)顯示藍(lán)屏問題的解決方法,需要的朋友可以參考下2018-01-01

