снимок экрана
Я пытаюсь реализовать просмотр списка карт с вертикальной прокруткой. Когда я использую стек, я не могу прокрутить их плавно. Поэтому я решил использовать CustomScrollView и SliverPersistentHeader. К сожалению, список SliverPersistentHeader не может касаться нижнего виджета при прокрутке. Кто-нибудь может спасти мой день?
class StackedList extends StatefulWidget {
@override
_StackedListState createState() => _StackedListState();
}
class _StackedListState extends State<StackedList> {
final List<Color> colors = Colors.primaries;
static const _minHeight = 24.0;
static const _maxHeight = 80.0;
@override
Widget build(BuildContext context) {
List<Color> _colors = List();
_colors.addAll(colors);
return CustomScrollView(
physics: ClampingScrollPhysics(),
shrinkWrap: false,
slivers: <Widget>[
..._colors
.map(
(color) => StackedListChild(
minHeight: _minHeight,
maxHeight: _maxHeight,
floating: false,
pinned: true,
child: getCard(
cardId: _colors.indexOf(color).toString(),
color: color,
),
),
)
.toList(),
],
);
}
}
class StackedListChild extends StatelessWidget {
final double minHeight;
final double maxHeight;
final bool pinned;
final bool floating;
final Widget child;
SliverPersistentHeaderDelegate get _delegate => _StackedListDelegate(
minHeight: minHeight, maxHeight: maxHeight, child: child);
const StackedListChild({
Key key,
@required this.minHeight,
@required this.maxHeight,
@required this.child,
this.pinned = false,
this.floating = false,
}) : assert(child != null),
assert(minHeight != null),
assert(maxHeight != null),
assert(pinned != null),
assert(floating != null),
super(key: key);
@override
Widget build(BuildContext context) => SliverPersistentHeader(
key: key, pinned: pinned, floating: floating, delegate: _delegate);
}
class _StackedListDelegate extends SliverPersistentHeaderDelegate {
final double minHeight;
final double maxHeight;
final Widget child;
_StackedListDelegate({
@required this.minHeight,
@required this.maxHeight,
@required this.child,
});
@override
double get minExtent => minHeight;
@override
double get maxExtent => math.max(maxHeight, minHeight);
@override
Widget build(
BuildContext context, double shrinkOffset, bool overlapsContent) {
return new SizedBox.expand(child: child);
}
@override
bool shouldRebuild(_StackedListDelegate oldDelegate) {
return maxHeight != oldDelegate.maxHeight ||
minHeight != oldDelegate.minHeight ||
child != oldDelegate.child;
}
}