Criar e exibir uma mensagem pop-up

Teste o Compose
O Jetpack Compose é o kit de ferramentas de interface recomendado para Android. Aprenda a adicionar notificações no Compose.

Você pode usar um Snackbar para mostrar uma breve mensagem ao usuário. Ao contrário de Notificações, a mensagem desaparece automaticamente após um curto período. Um Snackbar é ideal para mensagens breves em que o usuário não precisa fazer nada. Por exemplo, um app de e-mails pode usar um Snackbar para informar ao usuário que o app enviou um e-mail.

Usar um CoordinatorLayout

Um Snackbar é anexado a uma visualização. A Snackbar oferece funcionalidades básicas se estiver anexada a qualquer objeto derivado da classe View, como qualquer um dos objetos de layout comuns. No entanto, se o Snackbar estiver anexado a um CoordinatorLayout, o Snackbar terá outros recursos:

  • O usuário pode dispensar Snackbar deslizando-o para fora da tela.
  • O layout move outros elementos da interface quando a Snackbar é exibida. Por exemplo, se o layout tiver um FloatingActionButton, ele moverá o botão para cima quando mostrar um Snackbar, em vez de desenhar o Snackbar na parte de cima do botão. Veja como isso fica na Figura 1.

A classe CoordinatorLayout oferece um superconjunto da funcionalidade de FrameLayout. Se o app já usa um FrameLayout, você pode substituir esse layout por um CoordinatorLayout para ativar a funcionalidade Snackbar completa. Se o app usa outros objetos de layout, envolva os elementos de layout existentes em um CoordinatorLayout, conforme mostrado no exemplo abaixo:

<android.support.design.widget.CoordinatorLayout
    android:id="@+id/myCoordinatorLayout"
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <!-- Here are the existing layout elements, now wrapped in
         a CoordinatorLayout. -->
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <!-- ...Toolbar, other layouts, other elements... -->

    </LinearLayout>

</android.support.design.widget.CoordinatorLayout>

Defina uma tag android:id para seu CoordinatorLayout. Você precisa do ID do layout ao exibir a mensagem.

Figura 1. O CoordinatorLayout move a FloatingActionButton para cima quando a Snackbar é exibida.

Exibir uma mensagem

Há duas etapas para exibir uma mensagem. Primeiro, crie um objeto Snackbar com o texto da mensagem. Em seguida, você chama o método show() desse objeto para exibir a mensagem para o usuário.

Criar um objeto Snackbar

Crie um objeto Snackbar chamando o método estático Snackbar.make(). Ao criar a Snackbar, especifique a mensagem e o período de exibição dela:

Kotlin

val mySnackbar = Snackbar.make(view, stringId, duration)

Java

Snackbar mySnackbar = Snackbar.make(view, stringId, duration);
visualização
A visualização a que o Snackbar será anexado. O método pesquisa a hierarquia de visualização desde a visualização transmitida até chegar a um CoordinatorLayout ou à visualização de conteúdo da decoração da janela. Normalmente, é mais simples transmitir o CoordinatorLayout que envolve seu conteúdo.
stringId
O ID do recurso da mensagem que você quer exibir. Pode ser um texto formatado ou não formatado.
visualização
O período de exibição da mensagem. Pode ser LENGTH_SHORT ou LENGTH_LONG.

Mostrar a mensagem para o usuário

Depois de criar o Snackbar, chame o método show() para exibir o Snackbar ao usuário:

Kotlin

mySnackbar.show()

Java

mySnackbar.show();

O sistema não mostra vários objetos Snackbar ao mesmo tempo. Portanto, se a visualização estiver mostrando outro Snackbar, o sistema vai colocar seu Snackbar na fila e o exibirá depois que o Snackbar atual expirar ou for dispensado.

Se você quiser mostrar uma mensagem ao usuário e não precisar chamar nenhum dos métodos utilitários do objeto Snackbar, não vai ser necessário manter a referência ao Snackbar depois de chamar show(). Por esse motivo, é comum usar o encadeamento de métodos para criar e mostrar um Snackbar em uma instrução:

Kotlin

Snackbar.make(
        findViewById(R.id.myCoordinatorLayout),
        R.string.email_sent,
        Snackbar.LENGTH_SHORT
).show()

Java

Snackbar.make(findViewById(R.id.myCoordinatorLayout), R.string.email_sent,
                        Snackbar.LENGTH_SHORT)
        .show();