Una notificación es un mensaje que muestra Android fuera de la IU de la app para proporcionar al usuario recordatorios, mensajes de otras personas y otra información puntual de la app. Los usuarios pueden presionar la notificación para abrir la app o realizar una acción directamente desde la notificación.
En esta página, se proporciona una descripción general acerca de dónde aparecen las notificaciones y cuáles son las características disponibles. Para comenzar a compilar notificaciones, consulta Cómo crear una notificación.
Para obtener más información sobre el diseño de notificaciones y los patrones de interacción, consulta la guía de diseño de notificaciones.
Presentación en un dispositivo
Las notificaciones se muestran automáticamente a los usuarios en diferentes ubicaciones y formatos. Una notificación aparece como un ícono en la barra de estado, una entrada más detallada en el panel lateral de notificaciones y una insignia en el ícono de la app. Las notificaciones también aparecen en los wearables vinculados.
Barra de estado y panel lateral de notificaciones
Cuando llega una notificación, aparece primero como un ícono en la barra de estado.
Los usuarios pueden deslizar hacia abajo la barra de estado para abrir el panel de notificaciones, donde pueden ver más detalles y realizar acciones desde la notificación.
Los usuarios pueden arrastrar hacia abajo una notificación del panel lateral para abrir la vista expandida, que muestra contenido adicional y botones de acción, de haberlos. A partir de Android 13, esta vista expandida incluye un botón que les permite a los usuarios detener una app que tiene servicios en primer plano en curso.
La notificación permanecerá visible en el panel lateral hasta que la app o el usuario la descarten.
Notificación emergente
A partir de Android 5.0, las notificaciones pueden aparecer brevemente en una ventana flotante llamada notificación emergente. Normalmente, este formato se usa para las notificaciones importantes que el usuario debe ver de inmediato y solo se muestra si el dispositivo está desbloqueado.
La notificación emergente aparece cuando la app emite la notificación. Desaparece después de un momento, pero permanece visible en el panel de notificaciones como de costumbre.
Entre las condiciones que pueden activar notificaciones emergentes, se incluyen las siguientes:
La actividad del usuario se encuentra en el modo de pantalla completa, como cuando la app usa
fullScreenIntent
.La notificación tiene prioridad alta y usa tonos o vibración en dispositivos con Android 7.1 (nivel de API 25) y versiones anteriores.
El canal de notificaciones tiene importancia alta en los dispositivos que ejecutan Android 8.0 (nivel de API 26) y versiones posteriores.
Bloquear pantalla
A partir de Android 5.0, las notificaciones pueden aparecer en la pantalla de bloqueo.
Puedes configurar de forma programática si las notificaciones que publica tu app se muestran en una pantalla de bloqueo segura y, de ser así, el nivel de detalle visible.
Los usuarios pueden emplear la configuración del sistema para elegir el nivel de detalle visible en las notificaciones de la pantalla bloqueada o para inhabilitar todas las notificaciones en esta pantalla. A partir de Android 8.0, los usuarios pueden inhabilitar o habilitar las notificaciones en la pantalla de bloqueo para cada canal de notificaciones.
Para obtener más información, consulta Cómo configurar la visibilidad de las notificaciones de la pantalla de bloqueo.
Insignia en el ícono de la app
En los selectores compatibles en dispositivos con Android 8.0 (nivel de API 26) y versiones posteriores, los íconos de la app indican que hay notificaciones nuevas con una insignia de color conocida como punto de notificación en el ícono del selector de apps correspondiente.
Los usuarios pueden mantener presionado el ícono de una app para ver las notificaciones asociadas con ella. Luego, los usuarios pueden descartar las notificaciones o interactuar con ellas desde ese menú, de forma similar al panel lateral.
Para obtener más información sobre cómo funcionan las insignias, consulta Cómo modificar una insignia de notificación.
Dispositivos con Wear OS
Si el usuario tiene un dispositivo Wear OS vinculado, todas las notificaciones aparecerán allí automáticamente, incluidos los detalles y los botones de acción expandibles.
Para mejorar la experiencia, puedes personalizar el aspecto de las notificaciones en wearables y proporcionar diferentes acciones, como respuestas sugeridas y respuestas de entrada de voz. Si necesitas más información, consulta cómo agregar funciones específicas para wearables a tu notificación.
Anatomía de las notificaciones
El diseño de una notificación está determinado por las plantillas del sistema, y tu app define el contenido de cada sector de la plantilla. Algunos detalles de la notificación aparecen solo en la vista ampliada.
Las partes más comunes de una notificación se indican en la Figura 7 de la siguiente manera:
- Ícono pequeño: obligatorio, se establece con
setSmallIcon()
. - Nombre de la app: proporcionado por el sistema.
- Marca de tiempo: El sistema la proporciona, pero puedes anularla con
setWhen()
o bien ocultarla consetShowWhen(false)
. - Ícono grande: Es opcional y, por lo general, se usa solo para fotos de contacto.
No la uses para el ícono de tu app. Se establece con
setLargeIcon()
. - Título: Es opcional y se establece con
setContentTitle()
. - Texto: Es opcional y se establece con
setContentText()
.
Te recomendamos que uses plantillas del sistema para garantizar una compatibilidad de diseño correcta en todos los dispositivos. Si es necesario, puedes crear un diseño de notificación personalizado.
Para obtener más información sobre cómo crear una notificación con estas funciones y mucho más, lee Cómo crear una notificación.
Acciones de la notificación
Aunque no es obligatorio, se recomienda que cada notificación abra una actividad de app adecuada cuando se la presiona. Además de esta acción de notificación predeterminada, puedes agregar botones de acción que ejecuten una tarea relacionada con la app desde la notificación (generalmente sin abrir una actividad), como se muestra en la figura 8.
A partir de Android 7.0 (nivel de API 24), puedes agregar una acción para responder a los mensajes o ingresar otro texto directamente desde la notificación.
A partir de Android 10 (nivel de API 29), la plataforma puede generar automáticamente botones para acciones basadas en intenciones sugeridas.
En Cómo crear una notificación, se explica en más detalle el proceso para agregar botones de acción.
Cómo solicitar que se desbloquee el dispositivo
Es probable que los usuarios vean acciones de notificación en la pantalla de bloqueo del dispositivo. Si una acción de notificación causa que una app inicie una actividad o envíe una respuesta directa, los usuarios deben desbloquear el dispositivo para que la app pueda invocar esa acción de notificación.
En Android 12 (nivel de API 31) y versiones posteriores, puedes configurar una acción de notificación, de modo que el dispositivo se deba desbloquear para que la app invoque esa acción, independientemente del flujo de trabajo que inicie la acción. Esta opción agrega una capa de seguridad adicional a las notificaciones en dispositivos bloqueados.
Para solicitar que se desbloquee el dispositivo antes de que la app invoque una acción de notificación determinada, pasa true
a setAuthenticationRequired()
cuando creas la acción de notificación, como se muestra en el siguiente fragmento de código:
Kotlin
val moreSecureNotification = Notification.Action.Builder(...) // This notification always requests authentication when invoked // from a lock screen. .setAuthenticationRequired(true) .build()
Java
Notification moreSecureNotification = new Notification.Action.Builder(...) // This notification always requests authentication when invoked // from a lock screen. .setAuthenticationRequired(true) .build();
Notificación expandible
De forma predeterminada, el contenido de texto de la notificación se trunca para que quepa en una línea. Si deseas que la notificación sea más larga, puedes aplicar una plantilla adicional que habilite un área de texto más grande y expandible, como se muestra en la figura 9.
También puedes crear una notificación expandible con una imagen, de estilo similar a la bandeja de entrada, con una conversación de chat o con controles de reproducción de contenido multimedia. Para obtener más información, consulta Cómo crear una notificación expandible.
Actualizaciones de notificaciones y grupos
Para no abrumar a los usuarios con notificaciones múltiples o redundantes cuando haya actualizaciones, actualiza una notificación existente en lugar de emitir una nueva o usa la notificación de bandeja de entrada para mostrar las novedades de la conversación.
Sin embargo, si es necesario enviar varias notificaciones, puedes agruparlas en un grupo (disponible en Android 7.0 y versiones posteriores).
Un grupo de notificaciones te permite juntar varias notificaciones en una sola publicación en el panel de notificaciones, con un resumen. El usuario puede expandir progresivamente el grupo de notificaciones y cada notificación individual para obtener más detalles, como se muestra en la figura 10.
Para saber cómo agregar notificaciones a un grupo, consulta Cómo crear un grupo de notificaciones.
Canales de notificaciones
A partir de Android 8.0 (nivel de API 26), todas las notificaciones deben asignarse a un canal; si no, no aparecerán. Esto permite que los usuarios inhabiliten canales de notificaciones específicos de tu app en lugar de inhabilitar todas tus notificaciones. Los usuarios pueden controlar las opciones visuales y auditivas de cada canal desde la configuración del sistema Android, como se muestra en la figura 11. Los usuarios también pueden mantener presionada una notificación para cambiar los comportamientos del canal asociado.
En los dispositivos que ejecutan Android 7.1 (nivel de API 25) y versiones anteriores, los usuarios solo pueden administrar las notificaciones de cada app de manera individual. Cada app tiene solo un canal en Android 7.1 y versiones anteriores.
Una app puede tener canales independientes para cada tipo de notificación que emita. Una app también puede crear canales de notificaciones en respuesta a las elecciones realizadas por los usuarios. Por ejemplo, puedes configurar canales de notificaciones separados para cada grupo de conversación que crea el usuario en una app de mensajería.
El canal también es el lugar donde se especifica el nivel de importancia de las notificaciones en Android 8.0 y versiones posteriores, de modo que todas las notificaciones publicadas en el mismo canal de notificaciones tengan el mismo comportamiento. Esto se describe en la siguiente sección.
Para obtener más información, consulta Cómo crear y administrar canales de notificaciones.
Importancia de la notificación
Android usa la importancia de una notificación para determinar el nivel de interrupción (visual y auditiva) de cada notificación. Cuanto mayor sea la importancia de una notificación, mayor será el nivel de interrupción.
En Android 7.1 (nivel de API 25) y versiones anteriores, la importancia de una notificación está determinada por su priority
.
En Android 8.0 (nivel de API 26) y versiones posteriores, la importancia de una notificación se determina según el importance
del canal al que se envió la notificación. Los usuarios pueden cambiar la importancia de un canal de notificaciones en la configuración del sistema, como se muestra en la figura 12.
Los posibles niveles de importancia y los comportamientos de notificación asociados son los siguientes:
Urgente: Emite un sonido y aparece como una notificación emergente.
Alta: Emite un sonido.
Media: No emite sonido.
Bajo: No emite sonido ni aparece en la barra de estado.
Todas las notificaciones, independientemente de su importancia, aparecen en ubicaciones de la IU no disruptivas del sistema, como en el panel lateral de notificaciones o como insignias en el ícono del selector. Sin embargo, puedes modificar la apariencia de la insignia de notificación.
Para obtener más información, consulta cómo establecer la importancia.
Modo No interrumpir
A partir de Android 5.0 (nivel de API 21), los usuarios pueden habilitar el modo No interrumpir, que silencia los sonidos y la vibración de todas las notificaciones. Las notificaciones siguen apareciendo en la IU del sistema normalmente, a menos que el usuario especifique lo contrario.
Hay tres niveles disponibles en el modo No interrumpir:
- Silencio total: bloquea todos los sonidos y vibraciones, incluso de alarmas, música, videos y juegos.
- Solo alarmas: bloquea todos los sonidos y vibraciones, excepto las alarmas.
- Solo prioridad: los usuarios pueden configurar qué categorías del sistema pueden interrumpirlos (por ejemplo, solo alarmas, recordatorios, eventos, llamadas o mensajes). Para mensajes y llamadas, los usuarios pueden filtrar según el remitente o la persona que llama, como se muestra en la Figura 13.
En Android 8.0 (nivel de API 26) y versiones posteriores, los usuarios pueden, además, permitir notificaciones según categorías específicas de la app (también denominadas canales) anulando el modo No interrumpir canal por canal. Por ejemplo, una app de pagos puede tener canales para notificaciones relacionadas con retiros y depósitos. El usuario puede permitir notificaciones de retiro, de depósito o ambas en el modo de prioridad.
En los dispositivos con Android 7.1 (nivel de API 25) y versiones anteriores, los usuarios pueden permitir notificaciones de app específicas, en lugar de por canales.
Para configurar tus notificaciones para estas opciones de configuración, debes establecer una categoría para todo el sistema.
Notificaciones para servicios en primer plano
Se requiere una notificación cuando la app está ejecutando un servicio en primer plano, es decir, un Service
que se ejecuta en segundo plano y que es de larga duración y visible para el usuario, como un reproductor multimedia. Esta notificación no se puede descartar como otras. Para quitar la notificación, el servicio debe detenerse o quitarse del estado en primer plano.
Para obtener más información, consulta Servicios en primer plano. Si estás compilando un reproductor de contenido multimedia, también puedes consultar Cómo reproducir contenido multimedia en segundo plano.
Límites de publicaciones
A partir de Android 8.1 (nivel de API 27), las apps no pueden hacer que una notificación suene más de una vez por segundo. Si tu app publica varias notificaciones en un segundo, todas aparecen normalmente, pero solo la primera de cada segundo emite un sonido.
Sin embargo, Android también aplica un límite de frecuencia de actualización de notificaciones. Si publicas actualizaciones de una misma notificación con demasiada frecuencia, como muchas en menos de un segundo, el sistema puede eliminar algunas.
Compatibilidad de notificaciones
La IU del sistema de notificaciones de Android y las APIs relacionadas con notificaciones evolucionan continuamente. Para usar las funciones más recientes de la API de notificaciones y, al mismo tiempo, admitir dispositivos más antiguos, utiliza la API de notificaciones de la biblioteca de compatibilidad, NotificationCompat
, y sus subclases, así como NotificationManagerCompat
.
De esta manera, no necesitas escribir código condicional para verificar los niveles de API porque estas APIs lo manejan automáticamente.
NotificationCompat
se actualiza a medida que evoluciona la plataforma para incluir los métodos más recientes. Sin embargo, la disponibilidad de un método en NotificationCompat
no garantiza que se proporcione la función correspondiente en dispositivos más antiguos. En algunos casos, cuando se llama a una API reciente en dispositivos más antiguos, esta no funciona.
El siguiente es un resumen de los cambios de comportamiento más significativos por nivel de API para las notificaciones de Android.
Android 5.0 (nivel de API 21)
Se incorporaron las notificaciones emergentes y en la pantalla de bloqueo.
Permite que el usuario configure el teléfono en modo No interrumpir y configure qué notificaciones pueden interrumpirlo cuando el dispositivo está en modo de solo prioridad.
Se agregaron métodos para establecer si se muestra una notificación en la pantalla de bloqueo, como
setVisibility()
, y para especificar una versión "pública" del texto de la notificación.Se agregó el método
setPriority()
, que le indica al sistema el nivel de interrupción de la notificación. Por ejemplo, si se establece la prioridad en alta, la notificación aparecerá como emergente.Se agregó compatibilidad con pilas de notificaciones a los dispositivos con Android Wear (ahora denominado Wear OS). Agrupa notificaciones en una pila con
setGroup()
. Las pilas de notificaciones, que más adelante se conocieron como grupos o paquetes, no son compatibles con tablets ni teléfonos hasta Android 7.0 (nivel de API 24).
Android 7.0 (nivel de API 24)
Se rediseñaron las plantillas de notificación para destacar la hero image y el avatar.
Se agregaron tres plantillas de notificación: una para las apps de mensajería y las otras dos para personalizar la presentación del contenido con la capacidad de expansión y otras opciones del sistema.
Se agregó compatibilidad con dispositivos de mano, como teléfonos y tablets, para los grupos de notificaciones. Usa la misma API que las pilas de notificaciones de Android Wear (ahora denominado Wear OS) introducidas en Android 5.0 (nivel de API 21).
Permite que los usuarios respondan dentro de una notificación con la respuesta intercalada. Pueden ingresar texto, que luego se envía a la app superior de la notificación.
Android 8.0 (nivel de API 26)
Hace que las notificaciones individuales se coloquen en un canal específico.
Permite que los usuarios desactiven las notificaciones por canal, en lugar de desactivar todas las notificaciones de una app.
Hace que las apps con notificaciones activas muestren una insignia de notificación en la parte superior del ícono de la app en la pantalla principal o el selector.
Permite a los usuarios posponer una notificación desde el panel. Puedes establecer un tiempo de espera automático para las notificaciones.
Te permite establecer el color de fondo de la notificación.
Se movieron algunas APIs relacionadas con los comportamientos de las notificaciones de
Notification
aNotificationChannel
. Por ejemplo, usaNotificationChannel.setImportance()
en lugar deNotificationCompat.Builder.setPriority()
para Android 8.0 y versiones posteriores.
Android 13.0 (nivel de API 33)
- Agrega el permiso de tiempo de ejecución. Para que tu app envíe notificaciones no exentas, el usuario debe otorgarle este permiso.
Android 14.0 (nivel de API 34)
Limita las notificaciones de intents de pantalla completa a las apps que proporcionan llamadas y alarmas. Usa la API de
NotificationManager.canUseFullScreenIntent
para verificar si tu app tiene permiso. De lo contrario, la app puede usarACTION_MANAGE_APP_USE_FULL_SCREEN_INTENT
para iniciar la página de configuración en la que los usuarios pueden otorgar el permiso.Cambia la forma en que los usuarios experimentan las notificaciones que no se pueden descartar, ya que les permite descartar la acción de notificaciones incluso cuando se establece la marca
Notification.FLAG_ONGOING_EVENT
. Esto no se aplica a las notificacionesCallStyle
si se establece la marcaNotification.FLAG_ONGOING_EVENT
o el controlador de políticas de dispositivos (DPC) y los paquetes compatibles para empresas. Esto tampoco se aplica cuando el teléfono está bloqueado o si el usuario selecciona Borrar todo.
Comportamientos de las notificaciones
Reducción de sonido
Android 15.0 (nivel de API 35)
Android 15 presenta una función de inactividad de notificaciones que tiene como objetivo mejorar la experiencia de las notificaciones que llegan en rápida sucesión. Esta función reduce la apariencia, el volumen del sonido y la intensidad de la vibración de las notificaciones repetitivas durante un máximo de dos minutos.
Las notificaciones importantes que requieren audio y tecnología táctil para llamar la atención no están sujetas a un tiempo de inactividad. El usuario puede desactivar el tiempo de inactividad de las notificaciones en Configuración.
A continuación, se muestra un ejemplo de cómo encontrar la configuración del tiempo de inactividad de las notificaciones:
Kotlin
val intent = Intent(Settings.ACTION_MANAGE_ADAPTIVE_NOTIFICATIONS) val pendingIntent = PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_IMMUTABLE)
Java
Intent intent = new Intent(Settings.ACTION_MANAGE_ADAPTIVE_NOTIFICATIONS) PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, PendingIntent.FLAG_IMMUTABLE)