A partire da Android 14 (livello API 34), devi dichiarare un tipo di servizio appropriato per ogni servizio in primo piano. Ciò significa che devi dichiarare il
tipo di servizio nel file manifest dell'app e richiedere l'autorizzazione
per il servizio in primo piano appropriata per quel tipo (oltre a richiedere l'autorizzazione
FOREGROUND_SERVICE
). Inoltre, a seconda del tipo di servizio in primo piano, potrebbe essere necessario richiedere autorizzazioni di runtime prima di avviare il servizio.
Fotocamera
- 要在清单中的
android:foregroundServiceType
下声明的前台服务类型 camera
- 在清单中声明的权限
FOREGROUND_SERVICE_CAMERA
- 要传递给
startForeground()
的常量 FOREGROUND_SERVICE_TYPE_CAMERA
- 运行时前提条件
请求并获得
CAMERA
运行时权限注意:
CAMERA
运行时权限受使用时限制。因此,当您的应用位于后台时,您无法创建camera
前台服务,但存在一些例外情况。如需了解详情,请参阅有关启动需要运行时权限的前台服务的限制。- 说明
继续在后台访问摄像头,例如支持多任务的视频聊天应用。
Dispositivo connesso
- Foreground service type to declare in manifest under
android:foregroundServiceType
connectedDevice
- Permission to declare in your manifest
FOREGROUND_SERVICE_CONNECTED_DEVICE
- Constant to pass to
startForeground()
FOREGROUND_SERVICE_TYPE_CONNECTED_DEVICE
- Runtime prerequisites
At least one of the following conditions must be true:
Declare at least one of the following permissions in your manifest:
Request and be granted at least one of the following runtime permissions:
- Description
Interactions with external devices that require a Bluetooth, NFC, IR, USB, or network connection.
- Alternatives
If your app needs to do continuous data transfer to an external device, consider using the companion device manager instead. Use the companion device presence API to help your app stay running while the companion device is in range.
If your app needs to scan for bluetooth devices, consider using the Bluetooth scan API instead.
Sincronizzazione dati
- Tipo di servizio in primo piano da dichiarare nel file manifest in
android:foregroundServiceType
dataSync
- Autorizzazione da dichiarare nel manifest
FOREGROUND_SERVICE_DATA_SYNC
- Costante per passare a
startForeground()
FOREGROUND_SERVICE_TYPE_DATA_SYNC
- Prerequisiti di runtime
- Nessuno
- Descrizione
Operazioni di trasferimento di dati, ad esempio:
- Caricamento o download di dati
- Operazioni di backup e ripristino
- Operazioni di importazione o esportazione
- Recupera dati
- Elaborazione file locale
- Trasferire dati tra un dispositivo e il cloud su una rete
- Alternative
Per informazioni dettagliate, consulta le alternative ai servizi in primo piano di sincronizzazione dei dati.
Salute
- Foreground service type to declare in manifest under
android:foregroundServiceType
health
- Permission to declare in your manifest
FOREGROUND_SERVICE_HEALTH
- Constant to pass to
startForeground()
FOREGROUND_SERVICE_TYPE_HEALTH
- Runtime prerequisites
At least one of the following conditions must be true:
Declare the
HIGH_SAMPLING_RATE_SENSORS
permission in your manifest.Request and be granted at least one of the following runtime permissions:
Note: The
BODY_SENSORS
runtime permission is subject to while-in-use restrictions. For this reason, you cannot create ahealth
foreground service that uses body sensors while your app is in the background, with a few exceptions. For more information, see Restrictions on starting foreground services that need while-in-use permissions.- Description
Any long-running use cases to support apps in the fitness category such as exercise trackers.
Posizione
- Tipo di servizio in primo piano da dichiarare nel file manifest in
android:foregroundServiceType
location
- Autorizzazione da dichiarare nel file manifest
FOREGROUND_SERVICE_LOCATION
- Costante per passare a
startForeground()
FOREGROUND_SERVICE_TYPE_LOCATION
- Prerequisiti di runtime
L'utente deve aver attivato i servizi di geolocalizzazione e all'app deve essere concessa almeno una delle seguenti autorizzazioni di runtime:
Nota: per verificare che l'utente abbia attivato i servizi di geolocalizzazione e concesso l'accesso alle autorizzazioni di runtime, utilizza
PermissionChecker#checkSelfPermission()
Nota:le autorizzazioni di runtime per la posizione sono soggette a limitazioni durante l'utilizzo. Per questo motivo, non puoi creare un servizio in primo piano
location
mentre la tua app è in background, a meno che ti sia stata concessa l'autorizzazione di runtimeACCESS_BACKGROUND_LOCATION
. Per maggiori informazioni, consulta Limitazioni relative all'avvio di servizi in primo piano che richiedono autorizzazioni durante l'uso.- Descrizione
Casi d'uso di lunga data che richiedono l'accesso alla posizione, come la navigazione e la condivisione della posizione.
- Alternative
Se la tua app deve essere attivata quando l'utente raggiunge località specifiche, valuta la possibilità di utilizzare invece l'API geofence.
Contenuti multimediali
- Tipo di servizio in primo piano da dichiarare nel file manifest in
android:foregroundServiceType
mediaPlayback
- Autorizzazione da dichiarare nel manifest
FOREGROUND_SERVICE_MEDIA_PLAYBACK
- Costante per passare a
startForeground()
FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
- Prerequisiti di runtime
- Nessuno
- Descrizione
- Continua la riproduzione audio o video in background. Supporta la funzionalità di registrazione video digitale (DVR) su Android TV.
- Alternative
- Se stai mostrando un video Picture in picture, usa la modalità Picture in picture.
Proiezione di contenuti multimediali
- Foreground service type to declare in manifest under
android:foregroundServiceType
mediaProjection
- Permission to declare in your manifest
FOREGROUND_SERVICE_MEDIA_PROJECTION
- Constant to pass to
startForeground()
FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION
- Runtime prerequisites
Call the
createScreenCaptureIntent()
method before starting the foreground service. Doing so shows a permission notification to the user; the user must grant the permission before you can create the service.After you have created the foreground service, you can call
MediaProjectionManager.getMediaProjection()
.- Description
Project content to non-primary display or external device using the
MediaProjection
APIs. This content doesn't have to be exclusively media content.- Alternatives
To stream media to another device, use the Google Cast SDK.
Microfono
- Tipo di servizio in primo piano da dichiarare nel file manifest in
android:foregroundServiceType
microphone
- Autorizzazione da dichiarare nel manifest
FOREGROUND_SERVICE_MICROPHONE
- Costante per passare a
startForeground()
FOREGROUND_SERVICE_TYPE_MICROPHONE
- Prerequisiti di runtime
Richiedere e ottenere l'autorizzazione di runtime
RECORD_AUDIO
.Nota: l'autorizzazione di runtime
RECORD_AUDIO
è soggetta a restrizioni durante l'uso. Per questo motivo, non puoi creare un serviziomicrophone
in primo piano mentre la tua app è in background, con alcune eccezioni. Per maggiori informazioni, consulta Limitazioni relative all'avvio di servizi in primo piano che richiedono le autorizzazioni durante l'uso.- Descrizione
Continua l'acquisizione del microfono in background, ad esempio registratori vocali o app di comunicazione.
Telefonata
- Tipo di servizio in primo piano da dichiarare nel file manifest in
android:foregroundServiceType
phoneCall
- Autorizzazione da dichiarare nel manifest
FOREGROUND_SERVICE_PHONE_CALL
- Costante per passare a
startForeground()
FOREGROUND_SERVICE_TYPE_PHONE_CALL
- Prerequisiti di runtime
Deve essere vera almeno una di queste condizioni:
- L'app ha dichiarato l'autorizzazione
MANAGE_OWN_CALLS
nel file manifest.
- L'app ha dichiarato l'autorizzazione
- App è l'app tastiera predefinita tramite il ruolo
ROLE_DIALER
.
- App è l'app tastiera predefinita tramite il ruolo
- Descrizione
Continuare una chiamata in corso utilizzando le API
ConnectionService
.- Alternative
Se devi effettuare chiamate telefoniche, video o VoIP, valuta di utilizzare la libreria di
android.telecom
.Valuta la possibilità di utilizzare
CallScreeningService
per filtrare le chiamate.
Messaggistica remota
- Foreground service type to declare in manifest under
android:foregroundServiceType
remoteMessaging
- Permission to declare in your manifest
FOREGROUND_SERVICE_REMOTE_MESSAGING
- Constant to pass to
startForeground()
FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING
- Runtime prerequisites
- None
- Description
- Transfer text messages from one device to another. Assists with continuity of a user's messaging tasks when they switch devices.
Servizio breve
- Tipo di servizio in primo piano da dichiarare nel file manifest in
android:foregroundServiceType
shortService
- Autorizzazione da dichiarare nel manifest
- Nessuno
- Costante per passare a
startForeground()
FOREGROUND_SERVICE_TYPE_SHORT_SERVICE
- Prerequisiti di runtime
- Nessuno
- Descrizione
Completa rapidamente il lavoro critico che non può essere interrotto o posticipato.
Questo tipo presenta alcune caratteristiche uniche:
- Può essere eseguito solo per un breve periodo di tempo (circa 3 minuti).
- Nessun supporto per i servizi in primo piano fissi.
- Impossibile avviare altri servizi in primo piano.
- Non richiede un'autorizzazione specifica per tipo, ma
richiede comunque l'autorizzazione
FOREGROUND_SERVICE
. - Un
shortService
può passare a un altro tipo di servizio solo se l'app è attualmente idonea ad avviare un nuovo servizio in primo piano. - Un servizio in primo piano può modificare il proprio tipo in
shortService
in qualsiasi momento, dopodiché inizia il periodo di timeout.
Il timeout per shortService inizia nel momento in cui viene chiamato
Service.startForeground()
. L'app dovrebbe chiamareService.stopSelf()
oService.stopForeground()
prima del timeout. In caso contrario, viene chiamato il nuovoService.onTimeout()
, che offre alle app una breve possibilità di chiamarestopSelf()
ostopForeground()
per interrompere il servizio.Poco tempo dopo la chiamata di
Service.onTimeout()
, l'app entra in uno stato memorizzato nella cache e non è più considerata in primo piano, a meno che l'utente non stia interagendo attivamente con l'app. Poco tempo dopo che l'app viene memorizzata nella cache e il servizio non è stato interrotto, l'app riceve un ANR. Il messaggio ANR menzionaFOREGROUND_SERVICE_TYPE_SHORT_SERVICE
. Per questi motivi, è considerata una best practice implementare il callbackService.onTimeout()
.Il callback
Service.onTimeout()
non esiste su Android 13 e versioni precedenti. Se su questi dispositivi viene eseguito lo stesso servizio, non riceve alcun timeout, né l'errore ANR. Assicurati che il servizio si interrompa non appena termina l'attività di elaborazione, anche se non ha ancora ricevuto il callbackService.onTimeout()
.È importante notare che se il timeout di
shortService
non viene rispettato, l'app restituirà un errore ANR anche se ha altri servizi in primo piano validi o altri processi del ciclo di vita delle app in esecuzione.Se un'app è visibile all'utente o soddisfa una delle esenzioni che consentono l'avvio dei servizi in primo piano in background, la chiamata
Service.StartForeground()
di nuovo con il parametroFOREGROUND_SERVICE_TYPE_SHORT_SERVICE
estende il timeout di altri 3 minuti. Se l'app non è visibile all'utente e non soddisfa una delle esenzioni, qualsiasi tentativo di avviare un altro servizio in primo piano, indipendentemente dal tipo, causerà unaForegroundServiceStartNotAllowedException
.Se un utente disattiva l'ottimizzazione della batteria per la tua app, l'evento viene comunque influenzato dal timeout di shortService FGS.
Se avvii un servizio in primo piano che include il tipo
shortService
e un altro tipo di servizio in primo piano, il sistema ignora la dichiarazione del tiposhortService
. Tuttavia, il servizio deve comunque rispettare i prerequisiti degli altri tipi dichiarati. Per ulteriori informazioni, consulta la documentazione sui servizi in primo piano.
Uso speciale
- Foreground service type to declare in manifest under
android:foregroundServiceType
specialUse
- Permission to declare in your manifest
FOREGROUND_SERVICE_SPECIAL_USE
- Constant to pass to
startForeground()
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
- Runtime prerequisites
- None
- Description
Covers any valid foreground service use cases that aren't covered by the other foreground service types.
In addition to declaring the
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
foreground service type, developers should declare use cases in the manifest. To do so, they specify the<property>
element within the<service>
element. These values and corresponding use cases are reviewed when you submit your app in the Google Play Console. The use cases you provide are free-form, and you should make sure to provide enough information to let the reviewer see why you need to use thespecialUse
type.<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 esente
- Tipo di servizio in primo piano da dichiarare nel file manifest in
android:foregroundServiceType
systemExempted
- Autorizzazione da dichiarare nel manifest
FOREGROUND_SERVICE_SYSTEM_EXEMPTED
- Costante per passare a
startForeground()
FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED
- Prerequisiti di runtime
- Nessuno
- Descrizione
Riservato per applicazioni di sistema e integrazioni di sistema specifiche, per continuare a utilizzare i servizi in primo piano.
Per utilizzare questo tipo, un'app deve soddisfare almeno uno dei seguenti criteri:
- Il dispositivo è in modalità demo
- L'app è un proprietario del dispositivo
- L'app è proprietario di Profiler
- App per la sicurezza con il ruolo
ROLE_EMERGENCY
- App Amministratore dispositivo
- App con autorizzazione
SCHEDULE_EXACT_ALARM
oUSE_EXACT_ALARM
App VPN (configurate con Impostazioni > Rete e internet > VPN)
In caso contrario, la dichiarazione di questo tipo fa sì che il sistema restituisca un elemento
ForegroundServiceTypeNotAllowedException
.
Applicazione delle norme di Google Play per l'utilizzo di tipi di servizi in primo piano
Se la tua app ha come target Android 14 o versioni successive, devi dichiarare i tipi di servizi in primo piano dell'app nella pagina Contenuti app di Play Console (Norme > Contenuti app). Per maggiori informazioni su come dichiarare i tipi di servizi in primo piano in Play Console, consulta Informazioni sui requisiti relativi al servizio in primo piano e all'intent a schermo intero.