【自学Flutter】32 交错动画的使用,先收藏了
在Flutter中,交错动画可以通过AnimatedList
小部件实现。AnimatedList
提供了插入、移动和删除动画的能力。以下是一个简单的使用AnimatedList
的例子:
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: HomePage(),
);
}
}
class HomePage extends StatefulWidget {
@override
_HomePageState createState() => _HomePageState();
}
class _HomePageState extends State<HomePage> {
final GlobalKey<AnimatedListState> _listKey = GlobalKey();
final List<int> _items = List<int>.generate(10, (i) => i);
void _insert(int index, int item) {
_items.insert(index, item);
_listKey.currentState.insertItem(index);
}
void _remove(int index) {
final int item = _items.removeAt(index);
_listKey.currentState.removeItem(index, (context, animation) => _buildItem(item, animation));
}
Widget _buildItem(int item, Animation<double> animation) {
return SlideTransition(
position: Tween<Offset>(
begin: const Offset(0.0, 1.0),
end: const Offset(0.0, 0.0),
).animate(animation),
child: Card(
child: ListTile(
title: Text('Item $item'),
trailing: IconButton(
icon: Icon(Icons.delete),
onPressed: () => _remove(item),
),
),
),
);
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: AnimatedList(
key: _listKey,
initialItemCount: _items.length,
itemBuilder: (context, index, animation) =>
_buildItem(_items[index], animation),
),
floatingActionButton: FloatingActionButton(
onPressed: () => _insert(_items.length, _items.length),
child: Icon(Icons.add),
),
);
}
}
这个例子中,我们创建了一个AnimatedList
,并通过_buildItem
函数为列表中的每个项创建了一个带有插入和删除动画的Widget。_insert
和_remove
方法用于处理列表项的插入和删除,并通过_listKey.currentState
更新AnimatedList
的状态。
评论已关闭