Button
Buttons are fundamental components that allow the user to trigger a defined action. There are five types of buttons. The following table describes the appearance of each of the five button types, as well as where you should use them.
Type |
Appearance |
Purpose |
---|---|---|
Filled |
Solid background with contrasting text. |
High-emphasis buttons. These are for primary actions in an application, such as "submit" and "save." The shadow effect emphasizes the button's importance. |
Filled tonal |
Background color varies to match the surface. |
Also for primary or significant actions. Filled buttons provide more visual weight and suit functions such as "add to cart" and "Sign in." |
Elevated |
Stands out by having a shadow. |
Fits a similar role to tonal buttons. Increase elevation to cause the button to appear even more prominently. |
Outlined |
Features a border with no fill. |
Medium-emphasis buttons, containing actions that are important but not primary. They pair well with other buttons to indicate alternative, secondary actions like "Cancel" or "Back." |
Text |
Displays text with no background or border. |
Low-emphasis buttons, ideal for less critical actions such as navigational links, or secondary functions like "Learn More" or "View details." |
The following image demonstrates the five types of buttons in Material Design.
API surface
onClick
: The function called when the user presses the button.enabled
: When false, this parameter causes the button to appear unavailable and inactive.colors
: An instance ofButtonColors
that determines the colors used in the button.contentPadding
: The padding within the button.
Filled button
The filled button component uses the basic Button
composable. It is
filled with a solid color by default. The following snippet demonstrates how to
implement the component:
@Composable fun FilledButtonExample(onClick: () -> Unit) { Button(onClick = { onClick() }) { Text("Filled") } }
This implementation appears as follows:
data:image/s3,"s3://crabby-images/ece8b/ece8bea0692fd3c18198f38be90734c3e1d46f5c" alt="A filled button with a purple background that reads, 'filled'."
Filled tonal button
The filled tonal button component uses the FilledTonalButton
composable.
It is filled with a tonal color by default.
The following snippet demonstrates how to implement the component:
@Composable fun FilledTonalButtonExample(onClick: () -> Unit) { FilledTonalButton(onClick = { onClick() }) { Text("Tonal") } }
This implementation appears as follows:
data:image/s3,"s3://crabby-images/88c73/88c734ff1c20aefc0942698f3d8840794d991c15" alt="A tonal button with a light purple background that reads, 'filled'."
Outlined button
The outlined button component uses the OutlinedButton
composable. It
appears with an outline by default.
The following snippet demonstrates how to implement the component:
@Composable fun OutlinedButtonExample(onClick: () -> Unit) { OutlinedButton(onClick = { onClick() }) { Text("Outlined") } }
This implementation appears as follows:
data:image/s3,"s3://crabby-images/e0a6d/e0a6d31929512a96b9e731fbdd220b598fd51a16" alt="A transparent outlined button with a dark border that reads, 'Outlined'."
Elevated button
The elevated button component uses the ElevatedButton
composable. It has
a shadow that represents the elevation effect by default. Note that it is
essentially an outlined button with a shadow.
The following snippet demonstrates how to implement the component:
@Composable fun ElevatedButtonExample(onClick: () -> Unit) { ElevatedButton(onClick = { onClick() }) { Text("Elevated") } }
This implementation appears as follows:
data:image/s3,"s3://crabby-images/677e4/677e408d9461f13f9b4e98037b9cc69022f880cd" alt="An elevated button with a gray background that reads, 'Elevated'."
Text button
The text button component uses the TextButton
composable. Until pressed,
it appears as only text. It does not have a solid fill or outline by default.
The following snippet demonstrates how to implement the component:
@Composable fun TextButtonExample(onClick: () -> Unit) { TextButton( onClick = { onClick() } ) { Text("Text Button") } }
This implementation appears as follows:
data:image/s3,"s3://crabby-images/a0699/a06990a46011bf273d47738eba98eeabe52d3737" alt="A text button that reads 'Text Button'"