gpt4 book ai didi

gridview - 如何在 Flutter 的 GridView 中为 Widget 设置自定义高度?

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

即使在为 Container GridView 指定高度之后,我的代码仍会生成方形小部件。

class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);

final String title;

@override
_MyHomePageState createState() => new _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
List<String> widgetList = ['A', 'B', 'C'];

@override
Widget build(BuildContext context) {
return new Scaffold(
appBar: new AppBar(
title: new Text(widget.title),
),
body: new Container(
child: new GridView.count(
crossAxisCount: 2,
controller: new ScrollController(keepScrollOffset: false),
shrinkWrap: true,
scrollDirection: Axis.vertical,
children: widgetList.map((String value) {
return new Container(
height: 250.0,
color: Colors.green,
margin: new EdgeInsets.all(1.0),
child: new Center(
child: new Text(
value,
style: new TextStyle(fontSize: 50.0,color: Colors.white),
),
),
);
}).toList(),
),
),
);
}
}

上面代码的输出如左图所示。如何获得带有自定义高度小部件的 GridView,如右图所示?

output Required Output

最佳答案

关键是childAspectRatio。此值用于确定 GridView 中的布局。为了获得所需的方面,您必须将其设置为 (itemWidth/itemHeight)。解决方案是这样的:

class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);

final String title;

@override
_MyHomePageState createState() => new _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
List<String> widgetList = ['A', 'B', 'C'];

@override
Widget build(BuildContext context) {
var size = MediaQuery.of(context).size;

/*24 is for notification bar on Android*/
final double itemHeight = (size.height - kToolbarHeight - 24) / 2;
final double itemWidth = size.width / 2;

return new Scaffold(
appBar: new AppBar(
title: new Text(widget.title),
),
body: new Container(
child: new GridView.count(
crossAxisCount: 2,
childAspectRatio: (itemWidth / itemHeight),
controller: new ScrollController(keepScrollOffset: false),
shrinkWrap: true,
scrollDirection: Axis.vertical,
children: widgetList.map((String value) {
return new Container(
color: Colors.green,
margin: new EdgeInsets.all(1.0),
child: new Center(
child: new Text(
value,
style: new TextStyle(
fontSize: 50.0,
color: Colors.white,
),
),
),
);
}).toList(),
),
),
);
}
}

关于gridview - 如何在 Flutter 的 GridView 中为 Widget 设置自定义高度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48405123/

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