Я хочу знать, как я могу установить ширину соответствие родительскому ширину макета

new Container(
  width: 200.0,
  padding: const EdgeInsets.only(top: 16.0),
  child: new RaisedButton(
    child: new Text(
      "Submit",
      style: new TextStyle(
        color: Colors.white,
      )
    ),
    colorBrightness: Brightness.dark,
    onPressed: () {
      _loginAttempt(context);
    },
    color: Colors.blue,
  ),
),

Я знаю немного о расширенном виджете, но расширенном расширяет вид в обоих направлениях, я не знаю, как это сделать.

Mohit Suthar

Ответов: 23

Ответы (23)

Обновление:

С Flutter 2.0 RaisedButton устарел и заменяется ElevatedButton. вы можете использовать minimumSize вот так:

ElevatedButton(
        style: ElevatedButton.styleFrom(
          minimumSize: Size.fromHeight(40), // fromHeight use double.infinity as width and 40 is the height
        ),
        onPressed: () {},
        child: Text('Text Of Button'),
      )

Старый ответ для Flutter меньше 2.0:

Правильным решением было бы использовать виджет SizedBox.expand, который заставляет его дочерний соответствовать размеру своего родителя.

SizedBox.expand(
  child: RaisedButton(...),
)

Есть много альтернатив, которые позволяют более или менее настраивать:

SizedBox(
  width: double.infinity,
  // height: double.infinity,
  child: RaisedButton(...),
)

или используя ConstrainedBox

ConstrainedBox(
    constraints: const BoxConstraints(minWidth: double.infinity),
    child: RaisedButton(...),
)

Использование ListTile также работает, поскольку список заполняет всю ширину:

ListTile(
  title: new RaisedButton(...),
),

@ Мохит Сутар,

Найдено одно из лучших решений для сопоставить родительский с шириной, а также высотой, как показано ниже

new Expanded(
          child: new Container(
              padding: EdgeInsets.all(16.0),
              margin: EdgeInsets.all(16.0),
              decoration: new BoxDecoration(
                  color: Colors.white,
                  borderRadius:
                      const BorderRadius.all(const Radius.circular(8.0)),
                  border: new Border.all(color: Colors.black, width: 1.0)),
              child: new Text("TejaDroid")),
        ), 

Здесь вы можете проверить, что Расширенный Контроллер получает все остается ширина и высота.

вы можете сделать это с помощью MaterialButton

MaterialButton(
     padding: EdgeInsets.all(12.0),
     minWidth: double.infinity,
     onPressed: () {},
    child: Text("Btn"),
)

У меня сработало

width: MediaQuery.of(context).size.width-100,

Самый простой способ указать ширину или высоту родительского совпадения в приведенном выше коде.

...
width: double.infinity,
height: double.infinity,
...

RaisedButton ( ребенок: Ряд ( mainAxisAlignment: MainAxisAlignment.center, дети: [Текст ('Отправить')], ) ) У меня работает.

Самый простой способ - использовать FlatButton, завернутый в Контейнер. Кнопка по умолчанию принимает размер своего родителя и, таким образом, присваивает желаемую ширину контейнеру ..

            Container(
                  color: Colors.transparent,
                  width: MediaQuery.of(context).size.width,
                  height: 60,
                  child: FlatButton(
                    shape: new RoundedRectangleBorder(
                      borderRadius: new BorderRadius.circular(30.0),
                    ),
                    onPressed: () {},
                    color: Colors.red[300],
                    child: Text(
                      "Button",
                      style: TextStyle(
                        color: Colors.black,
                        fontFamily: 'Raleway',
                        fontSize: 22.0,
                      ),
                    ),
                  ),
                )

Вывод:

enter image description here

Вы можете установить соответствие родительского элемента виджета

1) установить ширину double.infinity:

new Container(
          width: double.infinity,
          padding: const EdgeInsets.only(top: 16.0),
          child: new RaisedButton(
            child: new Text(
                "Submit",
                style: new TextStyle(
                  color: Colors.white,
                )
            ),
            colorBrightness: Brightness.dark,
            onPressed: () {
              _loginAttempt(context);
            },
            color: Colors.blue,
          ),
        ),

2) Используйте MediaQuery:

new Container(
          width: MediaQuery.of(context).size.width,
          padding: const EdgeInsets.only(top: 16.0),
          child: new RaisedButton(
            child: new Text(
                "Submit",
                style: new TextStyle(
                  color: Colors.white,
                )
            ),
            colorBrightness: Brightness.dark,
            onPressed: () {
              _loginAttempt(context);
            },
            color: Colors.blue,
          ),
        ),

You can set the fixedSize.width of the ButtonStyle to a very large number, like double.maxFinite. You can also use Size.fromWidth() constructor if you don't want to specify the height:

ElevatedButton(
  child: const Text('Button'),
  style: ElevatedButton.styleFrom(
    fixedSize: const Size.fromWidth(double.maxFinite),
  ),
),

Живая демонстрация

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

Когда вы используете вложенные виджеты, тогда сложно определить ширину родительского виджета. Просто вы не можете указать ширину во вложенных виджетах. Таким образом, вы должны использовать либо Expanded, либо Column с CrossAxisAlignment как Strech.

In other cases, you can use media query width or double.infinity.

Вот несколько примеров для вложенных виджетов и одиночного виджета:

Первый:

