flutter - How to create TextButton rounded border

Flutter - TextButton Rounded Border
The TextButton class represents a material design text button. The flutter developers can use text buttons on toolbars, in dialogs, or in line with other content. Text buttons do not have visible borders. The flutter developers should avoid using text buttons where they would blend in with other content such as in the middle of lists. The TextButton style can be overridden with its style parameter.

The following flutter application development tutorial will demonstrate how we can add a rounded border to the TextButton. We will draw a solid colored rounded corners border around a TextButton. In the below example code, we will use the TextButton class’s styleFrom() method to add a rounded border around the TextButton widget.

The TextButton class’s styleFrom() method is a static convenience method that constructs a text button ButtonStyle given simple values. By default, TextButton class styleFrom() method returns a ButtonStyle that doesn't override anything.

The ButtonStyle class represents the visual properties that most buttons have in common. The ButtonStyle class’s all properties are null by default.

The flutter developers can add a rounded border to the TextButton by passing a value to the styleFrom() method’s shape parameter.

The styleFrom() method’s shape parameter value is an OutlinedBorder instance which adds a border to the TextButton.

The OutlinedBorder class represents a ShapeBorder that draws an outline with the width and color specified by the side. Here we will pass a RoundedRectangleBorder instance for the shape parameter value.

The RoundedRectangleBorder class represents a rectangular border with rounded corners. The RoundedRectangleBorder class borderRadius property value specifies the radii for each corner. Using this parameter value we make the TextButton border corners rounded.

The RoundedRectangleBorder class side property value is a BorderSide instance. The BorderSide class represents a side of a border of a box. The BorderSide class color property value is a Color that is the color of this side of the border. The BorderSide class width property value is a double instance that is the width of this side of the border, in logical pixels.

So finally, the flutter app developers can add rounded corners border to the TextButton widget by passing a RoundedRectangleBorder instance to the TextButton class’s styleFrom() method’s shape parameter.
main.dart

import 'package:flutter/material.dart';

void main(){
  runApp(
    MaterialApp(
      theme: ThemeData(primarySwatch: Colors.grey),
      home: Scaffold(
          appBar: AppBar(
              title: const Text("Flutter - TextButton Border Radius")
          ),
          body: Center(
            child: TextButton(
                onPressed: (){},
                child: const Text("Click Me"),
                style: TextButton.styleFrom(
                    shape: const RoundedRectangleBorder(
                        borderRadius: BorderRadius.all(
                            Radius.circular(24)
                        ),
                        side: BorderSide(
                            color: Colors.grey, width: 1
                        )
                    ),
                    padding: const EdgeInsets.symmetric(
                        horizontal: 64, vertical: 32
                    )
                )
            ),
          )
      ),
    ),
  );
}