我正在尝试使用Horizontally scrollable cards with Snap effect in flutter中的PageView,PageController和ListView制作轮播。但这引发了异常...
══╡渲染库引起的异常CA ══════════════════════ I / flutter(17678):在performResize()期间引发了以下断言: I / flutter(17678):水平视口的高度不受限制。 I / flutter(17678):视口在横轴上扩展以填充其容器并约束其子项以匹配 I /颤振(17678):其在横轴上的范围。在这种情况下,水平视口被无限量地 I / flutter(17678):要在其中扩展的垂直空间。
有人可以帮我修复它吗?
我想在背景图像,变换类和淡入淡出过渡的堆栈中添加此轮播。
@override
void initState() {
super.initState();
controller = PageController(
initialPage: 0,
keepPage: true,
);
@override
Widget build(BuildContext context) {
return AnimatedBuilder(
builder: (BuildContext context, Widget child) {
return Scaffold(
//BODY
body: ListView(children: <Widget>[
new Stack(
children: <Widget>[
new AspectRatio(...),
new Transform(...),
//THIS IS
new ListView.builder(
itemCount: 3,
scrollDirection: Axis.horizontal,
padding: EdgeInsets.symmetric(vertical: 16.0),
itemBuilder: (BuildContext context, int index) {
if (index % 3 == 0) {
return _buildCarousel(context, index ~/ 3);
} else {
return Divider();
}
},
),
}
}
}
Widget _buildCarousel(BuildContext context, int carouselIndex) {
return Column(
mainAxisSize: MainAxisSize.min,
children: <Widget>[
Text('Carousel $carouselIndex'),
SizedBox(
// you may want to use an aspect ratio here for tablet support
height: 200.0,
child: PageView.builder(
// store this controller in a State to save the carousel scroll position
controller: PageController(viewportFraction: 0.8),
itemBuilder: (BuildContext context, int itemIndex) {
return _buildCarouselItem(context, carouselIndex, itemIndex);
},
),
)
],
);
Widget _buildCarouselItem(
BuildContext context, int carouselIndex, int itemIndex) {
return Padding(
padding: EdgeInsets.symmetric(horizontal: 4.0),
child: Container(
decoration: BoxDecoration(
color: Colors.grey,
borderRadius: BorderRadius.all(Radius.circular(4.0)),
),
),
);
答案 0 :(得分:0)
您可能已经从错误中猜到了,基本上,这意味着由于您没有指定有限的高度,ListView
会变得无限高。
尝试在shrinkWrap: true
和ListView.builder
中使用ListView
。
或者,您也可以尝试将ListView
包裹在有限高度的Container
或SizedBox
中。
示例-
Container(
height: 200.0,
child: ListView(
/*Remaining Code*/
),
)
您可以尝试使用ListView.builder