Expanded(   // This will work for nested widgets and will take width of first parent widget.
  child: MaterialButton(
    onPressed: () {},
    child: const Text("Button Text"),
    color: Colors.indigo,
    textColor: Colors.white,
  )
)

Второй:

Column( // This will not work if parent widget Row.
  crossAxisAlignment: CrossAxisAlignment.stretch,
  children: [
    MaterialButton(
      onPressed: () {},
      child: const Text("Button Text"),
      color: Colors.indigo,
      textColor: Colors.white,
    )
  ]
)

Третий:

ButtonTheme( // if use media query, then will not work for nested widgets.
  minWidth: double.infinity,  //Or use 'width: MediaQuery.of(context).size.width'
  child: MaterialButton(
    onPressed: () {},
    child: const Text("Button Text"),
    color: Colors.indigo,
    textColor: Colors.white,
  )
)

Четверть:

SizedBox( // if use media query, then will not work for nested widgets.
  width: double.infinity, //Or use 'width: MediaQuery.of(context).size.width'
  child: MaterialButton(
    onPressed: () {},
    child: const Text("Button Text"),
    color: Colors.indigo,
    textColor: Colors.white,
  )
)

Пятый:

Container( // if use media query, then will not work for nested widgets.
  width: double.infinity, //Or use 'width: MediaQuery.of(context).size.width'
  child: MaterialButton(
    onPressed: () {},
    child: const Text("Button Text"),
    color: Colors.indigo,
    textColor: Colors.white,
  )
)

С моей точки зрения, рекомендуемый будет Первый. Также вы можете изменить MaterialButton на ElevatedButton или TextButton или RaisedButton (устаревший) или любой другой виджет.

Ура!

Следующий код работает для меня

       ButtonTheme(
            minWidth: double.infinity,
            child: RaisedButton(child: Text("Click!!", style: TextStyle(color: Colors.white),), color: Colors.pink, onPressed: () {}))
 new SizedBox(
  width: 100.0,
     child: new RaisedButton(...),
)

Это работает для меня.

    SizedBox(
             width: double.maxFinite,
             child: RaisedButton(
                 materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
                 child: new Text("Button 2"),
                 color: Colors.lightBlueAccent,
                 onPressed: () => debugPrint("Button 2"),
              ),
     ), 

Оберните ваш (дочерний виджет фиксированной ширины) центральным виджетом. Это будет центрировать ваш виджет:

Center(child:Container(width:250,child:TextButton(child:Text("Button Name),),)

Это работает для меня в автономном виджете.

  Widget signinButton() {
    return ButtonTheme(
      minWidth: double.infinity,
      child: new FlatButton(
        onPressed: () {},
        color: Colors.green[400],
        textColor: Colors.white,
        child: Text('Flat Button'),
      ),
    );
  }

// It can then be used in a class that contains a widget tree.
         OutlineButton(
              onPressed: () {
                logInButtonPressed(context);
              },
              child: Container(
                width: MediaQuery.of(context).size.width / 2,
                child: Text(
                  “Log in”,
                  textAlign: TextAlign.center,
                ),
              ),
            )

У меня работает примерно так.

Самый простой подход - использовать Контейнер, определяя его ширину до бесконечности. См. Ниже пример кода

Container(
    width: double.infinity,
    child:FlatButton(
        onPressed: () {
            //your action here
        },
        child: Text("Button"),

    )
)

Атрибут размера может быть предоставлен с помощью ButtonTheme с minWidth: double.infinity

ButtonTheme(
  minWidth: double.infinity,
  child: MaterialButton(
    onPressed: () {},
    child: Text('Raised Button'),
  ),
),

или после https://github.com/flutter/flutter/pull/19416 приземлился

MaterialButton(
  onPressed: () {},
  child: SizedBox.expand(
    width: double.infinity, 
    child: Text('Raised Button'),
  ),
),

После некоторого исследования я нашел какое-то решение, и благодаря @ Günter Zöchbauer,

Я использовал столбец вместо контейнера и

установить свойство в столбец CrossAxisAlignment.stretch, чтобы заполнить соответствующий родительский элемент кнопки

    new Column(
              crossAxisAlignment: CrossAxisAlignment.stretch,
              children: [
                new RaisedButton(
                  child: new Text(
                      "Submit",
                      style: new TextStyle(
                        color: Colors.white,
                      )
                  ),
                  colorBrightness: Brightness.dark,
                  onPressed: () {
                    _loginAttempt(context);
                  },
                  color: Colors.blue,
                ),
              ],
            ),

С Flutter 2.0 RaisedButton устарел и заменяется ElevatedButton.

minimumSize свойство виджета ElevatedButton делает именно это.

Пример кода:

ElevatedButton(
            style: ElevatedButton.styleFrom(
              primary: Colors.green,
              onPrimary: Colors.white,
              shadowColor: Colors.greenAccent,
              elevation: 3,
              shape: RoundedRectangleBorder(
                  borderRadius: BorderRadius.circular(20.0)),
              minimumSize: Size(100, 40), //////// HERE
            ),
            onPressed: () {},
            child: Text('MyButton'),
          )

Для match_parent вы можете использовать

SizedBox(
  width: double.infinity, // match_parent
  child: RaisedButton(...)
)

Для любого конкретного значения вы можете использовать

SizedBox(
  width: 100, // specific value
  child: RaisedButton(...)
)
Container(
  width: double.infinity,
  child: RaisedButton(...),
),

2022 WebDevInsider