class _MyHomePageState extends State with TickerProviderStateMixin {
AnimationController _controller;
Animation _animationBS;
AnimationController _controllerColor;
Animation<Color> _animation;
@override
void initState() {
// TODO: implement initState
super.initState();
_controller = AnimationController(
vsync: this,
duration: Duration(milliseconds: 1000));
_controller.addListener(() {
setState(() {//这里一定要设置setState,不然变大缩小动画不生效
});
});
_animationBS =Tween(begin: 50.0,end: 100.0).chain(CurveTween(curve: Curves.easeOut)).animate(_controller);
_controllerColor = AnimationController(
vsync: this, duration: Duration(milliseconds: 1000));
_animation = ColorTween(begin: Colors.blue,end: Colors.amber).animate(_controllerColor);
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: Container(
child: Center(
child: InkWell(
onTap: () {
if (_controller.isDismissed) {
_controller.forward();
} else {
_controller.reverse();
}
if (_controllerColor.isDismissed) {
_controllerColor.forward();
} else {
_controllerColor.reverse();
}
},
child: Container(
width: _animationBS.value,
height: _animationBS.value,
decoration: BoxDecoration(shape: BoxShape.circle ,color: _animation.value),
),
),
),
),
);
}
@override
void dispose() {
super.dispose();
_controller.dispose();
_controllerColor.dispose();
}
}
Flutter的Animation简单用法
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...