我正在尝试将圆角边框设置为MaterialButton,要做到这一点,我正在设置RoundedRectangleBorder来塑造属性的MaterialButton,问题是它没有效果。

代码:

  Widget _showNeedHelpButton() {
    return new Padding(
      padding: EdgeInsets.fromLTRB(0.0, 5.0, 0.0, 0.0),
      child: new MaterialButton(
        shape: RoundedRectangleBorder(borderRadius: BorderRadius.all(Radius.circular(20.0))),
        elevation: 5.0,
        minWidth: 200.0,
        height: 35,
        color: Color(0xFF801E48),
        child: new Text('Preciso de ajuda',
            style: new TextStyle(fontSize: 16.0, color: Colors.white)),
        onPressed: () {
          setState(() {
            _isNeedHelp = true;
          });
        },
      ),
    );
  }

结果:

dart - 如何在Flutter上为MaterialButton设置圆角边框?-LMLPHP

最佳答案

如果您需要使用MaterialButton()-您需要使用Material小部件对按钮进行扭曲,以获得所需的行为。

    Widget _showNeedHelpButton() {
    return Padding(
      padding: EdgeInsets.fromLTRB(0.0, 5.0, 0.0, 0.0),
      child: Material(  //Wrap with Material
        shape: RoundedRectangleBorder(borderRadius:BorderRadius.circular(22.0) ),
        elevation: 18.0,
        color: Color(0xFF801E48),
        clipBehavior: Clip.antiAlias, // Add This
        child: MaterialButton(
          minWidth: 200.0,
          height: 35,
          color: Color(0xFF801E48),
          child: new Text('Preciso de ajuda',
              style: new TextStyle(fontSize: 16.0, color: Colors.white)),
          onPressed: () {
//          setState(() {
//            _isNeedHelp = true;
//          });
          },
        ),
      ),
    );
  }

输出:
dart - 如何在Flutter上为MaterialButton设置圆角边框?-LMLPHP

更新:
  minWidth: 200.0,
  height: 95,

dart - 如何在Flutter上为MaterialButton设置圆角边框?-LMLPHP

10-01 05:03