Как убрать пробел между виджетами в колонке во флаттере? - PullRequest
0 голосов
/ 08 января 2019

Я искал ответ, но не смог найти.

Почему виджет Column дает пространство между дочерними виджетами?
Я хочу удалить это для моего макета виджета. Ниже мой код и позиция пробела.

enter image description here

код !!

import 'package:flutter/material.dart';
import 'package:flutter/services.dart';

void main() {
  SystemChrome.setEnabledSystemUIOverlays([]);
  runApp(MyApp());
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Clock',
      theme: ThemeData(
        primaryColor: Colors.blue
      ),
      home: Social(),
      debugShowCheckedModeBanner: false,
    );
  }
}

class Social extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        backgroundColor: Colors.white,
        elevation: 0.0
      ),
      backgroundColor: Colors.white,
      body: Column(
        children: <Widget>[
          Flexible(
            flex: 1,
            child: Row(
              children: <Widget>[
                ClipOval(
                  clipper: CircleClipper(),
                  child: Image.asset('assets/irene.jpg')
                ),
                Expanded(
                  child: Padding(
                    padding: const EdgeInsets.only(left: 8.0),
                    child: Column(
                      mainAxisAlignment: MainAxisAlignment.start,
                      children: <Widget>[
                        Align(
                          alignment: Alignment.centerLeft,
                          child: Text(
                            'Irene',
                            style: TextStyle(
                              color: Colors.blue,
                              fontWeight: FontWeight.bold,
                              fontSize: 15.0
                            )
                          )
                        ),
                        Align(
                          alignment: Alignment.centerLeft,
                          child: Text('Yesterday, Ney York')
                        )
                      ],
                    ),
                  ),
                ),
                Align(
                  alignment: Alignment.topRight,
                  child: IconButton(
                    color: Theme.of(context).primaryColor,
                    icon: Icon(Icons.menu),
                    onPressed: (){},
                  ),
                )
              ],
            ),
          ),
          Container(
            width: MediaQuery.of(context).size.width/1.1,
            height: MediaQuery.of(context).size.height/2,
            child: Card(
              child: Image.asset('assets/irene.jpg'),
              color: Colors.white,
              shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(30.0)),
              elevation: 10.0,
            ),
          ),
          Padding(
            padding: const EdgeInsets.only(left: 30.0,right: 30.0,top: 15.0),
            child: Row(
              children: <Widget>[
                Image(
                  image: AssetImage('assets/like.png'), 
                  width: 30.0,
                  height: 30.0,
                ),
                SizedBox(width: 20.0,),
                Image.asset('assets/chat.png'),
                Expanded(child: Container()),
                Image.asset('assets/share.png'),
              ],
            ),
          ),
          Expanded(child: Container()),
        ],
      ),
    );
  }
}

class CircleClipper extends CustomClipper<Rect> {
  @override
  Rect getClip(Size size) {
    return Rect.fromCircle(center: Offset(size.width/2,size.height/4), radius: size.width/3);
  }

  @override
  bool shouldReclip(CustomClipper<Rect> oldClipper) {
    return true;
  }
}

Как это исправить и какие виджеты мне нужно использовать?
Чтобы сделать размер дочернего виджета Column, я должен использовать Flexible, Expanded и т. Д.
Есть ли другие виджеты, которые могут удовлетворить это условие?

Ответы [ 2 ]

0 голосов
/ 08 января 2019

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

Вот исправление:

1- Нет необходимости для виджета, просто удалите его.

Flexible(
        flex: 1, ...)

2- Установите правильные размеры для вашего аватара, обернув его в Container, например так:

Container(
  width: 50,
  height: 50,
  child: ClipOval(clipper: CircleClipper(), child: Image.asset('assets/irene.jpg')),
)

Наконец, вот обновленный полный код:

import 'package:flutter/material.dart';
import 'package:flutter/services.dart';

    void main() {
      SystemChrome.setEnabledSystemUIOverlays([]);
      runApp(MyApp());
    }

    class MyApp extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return MaterialApp(
          title: 'Flutter Clock',
          theme: ThemeData(primaryColor: Colors.blue),
          home: Social(),
          debugShowCheckedModeBanner: false,
        );
      }
    }

    class Social extends StatelessWidget {
      @override
      Widget build(BuildContext context) {
        return Scaffold(
          appBar: AppBar(backgroundColor: Colors.white, elevation: 0.0),
          backgroundColor: Colors.white,
          body: Column(
            children: <Widget>[
              Row(
                children: <Widget>[
                  Container(
                    width: 50,
                    height: 50,
                    child: ClipOval(clipper: CircleClipper(), child: Image.asset('assets/irene.jpg')),
                  ),
                  Expanded(
                    child: Padding(
                      padding: const EdgeInsets.only(left: 8.0),
                      child: Column(
                        mainAxisAlignment: MainAxisAlignment.start,
                        children: <Widget>[
                          Align(
                              alignment: Alignment.centerLeft,
                              child: Text('Irene',
                                  style: TextStyle(color: Colors.blue, fontWeight: FontWeight.bold, fontSize: 15.0))),
                          Align(alignment: Alignment.centerLeft, child: Text('Yesterday, Ney York'))
                        ],
                      ),
                    ),
                  ),
                  Align(
                    alignment: Alignment.topRight,
                    child: IconButton(
                      color: Theme.of(context).primaryColor,
                      icon: Icon(Icons.menu),
                      onPressed: () {},
                    ),
                  )
                ],
              ),
              Container(
                width: MediaQuery.of(context).size.width / 1.1,
                height: MediaQuery.of(context).size.height / 2,
                child: Card(
                  child: Image.asset('assets/irene.jpg'),
                  color: Colors.white,
                  shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(30.0)),
                  elevation: 10.0,
                ),
              ),
              Padding(
                padding: const EdgeInsets.only(left: 30.0, right: 30.0, top: 15.0),
                child: Row(
                  children: <Widget>[
                    Icon(Icons.thumb_up, color: Colors.black),
                    SizedBox(
                      width: 20.0,
                    ),
                    Icon(Icons.chat, color: Colors.black),
                    Expanded(child: Container()),
                    Icon(Icons.share, color: Colors.black),
                  ],
                ),
              ),
              Expanded(child: Container()),
            ],
          ),
        );
      }
    }
0 голосов
/ 08 января 2019

Это потому, что вы используете Flexible, и он расширяет Widget внутри, чтобы заполнить доступное пространство.

Изменить это:

   body: Column(
          children: <Widget>[
            Flexible(
              flex: 1,

К этому:

   body: Column(
          children: <Widget>[
            SizedBox(
              height: 60.0,

И это должно работать

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...