web-dev-qa-db-fra.com

Flutter Layout Row / Column - partager la largeur, augmenter la hauteur

J'ai toujours un peu de mal avec la mise en page dans Flutter.
En ce moment, je veux partager l'espace disponible entre 3 widgets, dans une disposition en quadrant. La largeur est également partagée (cela fonctionne très bien via 2 Expanded widgets dans une rangée), mais maintenant je veux aussi que la hauteur s'ajuste automatiquement afin que widget3.height == widget1.height + widget2.height. layout Si le contenu de widget3 est plus grand, je veux widget1 et widget2 pour ajuster leur hauteur et vice versa.

Est-ce même possible dans Flutter?

40
TommyF

Jetez un oeil à IntrinsicHeight ; l'habillage de la ligne racine devrait fournir l'effet que vous recherchez:

import 'package:flutter/material.Dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: Scaffold(
        appBar: AppBar(title: Text('Rows & Columns')),
        body: RowsAndColumns(),
      ),
    );
  }
}

class RowsAndColumns extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Padding(
      padding: const EdgeInsets.only(top: 100.0),
      child: IntrinsicHeight(
        child: Row(crossAxisAlignment: CrossAxisAlignment.stretch, children: [
          Expanded(
            child: Column(children: [
              Container(height: 120.0, color: Colors.yellow),
              Container(height: 100.0, color: Colors.cyan),
            ]),
          ),
          Expanded(child: Container(color: Colors.amber)),
        ]),
      ),
    );
  }
}

L'ajustement des hauteurs des conteneurs de la colonne entraîne le redimensionnement du conteneur de droite pour qu'il corresponde:

screenshot

https://Gist.github.com/mjohnsullivan/c5b661d7b3b4ca00599e8ef87ff6ac61

103
Matt S.