A partir de Android 14 (nivel de API 34), debes declarar un tipo de servicio adecuado para cada servicio en primer plano. Es decir, debes declarar el tipo de servicio en el manifiesto de la app y, también, solicitar el permiso correspondiente del servicio en primer plano 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
- 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 decamera
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:
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 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:
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 para 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
El usuario debe tener habilitados 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 si el usuario habilitó los servicios de ubicación y le 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 de uso. Por este motivo, no puedes crear un servicio en primer plano
location
mientras la app está en segundo plano, a menos que se te otorgue 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 la app se debe activar cuando el usuario llega a ubicaciones específicas, considera usar la API de geovalencia en su lugar.
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 demicrophone
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 declaró el permiso
MANAGE_OWN_CALLS
en su archivo de manifiesto.
- La app declaró el permiso
- La app es la app de marcador predeterminada a través del
rol
ROLE_DIALER
.
- La app es la app de marcador predeterminada a través del
rol
- 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 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
- 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 usarspecialUse
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
- Tipo de servicio en primer plano para 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 de sistemas e integraciones de sistemas específicos, para seguirán 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
SCHEDULE_EXACT_ALARM
oUSE_EXACT_ALARM
y usan Servicio en primer plano para continuar las alarmas en segundo plano incluidas las alarmas solo de tecnología táctil. 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 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.