15

在 Flutter 2.0 版本中,FlatButton已将TextButton.

因此,填充属性不再直接可用,而是作为ButtonStyle属性。

我的问题是,我该如何设置它,因为它不再可用EdgeInsets

TextButton(
   style: new ButtonStyle(
     padding: ???,
   ),
   //padding: const EdgeInsets.all(0),   //NOT AVAILABLE
   child: Text("Support", style: Theme.of(context).textTheme.headline2),
      onPressed: () => {Navigator.pushNamed(context, SupportScreen().routeName)},
   ),
4

3 回答 3

28

这是我的 TextButton 代码

Container(
    child: TextButton(
    style: ButtonStyle(
        backgroundColor:
            MaterialStateProperty.all<Color>(Colors.green),
        padding: MaterialStateProperty.all<EdgeInsets>(
            EdgeInsets.all(10)),
    ),
    child: Text(
        "Login",
        style: TextStyle(
        height: 1.0,
        fontSize: 30,
        color: Colors.white,
        ),
    ),
    onPressed: () => {print("login")},
    ),  
),

请参阅我使用 TextButton 小部件的样式属性来插入填充和背景,并且我使用了 MaterialStateProperty.all

于 2021-04-10T16:55:56.227 回答
9

例如,您可以这样做:

TextButton(
              onPressed: () {},
              child: Text('Hello World'),
              style: TextButton.styleFrom(
                padding: EdgeInsets.fromLTRB(10, 10, 10, 10),
                primary: Colors.teal,
              ),
            ),

TextButton.styleFrom() 参考文档: https ://api.flutter.dev/flutter/material/TextButton-class.html

带有新按钮的示例和游戏: https ://www.woolha.com/tutorials/flutter-using-textbutton-widget-examples

于 2021-03-04T14:17:57.243 回答
1

您可以为 MaterialStates 设置不同的值:

class TextButtonPadding extends StatelessWidget {
  EdgeInsets _getPadding(Set<MaterialState> states) {
    const interactiveStates = <MaterialState>{
      MaterialState.pressed,
      MaterialState.hovered,
    };
    if (states.any(interactiveStates.contains)) {
      return EdgeInsets.all(30.0);
    }
    return EdgeInsets.zero;
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Container(
        child: TextButton(
          style: ButtonStyle(
            padding: MaterialStateProperty.resolveWith(_getPadding),
          ),
          onPressed: () {},
          child: Text(
            'Text Button',
          ),
        ),
      ),
    );
  }
}

或者为所有 MaterialStates 设置一个值:

class TextButtonPadding extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Container(
        child: TextButton(
          style: ButtonStyle(
            padding: MaterialStateProperty.all(
              EdgeInsets.all(30.0),
            ),
          ),
          onPressed: () {},
          child: Text(
            'Text Button',
          ),
        ),
      ),
    );
  }
}

请参阅https://api.flutter.dev/flutter/material/MaterialStateProperty-class.html

于 2021-03-13T10:25:18.270 回答