Рендерфлекс, заполненный 21 пикселем внизу

#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,),
),