Skip to content

SafeArea

A control that insets its content by sufficient padding to avoid intrusions by the operating system.

For example, this will indent the content by enough to avoid the status bar at the top of the screen.

It will also indent the content by the amount necessary to avoid the Notch on the iPhone X, or other similar creative physical features of the display.

When a minimum_padding is specified, the greater of the minimum padding or the safe area padding will be applied.

Inherits: LayoutControl, AdaptiveControl

Properties

Example#

Live example

Basic Example#

import flet as ft


class State:
    counter = 0


def main(page: ft.Page):
    state = State()

    def handle_button_click(e: ft.Event[ft.FloatingActionButton]):
        state.counter += 1
        message.value = str(state.counter)
        message.update()

    page.floating_action_button = ft.FloatingActionButton(
        icon=ft.Icons.ADD,
        on_click=handle_button_click,
    )

    page.add(
        ft.SafeArea(
            expand=True,
            content=ft.Container(
                message := ft.Text("0", size=50),
                alignment=ft.Alignment.CENTER,
            ),
        )
    )


ft.run(main)

Properties#

avoid_intrusions_bottom class-attribute instance-attribute #

avoid_intrusions_bottom: bool = True

Whether to avoid system intrusions on the bottom side of the screen.

avoid_intrusions_left class-attribute instance-attribute #

avoid_intrusions_left: bool = True

Whether to avoid system intrusions on the left.

avoid_intrusions_right class-attribute instance-attribute #

avoid_intrusions_right: bool = True

Whether to avoid system intrusions on the right.

avoid_intrusions_top class-attribute instance-attribute #

avoid_intrusions_top: bool = True

Whether to avoid system intrusions at the top of the screen, typically the system status bar.

content instance-attribute #

content: Control

The control to display.

Must be visible.

Raises:

maintain_bottom_view_padding class-attribute instance-attribute #

maintain_bottom_view_padding: bool = False

Specifies whether the SafeArea should maintain the bottom MediaQueryData.viewPadding instead of the bottom MediaQueryData.padding.

This avoids layout shifts caused by keyboard overlays, useful when flexible controls are used.

minimum_padding class-attribute instance-attribute #

minimum_padding: PaddingValue = 0

The minimum padding to apply.

The greater of the minimum insets and the media padding will be applied.