Los tipos de servicio en primer plano son obligatorios

Para permitir que los desarrolladores sean más conscientes con la definición de los servicios en primer plano para el usuario, en Android 10, se introdujo el atributo android:foregroundServiceType dentro del elemento <service>.

Si tu app está orientada a Android 14, debe especificar los tipos correctos de servicio en primer plano. Al igual que en versiones anteriores de Android, se pueden combinar varios tipos de servicios. En esta lista, se muestran los tipos de servicios en primer plano que puedes elegir:

Si un caso de uso en tu app no está asociado con ninguno de estos tipos, te recomendamos que migres la lógica para usar WorkManager o tareas de transferencia de datos que inicia el usuario..

Los tipos health, remoteMessaging, shortService, specialUse y systemExempted son nuevos en Android 14.

En el siguiente fragmento de código, se brinda el ejemplo de una declaración de tipo de servicio en primer plano en el manifiesto:

<manifest ...>
  <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
  <uses-permission android:name="android.permission.FOREGROUND_SERVICE_MEDIA_PLAYBACK" />
    <application ...>
      <service
          android:name=".MyMediaPlaybackService"
          android:foregroundServiceType="mediaPlayback"
          android:exported="false">
      </service>
    </application>
</manifest>

Si una app orientada a Android 14 no define tipos para un servicio determinado en el manifiesto, el sistema generará MissingForegroundServiceTypeException cuando se llame a startForeground() para ese servicio.

Declara un nuevo permiso para usar tipos de servicio en primer plano

Si las apps orientadas a Android 14 usan un servicio en primer plano, deben declarar un permiso específico, según el tipo de servicio en primer plano, que presenta Android 14. Estos permisos aparecen en las secciones etiquetadas como "permiso que debes declarar en tu archivo de manifiesto" en la sección de casos de uso previstos y aplicación para cada tipo de servicio en primer plano de esta página.

Todos los permisos se definen como permisos normales y se otorgan de forma predeterminada. Los usuarios no pueden revocar estos permisos.

Incluye el tipo de servicio en primer plano durante el tiempo de ejecución

The best practice for applications starting foreground services is to use the ServiceCompat version of startForeground() (available in androidx-core 1.12 and higher) where you pass in a bitwise integer of foreground service types. You can choose to pass one or more type values.

Usually, you should declare only the types required for a particular use case. This makes it easier to meet the system's expectations for each foreground service type. In cases where a foreground service is started with multiple types, then the foreground service must adhere to the platform enforcement requirements of all types.

ServiceCompat.startForeground(0, notification, FOREGROUND_SERVICE_TYPE_LOCATION)

If the foreground service type is not specified in the call, the type defaults to the values defined in the manifest. If you didn't specify the service type in the manifest, the system throws MissingForegroundServiceTypeException.

If the foreground service needs new permissions after you launch it, you should call startForeground() again and add the new service types. For example, suppose a fitness app runs a running-tracker service that always needs location information, but might or might not need media permissions. You would need to declare both location and mediaPlayback in the manifest. If a user starts a run and just wants their location tracked, your app should call startForeground() and pass just the location service type. Then, if the user wants to start playing audio, call startForeground() again and pass location|mediaPlayback.

Verificaciones del tiempo de ejecución del sistema

El sistema controla el uso adecuado de los tipos de servicios en primer plano y confirma si la app solicitó los permisos de tiempo de ejecución correspondientes o si usa las APIs requeridas. Por ejemplo, el sistema espera que las apps que usan el tipo FOREGROUND_SERVICE_TYPE_LOCATION de servicio en primer plano soliciten ACCESS_COARSE_LOCATION o ACCESS_FINE_LOCATION.

Esto implica que las apps deben seguir un orden de operaciones muy específico cuando le solicitan permisos al usuario e inician servicios en primer plano. Se deben solicitar y obtener los permisos correspondientes antes de que la app llame a startForeground(). Las apps que solicitan los permisos correctos después de que se inicia el servicio en primer plano deben cambiar este orden de operaciones y solicitar el permiso antes de iniciar el servicio en primer plano.

Los detalles de la aplicación forzosa de la plataforma aparecen en las secciones etiquetadas como "requisitos del tiempo de ejecución" en las secciones de casos de uso previstos y de aplicación forzosa de cada tipo de servicio en primer plano en esta página.

Casos de uso previstos y aplicación forzosa para cada tipo de servicio en primer plano

Para usar un tipo determinado de servicio en primer plano, debes declarar un permiso particular en tu archivo de manifiesto, además de cumplir con requisitos específicos del tiempo de ejecución. Tu app también debe cumplir con uno de los conjuntos de casos de uso previstos para ese tipo. En las siguientes secciones, se explica el permiso que debes declarar, los requisitos previos del entorno de ejecución y los casos de uso previstos para cada tipo.

Cámara

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

Solicita y obtén el permiso de tiempo de ejecución CAMERA

Nota: El permiso de tiempo de ejecución CAMERA está sujeto a las restricciones durante el uso. Por este motivo, no puedes crear un servicio en primer plano de camera mientras la app está en segundo plano, con algunas excepciones. Para obtener más información, consulta Restricciones sobre el inicio de servicios en primer plano que necesitan permisos durante el uso.

Descripción

Se sigue accediendo a la cámara en segundo plano, como las apps de videochat que permiten realizar varias tareas a la vez.

Dispositivo conectado

Tipo de servicio en primer plano que se declarará en el manifiesto
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 tu app necesita realizar una transferencia de datos continua a un dispositivo externo, considera usar el administrador de dispositivo complementario. Usa la API de ubicación de dispositivos complementarios para que la app se mantenga en ejecución mientras el dispositivo complementario esté dentro del alcance.

