title | description | type |
---|---|---|
AnimatedPadding |
控件介绍 |
widgets |
AnimatedPadding是一个隐式的动画组件,提供动态改变内边距的动画组件,用法如下:
var _padding = 0.0;
AnimatedPadding(
padding: EdgeInsets.symmetric(horizontal: _padding),
duration: Duration(seconds: 2),
child: Container(color: Colors.red),
)
duration
参数是动画执行的时间。如果仅仅是构建这样一个组件是不会有动画效果,需要让padding
参数发生变化,点击按钮设置新的_padding
值:
RaisedButton(
onPressed: () {
setState(() {
_padding = 50;
});
},
)
效果如下:
通过curve
参数设置动画执行的曲线,默认直线执行,系统提供了很多中动画执行曲线,比如加速、减速、弹簧等,用法如下:
AnimatedOpacity(
curve: Curves.easeIn,
...
)
如果想要在动画执行结束时处理一些事情,可以在onEnd
回调中处理,用法如下:
AnimatedOpacity(
onEnd: (){
//动画执行结束回调
},
...
)