【发布时间】:2019-11-27 17:25:25
【问题描述】:
我在颤动中使用动画列表加载列表类,在添加或删除项目时,动画可以工作,但是当列表最初加载时,动画不起作用。有没有办法在最初加载列表时为项目设置动画。
class AnimationTest extends StatefulWidget {
@override
_AnimationTestState createState() => _AnimationTestState();
}
class _AnimationTestState extends State<AnimationTest> with SingleTickerProviderStateMixin {
AnimationController _controller;
@override
void initState() {
_controller = AnimationController(
vsync: this,
duration: const Duration(seconds: 1),
);
super.initState();
}
@override
void dispose() {
_controller.dispose();
super.dispose();
}
@override
Widget build(BuildContext context) {
return AnimatedList(
key: _listKey,
initialItemCount: 3,
itemBuilder: (BuildContext context, int index, Animation animation) {
return SlideTransition(
position: animation.drive(Tween<Offset>(begin: Offset(1.0, 0.0), end: Offset.zero)
.chain(CurveTween(curve: Curves.decelerate))),
child: Row(
children: <Widget>[
Expanded(
child: InkWell(
onTap: () => _listKey.currentState.insertItem(0,duration: Duration(milliseconds: 600)),
child: Container(
padding: EdgeInsets.only(left: 10, right: 10),
height: 100,
child: Card(
margin: EdgeInsets.symmetric(vertical: 4.0),
color: Theme.of(context).backgroundColor,
)),
),
),
],
),
);
},
);
}
}
【问题讨论】:
-
AnimatedList 只会对添加/删除的项目进行动画处理。这意味着列表最初开始的项目不会被动画化。一种选择是从一个空列表开始,然后将每个项目附加到您的动画列表中,并在呈现此小部件时更新动画列表的状态。
标签: flutter flutter-animation flutter-animatedlist