Виджет столбца флаттера: дети с разной высотой - PullRequest
0 голосов
/ 27 октября 2018

Я пытаюсь создать небольшое тестовое приложение с большой центральной областью, на которую я буду рендерить изображение, и меньшую нижнюю область, которая будет содержать горизонтальный прокручиваемый список виджетов.Вот код:

import 'dart:convert';

import 'package:flutter/material.dart';
import 'package:http/http.dart' as http;
import 'dart:async';
import 'dart:isolate';    
import 'package:fluttertoast/fluttertoast.dart';    
import 'package:photo_app_ui_test/fxmanager/fx_manager.dart';

////    
void main() {
  runApp(SampleApp());
}

class SampleApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Sample App',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: SampleAppPage(),
    );
  }
}

class SampleAppPage extends StatefulWidget {
  SampleAppPage({Key key}) : super(key: key);

  @override
  _SampleAppPageState createState() => _SampleAppPageState();
}

class _SampleAppPageState extends State<SampleAppPage> {
  FxManager fxManager;
  bool      showLoadingDialog = true;

  @override
  void initState() {
    super.initState();
    //loadData();
    fxManager = FxManager();
    fxManager.init().then( (dynamic) => initInterface() );
  }


  void initInterface(){
    setState(() {
      showLoadingDialog = false;
    });
  }

  getBody() {
    if (showLoadingDialog) {
      return getProgressDialog();
    } else {
      return getEffectsWidget();//getListView();
    }
  }

  getProgressDialog() {
    return Center(child: CircularProgressIndicator());
  }

  getEffectsWidget() {
    return

      Column(
          children: <Widget>[

            Expanded(child: Container(color: Color.fromARGB(255, 255, 0, 0),
                child: Center(child: Text("Image")))),
            Flexible( child: Container(
                color: Color.fromARGB(255, 0, 255, 0),
                child: ListView(
                    scrollDirection: Axis.horizontal,
                    children: _getListData()
                )))
          ]);
  }

  _getListData() {
    List<Widget> widgets = [];
    for (int i = 0; i < 100; i++) {
      widgets.add(Padding(
          padding: EdgeInsets.all(10.0),
          child: Column(
            children: <Widget>[
              /*
              Expanded(
                child: Container(),
              ),*/
              FlatButton(
                  onPressed: () => {},
                  color: Colors.orange,
                  padding: EdgeInsets.all(10.0),
                  child: Column(
                    // Replace with a Row for horizontal icon + text
                    children: <Widget>[Icon(Icons.add), Text("Add")],
                  )),
            ],
          )));
    }
    return widgets;
  }


  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
          title: Text("Sample App"),
        ),
        body: getBody());
  }


}

, чтобы получить этот результат:

enter image description here

Я хотел бы сделать высоту зеленой рамки маленькойнасколько возможно:

enter image description here

Если виджет ListView является прямым потомком виджета Column, выдается обычное исключение Horizontal viewport was given unbounded height.Поэтому я должен вставить его в Flexible или Expanded.

1 Ответ

0 голосов
/ 27 октября 2018

Желаемый вывод:

getEffectsWidget() {
    return Column(children: <Widget>[
      Expanded(
          child: Container(
              color: Color.fromARGB(255, 255, 0, 0),
              child: Center(child: Text("Image")))),

       Container(
            color: Color.fromARGB(255, 0, 255, 0),
            child: SingleChildScrollView(
              scrollDirection: Axis.horizontal,
              child: Row(
                children: _getListData(),
              ),
            ),
      )
    ]);
  }

static _getListData() {
    List<Widget> widgets = [];
    for (int i = 0; i < 100; i++) {
      widgets.add(Padding(
          padding: EdgeInsets.only(right: 10.0), 
          child: Column(
            mainAxisSize: MainAxisSize.min,
            children: <Widget>[
              /*
              Expanded(
                child: Container(),
              ),*/
              FlatButton(
                  onPressed: () => {},
                  color: Colors.orange,
                  padding: EdgeInsets.all(10.0),
                  child: Column(
                    mainAxisSize: MainAxisSize.min,
                    // Replace with a Row for horizontal icon + text
                    children: <Widget>[Icon(Icons.add), Text("Add")],
                  )),
            ],
          )));
    }
    return widgets;
  }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...