在 Flutter 中,AnimatedPositionedDirectional 组件应用在 Stack 中,当位置或者是大小改变时,呈动画效果
const AnimatedPositionedDirectional({
Key? key,
required this.child,
this.start,
this.top,
this.end,
this.bottom,
this.width,
this.height,
Curve curve = Curves.linear,
required Duration duration,
VoidCallback? onEnd,
})
- start 如果当前的环境是 TextDirection.ltr 文字方向从左向右,则是左对齐,反之是右对齐
- end 如果当前的环境是 TextDirection.ltr 文字方向从左向右,则是右对齐,反之是左对齐
- width 限制子组件的宽度
- heght 限制子组件的高度
- curve 动画曲线 速率
- duration 动画执行时间
- onEnd 动画执行完成回调方法
使用 Demo
Directionality(
// TextDirection.ltr left to right 从左到右
// TextDirection.rtl rtl right to left
textDirection: TextDirection.ltr,
child: Stack(
children: [
AnimatedPositionedDirectional(
top: 100,
start: 100,
width: 100,
height: 200,
duration: Duration(seconds: 2),
//执行结束回调
onEnd: () {},
//动画曲线
curve: Curves.fastOutSlowIn,
child: Container(
color: Colors.blue,
child: Text("早起的年轻人"),
),
),
],
),
)
如果你有兴趣 你可以关注一下公众号 biglead 来获取最新的学习资料。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。