一尘不染

flutter - SliverList / SliverChildBuilderDelegate supply initial index orallow negative indices

flutter

我目前正在使用SliverList和
SliverChildBuilderDelegate 在Flutter中构建日历视图,这样我就不必一次渲染
日历中的每个项目。

第一个日期是纪元时间,即1970年1月1日,最后一个日期是
在今天的日期之后计算出的奇数时间。

我的问题是,当我第一次渲染视图时,我希望它
从今天开始而不是从1970年1月1日开始渲染视图。但是,如果我今天使用0
索引,则不允许(或提供)负索引到构建者委托,
因此您无法从该日期开始向上滚动。
据我所知,您也无法向构建器或列表提供初始索引,因此我也无法将时间
作为0索引,因为列表只是从此处开始,这非常
糟糕经验!我不确定如何进行。

有人有什么建议吗?


阅读 667

收藏
2020-08-13

共1个答案

一尘不染

我不知道执行此操作的简便方法,initialPosititionin ListViewin中都没有参数SliverList。我能想到的原因是
列表是嵌入在上的一系列小部件ScrollView,因此为了设置初始项目,您需要知道该项目的确切滚动偏移量。

默认情况下,这两个列表窗口小部件不对其项目的高度做任何假设,因此通常发现偏移量将要求您一一计算所有窗口小部件的高度,这效率很低。

但是,如果您事先知道所有列表项的高度,或者可以通过ListView.itemExtent字段或强制它们固定高度,则可以使事情变得容易SliverFixedExtentList

如果你知道(或强迫)列表项的高度事前,您可以通过设置初始项目initialScrollOffset在你的ScrollController。这是带有的示例ListView

@override
Widget build(BuildContext context) {
  final _itemExtent = 56.0; // I know item heights beforehand
  final generatedList = List.generate(500, (index) => 'Item $index');

  return ListView(
    controller: ScrollController(initialScrollOffset: _itemExtent * 401),
    children: generatedList
        .map((index) =>
            ListTile(title: Text(index, style: TextStyle(fontSize: 20.0))))
        .toList(),
  );
}

Or in a SliverList.

@override
Widget build(BuildContext context) {
  final _itemExtent = 56.0;
  final generatedList = List.generate(500, (index) => 'Item $index');

  return CustomScrollView(
    controller: ScrollController(initialScrollOffset: _itemExtent * 401),
    slivers: [
      SliverFixedExtentList(
        itemExtent: _itemExtent,  // I'm forcing item heights
        delegate: SliverChildBuilderDelegate(
          (context, index) => ListTile(
                title: Text(
                  generatedList[index],
                  style: TextStyle(fontSize: 20.0),
                ),
              ),
          childCount: generatedList.length,
        ),
      ),
    ],
  );
}

在这两种情况下,这都是您首次打开应用程序时的结果。

2020-08-13