Tipos de servicios en primer plano

A partir de Android 14 (API nivel 34), debes declarar un tipo de servicio adecuado para cada servicio en primer plano. Esto significa que debes declarar el tipo de servicio en el manifiesto de tu app y también solicitar el permiso de servicio en primer plano adecuado para ese tipo (además de solicitar el permiso FOREGROUND_SERVICE). Además, según el tipo de servicio en primer plano, es posible que debas solicitar permisos de tiempo de ejecución antes de iniciar el servicio.

Cámara

要在清单中 android:foregroundServiceType 下声明的前台服务类型
camera
要在清单中声明的权限
FOREGROUND_SERVICE_CAMERA
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_CAMERA
运行时前提条件

请求并被授予 CAMERA 运行时权限

说明

继续在后台访问相机,例如支持多任务的视频聊天应用。

Dispositivo conectado

Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceType
connectedDevice
Permiso para declarar en tu manifiesto
FOREGROUND_SERVICE_CONNECTED_DEVICE
Constante para pasar a startForeground()
FOREGROUND_SERVICE_TYPE_CONNECTED_DEVICE
Requisitos previos del entorno de ejecución

Debe cumplirse mínimo una de las siguientes condiciones:

Descripción

Interacciones con dispositivos externos que requieren una conexión Bluetooth, NFC, IR, USB o de red.

Alternativas

Si la app necesita realizar una transferencia de datos continua a un dispositivo externo, considera usar el administrador de dispositivos complementarios. Usa la API de presencia de dispositivos complementarios para ayudar a que tu app siga ejecutándose mientras el dispositivo complementario esté dentro del alcance.

Si la app necesita buscar dispositivos Bluetooth, considera usar la API de búsqueda de Bluetooth.

Sincronización de datos

Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceType
dataSync
Permiso que se debe declarar en el manifiesto
FOREGROUND_SERVICE_DATA_SYNC
Constante que se pasará a startForeground()
FOREGROUND_SERVICE_TYPE_DATA_SYNC
Requisitos previos del tiempo de ejecución
Ninguno
Descripción

Operaciones de transferencia de datos, como las siguientes:

  • Sube o descarga de datos
  • Operaciones de copia de seguridad y restablecimiento
  • Operaciones de importación o exportación
  • Cómo obtener datos
  • Procesamiento de archivos locales
  • Cómo transferir datos entre un dispositivo y la nube a través de una red
Alternativas

Consulta Alternativas a los servicios en primer plano de sincronización de datos para obtener información detallada.

Salud

Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceType
health
Permiso para declarar en tu manifiesto
FOREGROUND_SERVICE_HEALTH
Es la constante que se pasa a startForeground().
FOREGROUND_SERVICE_TYPE_HEALTH
Requisitos previos del entorno de ejecución

Debe cumplirse mínimo una de las siguientes condiciones:

Descripción

Cualquier caso de uso de larga duración para admitir apps de la categoría de entrenamiento, como monitoreos de ejercicios

Ubicación

要在清单中的以下位置声明的前台服务类型
android:foregroundServiceType
location
在清单中声明的权限
FOREGROUND_SERVICE_LOCATION
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_LOCATION
运行时前提条件

用户必须已启用位置信息服务,并且应用必须至少获得以下一项运行时权限:

说明

需要位置信息使用权的长时间运行的用例,例如导航和位置信息分享。

替代方案

如果您的应用需要在用户到达特定位置时触发,请考虑改用 Geofence API

Contenido multimedia

要在清单中声明的前台服务类型,位于
android:foregroundServiceType
mediaPlayback
要在清单中声明的权限
FOREGROUND_SERVICE_MEDIA_PLAYBACK
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
运行时前提条件
说明

在后台继续播放音频或视频。在 Android TV 上支持数字视频录制 (DVR) 功能。

替代方案

如果您要显示画中画视频,请使用画中画模式

Procesando archivos multimedia

要在清单中的以下位置声明的前台服务类型
android:foregroundServiceType
mediaProcessing
在清单中声明的权限
FOREGROUND_SERVICE_MEDIA_PROCESSING
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_MEDIA_PROCESSING
运行时前提条件
说明

