SliverList 上的粘性标题

And*_*sky 8 flutter

我看过新的颤振视频,也看到了一些有趣的东西。(这不是典型的粘性标题或可扩展列表,所以我不知道如何命名)

视频- 从 0:20 开始观看

有人知道如何使用 SliverList 创建带有标题的此类列表吗?

在此处输入图片说明

Zro*_*roq 15

一种方法是使用您的小部件创建一个CustomScrollView并传递一个SliverAppBar固定对象true和一个SliverFixedExtentList对象。

例子:

List<Widget> _sliverList(int size, int sliverChildCount) {
    var widgetList = new List<Widget>();
    for (int index = 0; index < size; index++)
      widgetList
        ..add(SliverAppBar(
           title: Text("Title $index"),
           pinned: true,
         ))
        ..add(SliverFixedExtentList(
          itemExtent: 50.0,
          delegate:
              SliverChildBuilderDelegate((BuildContext context, int index) {
                   return Container(
                      alignment: Alignment.center,
                      color: Colors.lightBlue[100 * (index % 9)],
                      child: Text('list item $index'),
                   );
              }, childCount: sliverChildCount),
        ));

   return widgetList;
}

@override
Widget build(BuildContext context) {
  return Scaffold(
    appBar: AppBar(
      title: Text("Slivers"),
    ),
    body: CustomScrollView(
      slivers: _sliverList(50, 10),
    ),
  );
}
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

  • 如何一次只显示一个应用栏?现在它只是不断添加,如果数量太多,布局看起来很奇怪。 (9认同)

use*_*613 11

SliverPersistentHeaderSliverAppBar您可以使用的更通用的小部件。

SliverPersistentHeader(
    delegate: SectionHeaderDelegate("Section B"),
    pinned: true,
),
Run Code Online (Sandbox Code Playgroud)

并且SectionHeaderDelegate可以通过以下方式实现:

class SectionHeaderDelegate extends SliverPersistentHeaderDelegate {
  final String title;
  final double height;

  SectionHeaderDelegate(this.title, [this.height = 50]);

  @override
  Widget build(context, double shrinkOffset, bool overlapsContent) {
    return Container(
      color: Theme.of(context).primaryColor,
      alignment: Alignment.center,
      child: Text(title),
    );
  }

  @override
  double get maxExtent => height;

  @override
  double get minExtent => height;

  @override
  bool shouldRebuild(SliverPersistentHeaderDelegate oldDelegate) => false;
}
Run Code Online (Sandbox Code Playgroud)