Si tu app necesita buscar dispositivos Bluetooth, considera usar la API de Bluetooth Scan.

Sincronización de datos

Tipo de servicio en primer plano que se declarará en el manifiesto
android:foregroundServiceType
dataSync
Permiso para declarar en tu manifiesto
FOREGROUND_SERVICE_DATA_SYNC
Constante para pasar a startForeground()
FOREGROUND_SERVICE_TYPE_DATA_SYNC
Requisitos previos del entorno 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
android:foregroundServiceType
health
Permiso para declarar en tu manifiesto
FOREGROUND_SERVICE_HEALTH
Constante para pasar a startForeground()
FOREGROUND_SERVICE_TYPE_HEALTH
Requisitos previos del entorno de ejecución

Debe cumplirse mínimo una de las siguientes condiciones:

Nota: El permiso de tiempo de ejecución BODY_SENSORS está sujeto a las restricciones durante el uso. Por este motivo, no puedes crear un servicio en primer plano de health que use sensores corporales mientras tu app está en segundo plano, con algunas excepciones. Para obtener más información, consulta Restricciones sobre el inicio de servicios en primer plano que necesitan permisos durante el uso.

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

Foreground service type to declare in manifest under
android:foregroundServiceType
location
Permission to declare in your manifest
FOREGROUND_SERVICE_LOCATION
Constant to pass to startForeground()
FOREGROUND_SERVICE_TYPE_LOCATION
Runtime prerequisites

The user must have enabled location services and the app must be granted at least one of the following runtime permissions:

Note: In order to check that the user has enabled location services as well as granted access to the runtime permissions, use PermissionChecker#checkSelfPermission()

Note: The location runtime permissions are subject to while-in-use restrictions. For this reason, you cannot create a location foreground service while your app is in the background, unless you've been granted the ACCESS_BACKGROUND_LOCATION runtime permission. For more information, see Restrictions on starting foreground services that need while-in-use permissions.

Description

Long-running use cases that require location access, such as navigation and location sharing.

Alternatives

If your app needs to be triggered when the user reaches specific locations, consider using the geofence API instead.

Contenido multimedia

Tipo de servicio en primer plano que se declarará en el manifiesto
android:foregroundServiceType
mediaPlayback
Permiso para declarar en tu manifiesto
FOREGROUND_SERVICE_MEDIA_PLAYBACK
Constante para pasar a startForeground()
FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
Requisitos previos del entorno de ejecución
Ninguno
Descripción
Continúa la reproducción de audio o video en segundo plano. Compatibilidad con la función de grabación de video digital (DVR) en Android TV.
Alternativas
Si muestras video de pantalla en pantalla, usa el modo de pantalla en pantalla.

Proyección de contenido multimedia

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

Llama al método createScreenCaptureIntent() antes de iniciar el servicio en primer plano. Al hacerlo, se muestra una notificación de permiso al usuario; el usuario debe otorgar el permiso antes de que puedas crear el servicio.

Después de crear el servicio en primer plano, puedes llamar a MediaProjectionManager.getMediaProjection().

Descripción

Proyecta el contenido en un dispositivo externo o una pantalla no principal con las APIs de MediaProjection. No es necesario que este contenido sea solo multimedia.

Alternativas

Para transmitir contenido multimedia a otro dispositivo, usa el SDK de Google Cast.

Micrófono

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

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

Nota: El permiso de tiempo de ejecución RECORD_AUDIO está sujeto a las restricciones durante el uso. Por este motivo, no puedes crear un servicio en primer plano de microphone mientras la app está en segundo plano, con algunas excepciones. Para obtener más información, consulta Restricciones sobre el inicio de servicios en primer plano que necesitan permisos durante el uso.

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

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

Debe cumplirse al menos una de estas condiciones:

  • La app es la app de marcador predeterminada a través del rol ROLE_DIALER.
Descripción

Continúa una llamada en curso con las APIs de ConnectionService.

Alternativas

Si necesitas hacer llamadas telefónicas, de video o de VoIP, considera usar la biblioteca de android.telecom.

Te recomendamos usar CallScreeningService para filtrar llamadas.

Mensajería remota

Tipo de servicio en primer plano que se declarará en el manifiesto
android:foregroundServiceType
remoteMessaging
Permiso para declarar en tu manifiesto
FOREGROUND_SERVICE_REMOTE_MESSAGING
Constante para pasar a startForeground()
FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING
Requisitos previos del entorno de ejecución
Ninguno
Descripción
Transfiere mensajes de texto de un dispositivo a otro. Brinda asistencia para la continuidad de las tareas de mensajería de un usuario cuando este cambia de dispositivo.

Servicio corto

Tipo de servicio en primer plano que se declarará en el manifiesto
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 apta para iniciar un nuevo servicio en primer plano en este momento.
  • Un servicio en primer plano puede cambiar su tipo a shortService en cualquier momento. A partir de ese momento, comienza el 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 servicios en primer plano.

Uso especial

Tipo de servicio en primer plano que se declarará en el manifiesto
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. Los casos de uso que proporcionas son de formato libre, y debes asegurarte de proporcionar suficiente información para permitir que el revisor vea por qué necesitas usar el tipo specialUse.

<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

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

Reservado para aplicaciones del sistema, además de integraciones de sistemas específicos, para seguir usando los servicios en primer plano.

Para usar este tipo, una app debe cumplir con mínimo uno de los siguientes criterios:

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

Si tu app se orienta a Android 14 o versiones posteriores, deberás declarar los tipos de servicios en primer plano de la app en la página de contenido de la app de Play Console (Política > Contenido de la app). Si quieres obtener más información para 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.