用于对媒体资源执行耗时的操作(例如将媒体转换为其他格式)的服务。系统允许此服务运行的时间有限;在正常情况下,此时限为每天 24 小时中的 6 小时。(此限制由应用的所有 mediaProcessing 前台服务共享。)

在以下情况下,您的应用应手动停止媒体处理服务:

如果超时期限已到,系统会调用服务的 Service.onTimeout(int, int) 方法。此时,该服务有几秒钟的时间来调用 Service.stopSelf()。如果服务未调用 Service.stopSelf(),则会发生 ANR,并显示以下错误消息:“<fgs_type> 的前台服务未在超时时间内停止:<component_name>”。

注意Service.onTimeout(int, int) 不适用于 Android 14 或更低版本。在搭载这些版本的设备上,如果媒体处理服务达到超时期限,系统会立即缓存应用。因此,您的应用不应等待收到超时通知。相反,它应在适当情况下尽快终止前台服务或将其更改为后台服务。

Proyección de contenido multimedia

要在清单中声明的前台服务类型,位于
android:foregroundServiceType
mediaProjection
要在清单中声明的权限
FOREGROUND_SERVICE_MEDIA_PROJECTION
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION
运行时前提条件

在启动前台服务之前,调用 createScreenCaptureIntent() 方法。这样做会向用户显示权限通知;用户必须授予权限,您才能创建服务。

创建前台服务后,您可以调用 MediaProjectionManager.getMediaProjection()

说明

使用 MediaProjection API 将内容投影到非主要显示屏或外部设备。这些内容不必全都为媒体内容。

替代方案

如需将媒体内容流式传输到其他设备,请使用 Google Cast SDK

Micrófono

Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceType
microphone
Permiso que se debe declarar en el manifiesto
FOREGROUND_SERVICE_MICROPHONE
Constante que se pasará a startForeground()
FOREGROUND_SERVICE_TYPE_MICROPHONE
Requisitos previos del tiempo de ejecución

Solicita y obtén el permiso de tiempo de ejecución RECORD_AUDIO.

Descripción

Continúa con la captura de micrófono en segundo plano, como las grabadoras de voz o las apps de comunicación.

Llamada telefónica

要在清单中声明的前台服务类型,位于
android:foregroundServiceType
phoneCall
要在清单中声明的权限
FOREGROUND_SERVICE_PHONE_CALL
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_PHONE_CALL
运行时前提条件

必须至少满足以下其中一个条件:

  • 应用通过 ROLE_DIALER 角色成为默认的拨号器应用。
说明

使用 ConnectionService API 继续当前通话。

替代方案

如果您需要拨打手机、视频或 VoIP 电话,不妨考虑使用 android.telecom 库。

考虑使用 CallScreeningService 来过滤来电。

Mensajería remota

要在清单中的以下位置声明的前台服务类型
android:foregroundServiceType
remoteMessaging
在清单中声明的权限
FOREGROUND_SERVICE_REMOTE_MESSAGING
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING
运行时前提条件
说明
将短信从一台设备转移到另一台设备。在用户切换设备时,帮助确保用户消息任务的连续性。

Servicio corto

Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceType
shortService
Permiso para declarar en tu manifiesto
Ninguno
Constante para pasar a startForeground()
FOREGROUND_SERVICE_TYPE_SHORT_SERVICE
Requisitos previos del entorno de ejecución
Ninguno
Descripción

Finaliza con rapidez tareas importantes que no se puedan interrumpir ni posponer.

Este tipo tiene algunas características únicas:

  • Solo se puede ejecutar por un período breve (alrededor de 3 minutos).
  • No admite servicios fijos en primer plano.
  • No se pueden iniciar otros servicios en primer plano.
  • No requiere un permiso específico para el tipo, aunque sí el permiso FOREGROUND_SERVICE.
  • Un shortService solo puede cambiar a otro tipo de servicio si la app es actualmente apta para iniciar un nuevo servicio en primer plano.
  • Un servicio en primer plano puede cambiar su tipo a shortService en cualquier momento, en cuyo punto comienza el período de tiempo de espera.

