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:
cameraconnectedDevicedataSynchealthlocationmediaPlaybackmediaProjectionmicrophonephoneCallremoteMessagingshortServicespecialUsesystemExempted
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
如果以 Android 14 为目标平台的应用使用前台服务,则必须根据前台服务类型声明 Android 14 中引入的特定权限。这些权限显示在本页每种前台服务类型的预期用例和强制执行部分中标记为“您必须在清单文件中声明的权限”的部分。
所有这些权限都定义为一般权限,并默认授予。用户无法撤消这些权限。
Incluye el tipo de servicio en primer plano durante el tiempo de ejecución
La práctica recomendada para las aplicaciones que inician servicios en primer plano es usar la versión ServiceCompat de startForeground() (disponible en androidx-core 1.12 y versiones posteriores), en la que pasas un número entero a nivel de bits de los tipos de servicios en primer plano. Puedes pasar uno o más valores de tipo.
Por lo general, debes declarar solo los tipos necesarios para un caso de uso en particular. Esto facilita el cumplimiento de las expectativas del sistema para cada tipo de servicio en primer plano. En los casos en que un servicio en primer plano se inicia con varios tipos, el servicio en primer plano debe cumplir con los requisitos de aplicación de la plataforma de todos los tipos.
ServiceCompat.startForeground(0, notification, FOREGROUND_SERVICE_TYPE_LOCATION)
Si no se especifica el tipo de servicio en primer plano en la llamada, el tipo se establece de forma predeterminada en los valores definidos en el manifiesto. Si no especificaste el tipo de servicio en el manifiesto, el sistema arroja MissingForegroundServiceTypeException.
Si el servicio en primer plano necesita nuevos permisos después de iniciarlo, debes volver a llamar a startForeground() y agregar los nuevos tipos de servicio. Por ejemplo, supongamos que una app de fitness ejecuta un servicio de seguimiento de actividades de correr que siempre necesita información de location, pero que puede necesitar o no permisos de media. Debes declarar location y mediaPlayback en el manifiesto. Si un usuario inicia una actividad de correr y solo quiere que se haga un seguimiento de su ubicación, tu app debe llamar a startForeground() y pasar solo el tipo de servicio location. Luego, si el usuario quiere comenzar a reproducir audio, vuelve a llamar a startForeground() y pasa location|mediaPlayback.
Verificaciones del tiempo de ejecución del sistema
系统会检查前台服务类型的使用是否恰当,并确认应用是否已请求适当的运行时权限或使用所需的 API。例如,系统希望使用前台服务类型 FOREGROUND_SERVICE_TYPE_LOCATION 的应用请求 ACCESS_COARSE_LOCATION 或 ACCESS_FINE_LOCATION。
这意味着,在向用户请求权限和启动前台服务时,应用必须遵循非常具体的操作顺序。应用在尝试调用 startForeground() 之前,必须先请求并获得所需的权限。在启动前台服务后请求相应权限的应用必须更改此顺序,并在启动前台服务之前请求该权限。
本页面的每种前台服务类型的预期用例和强制执行部分中标记为“运行时要求”的部分列出了平台强制执行的具体内容。
Casos de uso previstos y aplicación forzosa para cada tipo de servicio en primer plano
为了使用给定的前台服务类型,您必须在清单文件中声明特定权限,必须满足特定的运行时要求,并且应用必须满足该类型的其中一组预期用例。以下部分介绍了您必须声明的权限、运行时前提条件以及每种类型的预期用例。
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
CAMERANota: El permiso de tiempo de ejecución
CAMERAestá sujeto a restricciones durante el uso. Por este motivo, no puedes crear un servicio en primer plano decameramientras la app está en segundo plano, con algunas excepciones. Para obtener más información, consulta Restricciones para iniciar servicios en primer plano que necesitan permisos durante el uso.- Descripción
Continúa 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 en
android:foregroundServiceTypeconnectedDevice- 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:
Declara mínimo uno de los siguientes permisos en tu manifiesto:
Solicita y obtén al menos uno de los siguientes permisos de tiempo de ejecución:
Llamada a
UsbManager.requestPermission()
- 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:foregroundServiceTypedataSync- 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
- 要在清单中的以下位置声明的前台服务类型
android:foregroundServiceTypehealth- 在清单中声明的权限
FOREGROUND_SERVICE_HEALTH- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_HEALTH- 运行时前提条件
必须至少满足以下其中一个条件:
在清单中声明
HIGH_SAMPLING_RATE_SENSORS权限。至少请求并被授予以下其中一项运行时权限:
- 在 API 级别 35 及更低级别上使用
BODY_SENSORS READ_HEART_RATEREAD_SKIN_TEMPERATUREREAD_OXYGEN_SATURATIONACTIVITY_RECOGNITION
- 在 API 级别 35 及更低级别上使用
注意:
BODY_SENSORS和基于传感器的读取运行时权限受“在使用时”限制。因此,除非您已获得BODY_SENSORS_BACKGROUND(API 级别 33 到 35)或READ_HEALTH_DATA_IN_BACKGROUND(API 级别 36 及更高级别)权限,否则您无法创建在应用处于后台运行时使用身体传感器的health前台服务。如需了解详情,请参阅与启动需要使用时权限的前台服务相关的限制。- 说明
为健身类别的应用(例如锻炼追踪器)提供支持的所有长时间运行的用例。
Ubicación
- Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceTypelocation- Permiso para declarar en tu manifiesto
FOREGROUND_SERVICE_LOCATION- Constante para pasar a
startForeground() FOREGROUND_SERVICE_TYPE_LOCATION- Requisitos previos del entorno de ejecución
El usuario debe haber habilitado los servicios de ubicación, y la app debe tener al menos uno de los siguientes permisos de tiempo de ejecución:
Nota: Para verificar que el usuario habilitó los servicios de ubicación y otorgó acceso a los permisos de tiempo de ejecución, usa
PermissionChecker#checkSelfPermission().Nota: Los permisos de tiempo de ejecución de la ubicación están sujetos a restricciones durante el uso. Por este motivo, no puedes crear un servicio en primer plano
locationmientras la app está en segundo plano, a menos que se te haya otorgado el permiso de tiempo de ejecuciónACCESS_BACKGROUND_LOCATION. Para obtener más información, consulta Restricciones para iniciar servicios en primer plano que necesitan permisos durante el uso.- Descripción
Casos de uso de larga duración que requieren acceso a la ubicación, como la navegación y el uso compartido de la ubicación
- Alternativas
Si tu app debe activarse cuando el usuario llega a ubicaciones específicas, considera usar la API de geovallado.
Contenido multimedia
- Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceTypemediaPlayback- 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 quieres mostrar un video en pantalla en pantalla, usa el modo Pantalla en pantalla.
Proyección de contenido multimedia
- Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceTypemediaProjection- 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. De esta manera, se muestra una notificación de permiso al usuario, quien debe otorgar el permiso para 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
- 要在清单中的以下位置声明的前台服务类型
android:foregroundServiceTypemicrophone- 在清单中声明的权限
FOREGROUND_SERVICE_MICROPHONE- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_MICROPHONE- 运行时前提条件
请求并获得
RECORD_AUDIO运行时权限。注意:
RECORD_AUDIO运行时权限受使用时限制的约束。因此,除少数例外情况外,您无法在应用在后台运行时创建microphone前台服务。如需了解详情,请参阅与启动需要使用时权限的前台服务相关的限制。- 说明
在后台继续捕获麦克风内容,例如录音器或通信应用。
Llamada telefónica
- 要在清单中的以下位置声明的前台服务类型
android:foregroundServiceTypephoneCall- 在清单中声明的权限
FOREGROUND_SERVICE_PHONE_CALL- 要传递给
startForeground()的常量 FOREGROUND_SERVICE_TYPE_PHONE_CALL- 运行时前提条件
必须至少满足以下其中一个条件:
- 应用已在其清单文件中声明
MANAGE_OWN_CALLS权限。
- 应用已在其清单文件中声明
- 应用是通过
ROLE_DIALER角色的默认拨号器应用。
- 应用是通过
- 说明
使用
ConnectionServiceAPI 继续当前通话。- 替代方案
如果您需要拨打电话、视频通话或 VoIP 通话,不妨考虑使用
android.telecom库。考虑使用
CallScreeningService来过滤来电。
Mensajería remota
- Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceTyperemoteMessaging- 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 en
android:foregroundServiceTypeshortService- 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
shortServicesolo 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
shortServiceen 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 aService.stopSelf()oService.stopForeground()antes de que se agote el tiempo de espera. De lo contrario, se llama al nuevoService.onTimeout(), lo que les brinda a las apps una breve oportunidad para llamar astopSelf()ostopForeground()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 mencionaFOREGROUND_SERVICE_TYPE_SHORT_SERVICE. Por estos motivos, te recomendamos que, como práctica recomendada, implementes la devolución de llamada aService.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 aService.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ámetroFOREGROUND_SERVICE_TYPE_SHORT_SERVICEextiende 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
shortServicey otro tipo de servicio en primer plano, el sistema ignora la declaración del tiposhortService. 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:foregroundServiceTypespecialUse- 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 usarspecialUseel 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
- Tipo de servicio en primer plano que se declarará en el manifiesto en
android:foregroundServiceTypesystemExempted- 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 y integraciones de sistemas específicos, para continuar usando los servicios en primer plano.
Para usar este tipo, una app debe cumplir con mínimo uno de los siguientes criterios:
- El dispositivo debe estar en modo de demostración
- La app debe ser del propietario del dispositivo
- La app debe ser del propietario del generador de perfiles.
- Apps de seguridad que tienen la función
ROLE_EMERGENCY - Apps de administración del dispositivo
- Apps que tienen el permiso
SCHEDULE_EXACT_ALARMoUSE_EXACT_ALARMy usan el servicio en primer plano para continuar con las alarmas en segundo plano, incluidas las alarmas solo táctiles Apps de VPN (configuradas con Configuración > Internet y redes > VPN)
De lo contrario, declarar este tipo causa que el sistema arroje una
ForegroundServiceTypeNotAllowedException.
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.