Criar e exibir uma mensagem pop-up

Testar 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 das notificações, a mensagem desaparece automaticamente após um curto período. O Snackbar é ideal para mensagens breves que o usuário não precisa necessariamente responder. 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. O Snackbar oferece funcionalidade básica se for anexado a qualquer objeto derivado da classe View, como qualquer um dos objetos de layout comuns. No entanto, se o Snackbar for anexado a um CoordinatorLayout, o Snackbar vai ganhar outros recursos:

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

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

<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 o FloatingActionButton para cima quando o Snackbar aparece.

Exibir uma mensagem

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

Criar um objeto Snackbar

Crie um objeto Snackbar chamando o método Snackbar.make() estático. Ao criar o Snackbar, especifique a mensagem exibida e a duração da exibição:

Kotlin

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

Java

Snackbar mySnackbar = Snackbar.make(view, stringId, duration);
visualizar
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 apenas 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. Os valores podem ser LENGTH_SHORT ou LENGTH_LONG.

Mostrar a mensagem ao usuário

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

Kotlin

mySnackbar.show()

Java

mySnackbar.show();

O sistema não mostra vários objetos Snackbar ao mesmo tempo. Assim, se a visualização estiver exibindo outro Snackbar, o sistema colocará seu Snackbar na fila e o exibirá após o Snackbar atual expirar ou ser dispensado.

Se você quiser mostrar uma mensagem para o usuário e não precisar chamar nenhum dos métodos utilitários do objeto Snackbar, não será necessário manter a referência ao Snackbar depois de chamar show(). Por essa razão, é 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();