Material Components widgets
Visual, behavioral, and motion-rich widgets implementing the Material Design guidelines.
- App structure and navigation
- Buttons
- Input and selections
- Dialogs, alerts, and panels
- Information displays
- Layout
See more widgets in the widget catalog.
App structure and navigation
data:image/s3,"s3://crabby-images/57d89/57d890d98d8eac12f6ac640158ec6a654a23d61e" alt=""
Implements the basic Material Design visual layout structure. This class provides APIs for showing drawers, snack bars, and bottom sheets.
Documentationdata:image/s3,"s3://crabby-images/3423a/3423afb55c34c5dbb0865a10bc3f29723a1474bc" alt=""
A Material Design app bar. An app bar consists of a toolbar and potentially other widgets, such as a TabBar and a FlexibleSpaceBar.
Documentationdata:image/s3,"s3://crabby-images/698cb/698cb9fc2d5dc8242873b23b516c8547e11b9d9f" alt=""
Bottom navigation bars make it easy to explore and switch between top-level views in a single tap. The BottomNavigationBar widget implements this component.
Documentationdata:image/s3,"s3://crabby-images/f72e5/f72e5b36903dadefe757b21542900c3b0bb99766" alt=""
A Material Design widget that displays a horizontal row of tabs.
Documentationdata:image/s3,"s3://crabby-images/d4cbb/d4cbb198b897e863a40d05baa5008d4e938856d0" alt=""
A page view that displays the widget which corresponds to the currently selected tab. Typically used in conjunction with a TabBar.
Documentationdata:image/s3,"s3://crabby-images/dd915/dd9151232aee9574ed555a899e5aab0545e5d90c" alt=""
A convenience widget that wraps a number of widgets that are commonly required for applications implementing Material Design.
Documentationdata:image/s3,"s3://crabby-images/789d0/789d063d7b543848f3121bb5fb4c57e11b6774a8" alt=""
A convenience class that wraps a number of widgets that are commonly required for an application.
Documentationdata:image/s3,"s3://crabby-images/7f605/7f605c2244e0bb03d9dbc980c5b1102e9c7ff9a4" alt=""
A Material Design panel that slides in horizontally from the edge of a Scaffold to show navigation links in an application.
Documentationdata:image/s3,"s3://crabby-images/fd374/fd374f5ff0de12709762efc14f67a61d8463d8e6" alt=""
A material design app bar that integrates with a CustomScrollView.
DocumentationButtons
data:image/s3,"s3://crabby-images/1db27/1db27b1202164e20dd27fb0d451f14e734d41ac6" alt=""
A Material Design raised button. A raised button consists of a rectangular piece of material that hovers over the interface.
Documentationdata:image/s3,"s3://crabby-images/13146/131469b6f98671eecdead1a7e168ed253462f07b" alt=""
A floating action button is a circular icon button that hovers over content to promote a primary action in the application. Floating action buttons are most commonly used in the Scaffold.floatingActionButton field.
Documentationdata:image/s3,"s3://crabby-images/f5d31/f5d31a7fddfb6f038a49cd950f4fc47639832f20" alt=""
A flat button is a section printed on a Material Components widget that reacts to touches by filling with color.
Documentationdata:image/s3,"s3://crabby-images/3eda7/3eda7112fbcb7b8b78d80b677ddedce318c87934" alt=""
An icon button is a picture printed on a Material widget that reacts to touches by filling with color (ink).
Documentationdata:image/s3,"s3://crabby-images/d5399/d539972632fc6a8bdce0d9d048ecd81fb9ba1c31" alt=""
Shows the currently selected item and an arrow that opens a menu for selecting another item.
Documentationdata:image/s3,"s3://crabby-images/0ca6b/0ca6b19b6eeff8f052bbb83e063379bdca7925c7" alt=""
Displays a menu when pressed and calls onSelected when the menu is dismissed because an item was selected.
Documentationdata:image/s3,"s3://crabby-images/14e18/14e182de4b3a48291122c00a6b440cabfa81d059" alt=""
A horizontal arrangement of buttons.
DocumentationInput and selections
data:image/s3,"s3://crabby-images/c2a8a/c2a8a6b00688be9b1a9b47f8cb71182de035833d" alt=""
Touching a text field places the cursor and displays the keyboard. The TextField widget implements this component.
Documentationdata:image/s3,"s3://crabby-images/8a98c/8a98c39a6fbbd4b262b77f5af1397a9af2235e56" alt=""
Checkboxes allow the user to select multiple options from a set. The Checkbox widget implements this component.
Documentationdata:image/s3,"s3://crabby-images/34fd6/34fd6384edfb6eb2346b742c1157703be0fe3ae8" alt=""
Radio buttons allow the user to select one option from a set. Use radio buttons for exclusive selection if you think that the user needs to see all available options side-by-side.
Documentationdata:image/s3,"s3://crabby-images/ff33d/ff33d3a45f2acc8b86391f1ce628195d5de61100" alt=""
On/off switches toggle the state of a single settings option. The Switch widget implements this component.
Documentationdata:image/s3,"s3://crabby-images/b757f/b757f6c0ea5ea5d09d2e723ec6ff034c17a8591f" alt=""
Sliders let users select from a range of values by moving the slider thumb.
Documentationdata:image/s3,"s3://crabby-images/fd9c9/fd9c9426398fcf1054917851ba1ca0b91fc8158e" alt=""
Date pickers use a dialog window to select a single date on mobile. Time pickers use a dialog to select a single time (in the hours:minutes format) on mobile.
DocumentationDialogs, alerts, and panels
data:image/s3,"s3://crabby-images/1a83b/1a83b09eda6d0f4613e64fb58363b8e424a8d7e9" alt=""
Simple dialogs can provide additional details or actions about a list item. For example they can display avatars icons clarifying subtext or orthogonal actions (such as adding an account).
Documentationdata:image/s3,"s3://crabby-images/754ce/754ce3e2e8348c469518b65ca0588002ca3ed773" alt=""
Alerts are urgent interruptions requiring acknowledgement that inform the user about a situation. The AlertDialog widget implements this component.
Documentationdata:image/s3,"s3://crabby-images/65f86/65f860228ebdcae3c14e4765e7d9c804c5990be9" alt=""
Bottom sheets slide up from the bottom of the screen to reveal more content. You can call showBottomSheet() to implement a persistent bottom sheet or showModalBottomSheet() to implement a modal bottom sheet.
Documentationdata:image/s3,"s3://crabby-images/8446a/8446a7e9cd3f6c1d90404be02cdecfbe187e69dc" alt=""
Expansion panels contain creation flows and allow lightweight editing of an element. The ExpansionPanel widget implements this component.
Documentationdata:image/s3,"s3://crabby-images/e20ee/e20eed27443af63c556d1856264f83d379966b15" alt=""
A lightweight message with an optional action which briefly displays at the bottom of the screen.
DocumentationInformation displays
A widget that displays an image.
Documentationdata:image/s3,"s3://crabby-images/85e35/85e35900a4bbbca1d847b6c40e4b6c2bb32c61e3" alt=""
A Material Design icon.
Documentation