data:image/s3,"s3://crabby-images/1a0e7/1a0e7f3c70595d881c2f863e5f69eb8a9a4cc0b5" alt=""
An edge-to-edge app takes advantage of the entire screen by drawing UI under the system bars.
data:image/s3,"s3://crabby-images/53051/530514a1818ff2de40c1230b3ab709f895615c80" alt=""
Takeaways
- Draw background and scrolling content underneath system bars for an edge-to-edge experience.
- Avoid adding tap gestures or drag targets under system insets; these conflict with edge-to-edge and gesture navigation.
data:image/s3,"s3://crabby-images/bba4a/bba4accc065ee5e2f8ab1549076dd6e68651eb99" alt=""
Draw your content behind the system bars
The edge-to-edge feature lets you draw the UI under the system bars for an immersive experience.
An app can address overlaps in content by reacting to insets. Insets describe how much the content of your app needs to be padded to avoid overlapping with system bars or with physical device features such as display cutouts. Read about how to support edge-to-edge and handle insets in Compose and Views.
Be aware of the following types of insets when designing edge-to-edge use cases:
- System bar insets apply to UI that is both tappable and shouldn't be visually obscured by the system bars.
- System gesture insets apply to gesture-navigational areas used by the OS that take priority over your app.
- Display cutout insets apply to device areas that extend into the display surface, such as the camera cutout.
Status bar considerations
See the Android System Bars for fundamental system bar design guidance. The following section discusses additional status bar considerations.
Scrolling content
Top app bars should collapse while scrolling. Learn how to collapse the Material 3 TopAppBar.
data:image/s3,"s3://crabby-images/988b3/988b3e4bf1d95ff4a6e3406a64c03b870739ba31" alt=""
Do
data:image/s3,"s3://crabby-images/6301c/6301c7acbd59771b9f1a2e46e24d78c384caed50" alt=""
Do
Status bars should be translucent when the UI scrolls underneath, so that the status bar icons don't look cluttered. To accomplish this, first make a scrollable UI edge-to-edge by implementing the steps in the LazyColumn or RecyclerView documentation. Then, ensure the system bar is translucent by doing one of the following:
- Rely on the Material 3 TopAppBar automatic protection when scrolling, if applicable.
- Create a custom composable with 60% alpha or use GradientProtection for Views.
data:image/s3,"s3://crabby-images/d1945/d19450c275064c8e230fbdd98d18e598c13933f9" alt=""
For adaptive layouts, ensure there are separate protections for panes with different background colors.
data:image/s3,"s3://crabby-images/1fa90/1fa90da833845e33d59155b6648b816c89b33d4e" alt=""
Don´t
data:image/s3,"s3://crabby-images/21e07/21e07307be91919d81532651a1bd6254a6aa6587" alt=""
Do
Likewise, navigation drawers should also have a separate protection from the rest of the app.
data:image/s3,"s3://crabby-images/6ac74/6ac7473713bb94224a00571beed40889a6386cad" alt=""
Don't stack status bar protections, for example by using both the Material 3 TopAppBar built-in protection and a custom protection.
Navigation bar considerations
See the Android System Bars for fundamental navigation bar design guidance. The following section includes additional navigation bar considerations.
Scrolling content
Bottom app bars should collapse while scrolling.
data:image/s3,"s3://crabby-images/bc39e/bc39e2c316b99cccddc0a1a3ff74fd807e71d5df" alt=""
Do
data:image/s3,"s3://crabby-images/283b0/283b066b8e125e574516d256b0ff085d2dff18c2" alt=""
Do
Display cutouts
Display cutouts can affect the appearance of your UI. Apps must handle display cutout insets so that important parts of the UI don't draw underneath the display cutout.
data:image/s3,"s3://crabby-images/583c7/583c75667d6b6ff2b1347ceb86ba45235b28d7da" alt=""
Do
data:image/s3,"s3://crabby-images/e8c43/e8c43e4838e513c71e0da494c3a6ec63a017d916" alt=""
Don´t
However, solid app bar backgrounds should draw into the display cutout as shown in the following image.
data:image/s3,"s3://crabby-images/79384/793843f93224cb26a2028f2a0745ecc812a92e33" alt=""
Ensure horizontal carousels draw into the display cutout.
data:image/s3,"s3://crabby-images/e7fe1/e7fe1512e3517b75a876c545615a84197f24e9de" alt=""
Read about how to support display cutouts in Compose and Views.
Other guidance
In general, backgrounds and divider lines should also draw edge-to-edge while content like text and buttons should be inset to avoid the system UI and hardware elements.