Объекту RenderListWheelViewport был присвоен бесконечный размер во время макета - PullRequest
0 голосов
/ 29 апреля 2020

Я использую ListWheelScrollView Виджет, чтобы придать эффекту моего элемента списка, но получаю ошибку, как уже упоминалось. Я просто хочу показать Stacked Items с некоторыми изображениями и текстами в отдельном элементе списка и дать им эффект 3D Wheeling.

Ниже мой код ->

class ExploreWidget extends StatefulWidget {
  @override
  State<StatefulWidget> createState() => _ExploreState();
}

class _ExploreState extends State<ExploreWidget> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: null,
      body: Column(
        children: <Widget>[
          _header(),
          _exploreList()
        ],
      )
    );

  }

  Widget _header(){
    return SizedBox(
      height: 200,
      width: 800,
    );

  }

  Widget _exploreList(){
    return ListWheelScrollView.useDelegate(
      itemExtent: 75,
      childDelegate: ListWheelChildBuilderDelegate(
        builder:(context,index){
          return Container(
            height: 500,
            width: 800,
            child: Stack(
              children: <Widget>[
                Image(image: AssetImage(
                  _products[index].image
                )),
                Text(_products[index].name,style: Style.sectionTitleWhite,),
                Text('70% off',style: Style.cardListTitleWhite,),
              ],
            ),
          );
        }
      ),
    );
  }

}

1 Ответ

1 голос
/ 29 апреля 2020

Произошла ошибка из-за способа реализации виджета _exploreList(). Этот виджет находится внутри Column, который не прокручивается сам по себе. Кроме того, вы возвращаете ScrollView, который имеет бесконечный размер. Следовательно, он выбрасывал указанную ошибку. Чтобы решить эту проблему, оберните _exploreList() виджет внутри Flexible, который занимает только минимальное доступное пространство для рендеринга и прокрутки. Рабочий пример кода ниже:

body: Column(
          children: <Widget>[
            _header(),
            Flexible(
              child: _exploreList()
            )
          ],
        )

Теперь вы сможете правильно использовать WheelScrollView.

enter image description here

...