为了帮助开发者更有目的地定义面向用户的前台服务,Android 10 在 <service>
元素内引入了 android:foregroundServiceType
属性。
如果您的应用以 Android 14 为目标平台,则必须指定适当的前台服务类型。与以前的 Android 版本一样,可组合使用多个类型。下面列出了可供选择的前台服务类型:
camera
connectedDevice
dataSync
health
location
mediaPlayback
mediaProjection
microphone
phoneCall
remoteMessaging
shortService
specialUse
systemExempted
如果应用中的用例与这些类型均不相关,强烈建议您迁移逻辑以使用 WorkManager 或用户发起的数据传输作业。
Android 14 中新增了 health, remoteMessaging, shortService, specialUse
和 systemExempted
类型。
以下代码段提供了一个清单中的前台服务类型声明示例:
<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>
如果以 Android 14 为目标平台的应用未在清单中定义给定服务的类型,系统会在调用 startForeground()
时引发 MissingForegroundServiceTypeException
。
Declara un nuevo permiso para usar tipos de servicio en primer plano
Si las apps que se orientan 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. Esos 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 forzosa de 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
对于启动前台服务的应用,最佳实践是使用 ServiceCompat
版本的 startForeground()
(在 androidx-core 1.12 及更高版本中提供),并在其中传入前台服务类型的按位整数。您可以选择传递一个或多个类型值。
通常,您应仅声明特定用例所需的类型。这样可以更轻松地满足系统对每种前台服务类型的预期。如果某项前台服务以多种类型启动,则该前台服务必须遵守所有类型的平台强制执行要求。
ServiceCompat.startForeground(0, notification, FOREGROUND_SERVICE_TYPE_LOCATION)
如果调用中未指定前台服务类型,则该类型默认为清单中定义的值。如果您未在清单中指定服务类型,系统会抛出 MissingForegroundServiceTypeException
。
如果启动后前台服务需要新的权限,您应再次调用 startForeground()
并添加新的服务类型。例如,假设健身应用运行的跑步跟踪器服务始终需要 location
信息,但不一定需要 media
权限。您需要在清单中同时声明 location
和 mediaPlayback
。如果用户开始跑步并且只想跟踪自己的位置,您的应用应调用 startForeground()
并仅传递 location
服务类型。然后,如果用户想要开始播放音频,请再次调用 startForeground()
并传递 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 tiempo 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 bajo
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 restricciones durante el uso. Por este motivo, no puedes crear un servicio en primer plano decamera
mientras la app está en segundo plano, con algunas excepciones. Para obtener más información, consulta Restricciones para iniciar servicios en primer plano que necesiten 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
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:
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 tu app necesita realizar una transferencia de datos continua a un dispositivo externo, considera usar el administrador de dispositivos complementario. Usa la API de presencia de dispositivo complementario para ayudar a que la app permanezca 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 en su lugar.
Sincronización de datos
- 要在清单中声明的前台服务类型
android:foregroundServiceType
dataSync
- 在清单中声明的权限
FOREGROUND_SERVICE_DATA_SYNC
- 要传递给
startForeground()
的常量 FOREGROUND_SERVICE_TYPE_DATA_SYNC
- 运行时前提条件
- 无
- 说明
数据传输操作,例如:
- 数据上传或下载
- 备份和恢复操作
- 导入或导出操作
- 获取数据
- 本地文件处理
- 通过网络在设备和云端之间传输数据
- 替代方案
创建用户发起的数据传输作业,让用户启动长时间运行的数据上传或下载任务。
使用 Download Manager API 可以通过 URI 下载数据。
使用
BackupManager
备份或恢复数据。对于其他用例,请考虑使用 WorkManager。
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:
Declara el permiso
HIGH_SAMPLING_RATE_SENSORS
en tu manifiesto.Solicita y obtén al menos uno de los siguientes permisos de tiempo de ejecución:
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 dehealth
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
- Tipo de servicio en primer plano que se declarará en el manifiesto
android:foregroundServiceType
location
- 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
Solicita y obtén al menos uno de los siguientes permisos de tiempo de ejecución:
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 de
location
mientras la app está en segundo plano, con algunas excepciones. Para obtener más información, consulta Restricciones para iniciar servicios en primer plano que necesiten 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 en su lugar.
Contenido multimedia
- 要在清单中声明的前台服务类型
android:foregroundServiceType
mediaPlayback
- 在清单中声明的权限
FOREGROUND_SERVICE_MEDIA_PLAYBACK
- 要传递给
startForeground()
的常量 FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
- 运行时前提条件
- 无
- 说明
- 在后台继续播放音频或视频。在 Android TV 上支持数字视频录制 (DVR) 功能。
- 替代方案
- 如果您展示的是画中画视频,请使用“画中画”模式。
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
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 restricciones durante el uso. Por este motivo, no puedes crear un servicio en primer plano demicrophone
mientras la app está en segundo plano, con algunas excepciones. Para obtener más información, consulta Restricciones para iniciar servicios en primer plano que necesiten 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 declaró el permiso
MANAGE_OWN_CALLS
en su archivo de manifiesto.
- La app declaró el permiso
- La app es la app de Teléfono predeterminada a través de la función
ROLE_DIALER
.
- La app es la app de Teléfono predeterminada a través de la función
- Descripción
Continúa una llamada en curso con las APIs de
ConnectionService
.- Alternativas
Si necesitas hacer llamadas telefónicas, de video o 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 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_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 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 servicios en primer plano.
Uso especial
- 要在其清单中声明的前台服务类型
android:foregroundServiceType
specialUse
- 在清单中声明的权限
FOREGROUND_SERVICE_SPECIAL_USE
- 要传递给
startForeground()
的常量 FOREGROUND_SERVICE_TYPE_SPECIAL_USE
- 运行时前提条件
- 无
- 说明
涵盖其他前台服务类型未涵盖的所有有效前台服务用例。
除了声明
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
前台服务类型之外,开发者还应在清单中声明用例。为此,他们会在<service>
元素内指定<property>
元素。当您在 Google Play 管理中心内提交应用时,我们会审核这些值和相应的用例。您提供的用例是自由形式的,您应确保提供足够的信息,让审核人员了解您为何需要使用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
- 要在其清单中声明的前台服务类型
android:foregroundServiceType
systemExempted
- 在清单中声明的权限
FOREGROUND_SERVICE_SYSTEM_EXEMPTED
- 要传递给
startForeground()
的常量 FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED
- 运行时前提条件
- 无
- 说明
为系统应用和特定系统集成预留,以便继续使用前台服务。
如需使用此类型,应用必须至少满足以下条件之一:
- 设备处于演示模式状态
- 应用是设备所有者
- 应用是性能分析器所有者
- 属于具有
ROLE_EMERGENCY
角色的安全应用 - 属于设备管理应用
- 具有
SCHEDULE_EXACT_ALARM
或USE_EXACT_ALARM
权限的应用 VPN 应用(通过设置 > 网络和互联网 > VPN 进行配置)
否则,声明此类型会导致系统抛出
ForegroundServiceTypeNotAllowedException
。
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.