El tiempo de espera para shortService comienza desde el momento en que se llama a Service.startForeground(). Se espera que la app llame a Service.stopSelf() o Service.stopForeground() antes de que se agote el tiempo de espera. De lo contrario, se llama al nuevo Service.onTimeout(), lo que les brinda a las apps una breve oportunidad para llamar a stopSelf() o stopForeground() para detener su servicio.

Poco tiempo después de llamar a Service.onTimeout(), la app entra en un estado almacenado en caché y ya no se considera en primer plano, a menos que el usuario interactúe, de manera activa, con la app. Poco tiempo después de que la app se almacena en caché, y el servicio no se detiene, la app recibe un mensaje de ANR. Este mensaje menciona FOREGROUND_SERVICE_TYPE_SHORT_SERVICE. Por estos motivos, te recomendamos que, como práctica recomendada, implementes la devolución de llamada a Service.onTimeout().

La devolución de llamada a Service.onTimeout() no existe en Android 13 y versiones anteriores. Si el mismo servicio se ejecuta en esos dispositivos, no recibirá un tiempo de espera ni un mensaje de ANR. Asegúrate de que el servicio se detenga en cuanto finalice la tarea de procesamiento, incluso si todavía no recibió la devolución de llamada a Service.onTimeout().

Es importante tener en cuenta que, si no se respeta el tiempo de espera de shortService, la app mostrará un error de ANR, incluso si tiene otros servicios en primer plano válidos u otros procesos del ciclo de vida de la app en ejecución.

Si una app es visible para el usuario o satisface una de las exenciones que permiten que se inicien los servicios en primer plano desde el segundo plano, volver a llamar a Service.StartForeground() con el parámetro FOREGROUND_SERVICE_TYPE_SHORT_SERVICE extiende el tiempo de espera por otros 3 minutos. Si la app no es visible para el usuario y no satisface una de las exenciones, cualquier intento de iniciar otro servicio en primer plano, independientemente del tipo, producirá ForegroundServiceStartNotAllowedException.

Si un usuario inhabilita la optimización de la batería de tu app, de todos modos, se verá afectada por el tiempo de espera del servicio en primer plano de shortService.

Si inicias un servicio en primer plano que incluye el tipo shortService y otro tipo de servicio en primer plano, el sistema ignora la declaración del tipo shortService. Sin embargo, el servicio debe cumplir con los requisitos previos de los otros tipos declarados. Para obtener más información, consulta la documentación de los servicios en primer plano.

Uso especial

Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceType
specialUse
Permiso para declarar en tu manifiesto
FOREGROUND_SERVICE_SPECIAL_USE
Constante para pasar a startForeground()
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
Requisitos previos del entorno de ejecución
Ninguno
Descripción

Abarca todos los casos de uso válidos de servicios en primer plano que no están cubiertos por los otros tipos de servicios en primer plano.

Además de declarar el tipo de servicio en primer plano de FOREGROUND_SERVICE_TYPE_SPECIAL_USE, los desarrolladores deben declarar casos de uso en el manifiesto. Para ello, especifican el elemento <property> dentro del objeto <service>. Estos valores y los casos de uso correspondientes se revisan cuando envías tu app en Google Play Console. El uso son de formato libre, y debes asegurarte de proporcionar suficientes información para que el revisor pueda ver por qué necesitas usar specialUse el tipo de letra.

<service android:name="fooService" android:foregroundServiceType="specialUse">
  <property android:name="android.app.PROPERTY_SPECIAL_USE_FGS_SUBTYPE"
      android:value="explanation_for_special_use"/>
</service>

Sistema exento

要在其清单中声明的前台服务类型
android:foregroundServiceType
systemExempted
在清单中声明的权限
FOREGROUND_SERVICE_SYSTEM_EXEMPTED
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED
运行时前提条件
说明

为系统应用和特定系统集成预留,以便继续使用前台服务。

如需使用此类型,应用必须至少满足以下条件之一:

Aplicación forzosa de las políticas de Google Play para usar tipos de servicios en primer plano

Si tu app se segmenta para Android 14 o versiones posteriores, deberás declarar los tipos de servicios en primer plano de la app en la página Contenido de la app de Play Console (Política > Contenido de la app). Para obtener más información sobre cómo declarar los tipos de servicios en primer plano en Play Console, consulta Información sobre los requisitos de los intents de pantalla completa y los servicios en primer plano.