build method
The widget to place inside the SliverPersistentHeader.
The context
is the BuildContext of the sliver.
The shrinkOffset
is a distance from maxExtent towards minExtent
representing the current amount by which the sliver has been shrunk. When
the shrinkOffset
is zero, the contents will be rendered with a dimension
of maxExtent in the main axis. When shrinkOffset
equals the difference
between maxExtent and minExtent (a positive number), the contents will
be rendered with a dimension of minExtent in the main axis. The
shrinkOffset
will always be a positive number in that range.
The overlapsContent
argument is true if subsequent slivers (if any) will
be rendered beneath this one, and false if the sliver will not have any
contents below it. Typically this is used to decide whether to draw a
shadow to simulate the sliver being above the contents below it. Typically
this is true when shrinkOffset
is at its greatest value and false
otherwise, but that is not guaranteed. See NestedScrollView for an
example of a case where overlapsContent
's value can be unrelated to
shrinkOffset
.
Implementation
@override
Widget build(
BuildContext context,
double shrinkOffset,
bool overlapsContent,
) {
final offset = min(shrinkOffset, maxExtent - minExtent);
final progress = offset / (maxExtent - minExtent);
final visibleMainHeight = max(maxExtent - shrinkOffset, minExtent);
return Material(
elevation: progress < 1 ? expandedElevation : collapsedElevation,
child: Stack(
fit: StackFit.expand,
children: [
if (background != null) background!.transform(progress),
Container(
height: visibleMainHeight,
padding: EdgeInsets.only(top: statusBarHeight),
color: backgroundColor ?? Theme.of(context).appBarTheme.color,
child: Stack(
fit: StackFit.expand,
children: [
if (builder != null) builder!(context, progress),
if (children != null)
...children!.map((item) => item.transform(progress)).toList(),
],
),
),
AppBar(
backgroundColor: Colors.transparent,
actions: actions,
leading: leading,
title: title,
elevation: 0,
),
],
),
);
}