AnimatedList class
A scrolling container that animates items when they are inserted or removed.
This widget's AnimatedListState can be used to dynamically insert or remove items. To refer to the AnimatedListState either provide a GlobalKey or use the static of method from an item's input callback.
This widget is similar to one created by ListView.builder.
This sample application uses an AnimatedList to create an effect when
items are removed or added to the list.
link
To create a local project with this code sample, run:
flutter create --sample=widgets.AnimatedList.1 mysample
By default, AnimatedList will automatically pad the limits of the
list's scrollable to avoid partial obstructions indicated by
MediaQuery's padding. To avoid this behavior, override with a
zero padding
property.
The following example demonstrates how to override the default top and
bottom padding using MediaQuery.removePadding.
link
Widget myWidget(BuildContext context) {
return MediaQuery.removePadding(
context: context,
removeTop: true,
removeBottom: true,
child: AnimatedList(
initialItemCount: 50,
itemBuilder: (BuildContext context, int index, Animation<double> animation) {
return Card(
color: Colors.amber,
child: Center(child: Text('$index')),
);
}
),
);
}
See also:
- SliverAnimatedList, a sliver that animates items when they are inserted or removed from a list.
- SliverAnimatedGrid, a sliver which animates items when they are inserted or removed from a grid.
- AnimatedGrid, a non-sliver scrolling container that animates items when they are inserted or removed in a grid.
- Inheritance
-
- Object
- DiagnosticableTree
- Widget
- StatefulWidget
- AnimatedList
Constructors
- AnimatedList({Key? key, required AnimatedItemBuilder itemBuilder, int initialItemCount = 0, Axis scrollDirection = Axis.vertical, bool reverse = false, ScrollController? controller, bool? primary, ScrollPhysics? physics, bool shrinkWrap = false, EdgeInsetsGeometry? padding, Clip clipBehavior = Clip.hardEdge})
-
Creates a scrolling container that animates items when they are inserted
or removed.
const
- AnimatedList.separated({Key? key, required AnimatedItemBuilder itemBuilder, required AnimatedItemBuilder separatorBuilder, required AnimatedItemBuilder removedSeparatorBuilder, int initialItemCount = 0, Axis scrollDirection = Axis.vertical, bool reverse = false, ScrollController? controller, bool? primary, ScrollPhysics? physics, bool shrinkWrap = false, EdgeInsetsGeometry? padding, Clip clipBehavior = Clip.hardEdge})
- A scrolling container that animates items with separators when they are inserted or removed.
Properties
- clipBehavior → Clip
-
The content will be clipped (or not) according to this option.
finalinherited
- controller → ScrollController?
-
An object that can be used to control the position to which this scroll
view is scrolled.
finalinherited
- hashCode → int
-
The hash code for this object.
no setterinherited
- initialItemCount → int
-
The number of items the AnimatedList or AnimatedGrid will start with.
finalinherited
- itemBuilder → AnimatedItemBuilder
-
Called, as needed, to build children widgets.
finalinherited
- key → Key?
-
Controls how one widget replaces another widget in the tree.
finalinherited
- padding → EdgeInsetsGeometry?
-
The amount of space by which to inset the children.
finalinherited
- physics → ScrollPhysics?
-
How the scroll view should respond to user input.
finalinherited
- primary → bool?
-
Whether this is the primary scroll view associated with the parent
PrimaryScrollController.
finalinherited
- removedSeparatorBuilder → AnimatedItemBuilder?
-
Called, as needed, to build separator widgets.
finalinherited
- reverse → bool
-
Whether the scroll view scrolls in the reading direction.
finalinherited
- runtimeType → Type
-
A representation of the runtime type of the object.
no setterinherited
- scrollDirection → Axis
-
The Axis along which the scroll view's offset increases.
finalinherited
- shrinkWrap → bool
-
Whether the extent of the scroll view in the
scrollDirection
should be determined by the contents being viewed.finalinherited
Methods
-
createElement(
) → StatefulElement -
Creates a StatefulElement to manage this widget's location in the tree.
inherited
-
createState(
) → AnimatedListState -
Creates the mutable state for this widget at a given location in the tree.
override
-
debugDescribeChildren(
) → List< DiagnosticsNode> -
Returns a list of DiagnosticsNode objects describing this node's
children.
inherited
-
debugFillProperties(
DiagnosticPropertiesBuilder properties) → void -
Add additional properties associated with the node.
inherited
-
noSuchMethod(
Invocation invocation) → dynamic -
Invoked when a nonexistent method or property is accessed.
inherited
-
toDiagnosticsNode(
{String? name, DiagnosticsTreeStyle? style}) → DiagnosticsNode -
Returns a debug representation of the object that is used by debugging
tools and by DiagnosticsNode.toStringDeep.
inherited
-
toString(
{DiagnosticLevel minLevel = DiagnosticLevel.info}) → String -
A string representation of this object.
inherited
-
toStringDeep(
{String prefixLineOne = '', String? prefixOtherLines, DiagnosticLevel minLevel = DiagnosticLevel.debug, int wrapWidth = 65}) → String -
Returns a string representation of this node and its descendants.
inherited
-
toStringShallow(
{String joiner = ', ', DiagnosticLevel minLevel = DiagnosticLevel.debug}) → String -
Returns a one-line detailed description of the object.
inherited
-
toStringShort(
) → String -
A short, textual description of this widget.
inherited
Operators
-
operator ==(
Object other) → bool -
The equality operator.
inherited
Static Methods
-
maybeOf(
BuildContext context) → AnimatedListState? - The AnimatedListState from the closest instance of AnimatedList that encloses the given context.
-
of(
BuildContext context) → AnimatedListState - The state from the closest instance of this class that encloses the given context.