gpt4 book ai didi

dart - 如何在多个项目之间分配空间

转载 作者:IT老高 更新时间:2023-10-28 12:42:59 27 4
gpt4 key购买 nike

我正在尝试添加一个覆盖屏幕 前 20% 的图像,而其他 80% 应该是卡片网格。图片需要在正文中,并且不在应用栏上。我制作了卡片网格,然后尝试将图像和网格放在一个列中。实现如下。

  @override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
primary: true,
appBar: AppBar(
elevation: 4.0,
backgroundColor: Color(0xfff8f8f8),
title: Center(child: titleLogo,),
),
//------------ PROBLEM BELOW ----------------
body: new Column(
children: <Widget>[
titleLogo, //Image object
TheGridView().build() //Returns a GridView object
],
),
),
);

}

我收到以下错误

I/flutter (21751): The following assertion was thrown during performResize():
I/flutter (21751): Vertical viewport was given unbounded height.
I/flutter (21751): Viewports expand in the scrolling direction to fill their container.In this case, a vertical
I/flutter (21751): viewport was given an unlimited amount of vertical space in which to expand. This situation
I/flutter (21751): typically happens when a scrollable widget is nested inside another scrollable widget.
I/flutter (21751): If this widget is always nested in a scrollable widget there is no need to use a viewport because
I/flutter (21751): there will always be enough vertical space for the children. In this case, consider using a Column
I/flutter (21751): instead. Otherwise, consider using the "shrinkWrap" property (or a ShrinkWrappingViewport) to size
I/flutter (21751): the height of the viewport to the sum of the heights of its children.

非常感谢任何建议。提前谢谢你。

最佳答案

要在多个项目之间分配空间,您应该使用 Expanded像这样的小部件:

return new Column(
children: <Widget>[
new Expanded(
flex: 2,
child: new Container(
color: Colors.red,
),
),
new Expanded(
flex: 8,
child: new Container(//use your Gridview instead
color: Colors.green,
)
)
],

);

enter image description here

关于dart - 如何在多个项目之间分配空间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50880701/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com