#flutter #android-studio #gridview #flutter-layout
Вопрос:
Я новичок в флаттере и пытаюсь использовать вид сетки, но он показывает гибкое отображение, заполненное 21 пикселями внизу. В представлении сетки я использую картинку, но она показывает ошибку. Кто-нибудь знает, как это исправить? Спасибо
Я ищу в Интернете, он использует SingleChildScrollView, но я не хочу его использовать, потому что он выглядит странно для представления сетки
Вот мой код
import 'package:flutter/material.dart';
import 'package:monger_app/page/detail.dart';
class BudgetSettings extends StatefulWidget {
@override
_BudgetSettingsState createState() => _BudgetSettingsState();
}
class _BudgetSettingsState extends State<BudgetSettings> {
List<Container> categorylist = new List();
var character=[
{"name":"Food", "image":"food.png"},
{"name":"Social-Life", "image":"travel.png"},
{"name":"Transportation", "image":"transportation.png"},
{"name":"Beauty", "image":"makeup.png"},
{"name":"Household", "image":"household.png"},
{"name":"Education", "image":"education.png"},
{"name":"Health", "image":"health.png"},
{"name":"Gift", "image":"gift.png"},
{"name":"Other", "image":"other.png"},
];
_makelist() async {
for (var i = 0; i < character.length; i ) {
final newcharacter = character[i];
final String image = newcharacter["image"];
categorylist.add(
new Container(
padding: new EdgeInsets.all(20.0),
child: new Card( child:
new Column(
children: <Widget>[
new Image.asset('assets/$image', fit: BoxFit.cover,),
new Padding(padding: new EdgeInsets.all(5.0),),
new Text(newcharacter['name'], style: new TextStyle(fontSize: 18.0),),
],
),
),
)
);
}
}
@override
void initState() {
_makelist();
super.initState();
}
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('Budget Setting'),
),
body: new GridView.count(
crossAxisCount: 2,
children: categorylist,
),
);
}
}
Ответ №1:
Простое решение вашей проблемы-это обернуть виджет с изображением в гибкий виджет, вот так:
Flexible(
child: Image.asset('assets/$image', fit: BoxFit.cover,),
),