Se la tua app deve richiedere la posizione o ricevere aggiornamenti delle autorizzazioni, il
dispositivo deve attivare le impostazioni di sistema appropriate, come la scansione
GPS o Wi-Fi. Anziché attivare direttamente servizi come il GPS del dispositivo,
la tua app specifica il livello di precisione/consumo energetico richiesto e
l'intervallo di aggiornamento desiderato e il dispositivo apporta automaticamente le modifiche
appropriate alle impostazioni di sistema. Queste impostazioni sono definite dall'oggetto dati
LocationRequest
.
Questa lezione mostra come utilizzare il client di impostazioni per controllare quali impostazioni sono attive e presentare la finestra di dialogo Impostazioni di geolocalizzazione in modo che l'utente possa aggiornare le impostazioni con un solo tocco.
Configurare i servizi di localizzazione
Per utilizzare i servizi di localizzazione forniti da Google Play Services e dal provider di geolocalizzazione ibrida, connetti la tua app utilizzando il client delle impostazioni, quindi controlla le impostazioni di localizzazione attuali e chiedi all'utente di attivare le impostazioni richieste, se necessario.
Le app le cui funzionalità utilizzano i servizi di localizzazione devono richiedere le autorizzazioni di accesso alla posizione, a seconda dei casi d'uso di queste funzionalità.
Configurare una richiesta di posizione
Per archiviare i parametri per le richieste al fornitore di geolocalizzazione combinata, crea un
LocationRequest
.
I parametri determinano il livello di precisione delle richieste di localizzazione. Per
i dettagli di tutte le opzioni di richiesta della posizione disponibili, consulta il
riferimento della classe LocationRequest
. Questa lezione imposta l'intervallo di aggiornamento, l'intervallo di aggiornamento più veloce e la priorità, come descritto di seguito:
- Intervallo aggiornamento
-
setIntervalMillis()
- Questo metodo imposta la frequenza in millisecondi con cui la tua app preferisce ricevere gli aggiornamenti della posizione. Tieni presente che gli aggiornamenti della posizione potrebbero essere leggermente più veloci o più lenti di questa velocità per ottimizzare l'utilizzo della batteria oppure potrebbero non essere presenti aggiornamenti (se il dispositivo non ha connettività, ad esempio). - Intervallo di aggiornamento più veloce
-
setMinUpdateIntervalMillis()
- Questo metodo imposta la velocità più rapida in millisecondi alla quale la tua app può gestire gli aggiornamenti della posizione. A meno che la tua app non tragga vantaggio dalla ricezione di aggiornamenti più rapidamente rispetto alla velocità specificata insetInterval()
, non devi chiamare questo metodo. - Priorità
-
setPriority()
- Questo metodo imposta la priorità della richiesta, fornendo ai servizi di localizzazione di Google Play un suggerimento forte su quali origini della posizione utilizzare. Sono supportati i seguenti valori:-
PRIORITY_BALANCED_POWER_ACCURACY
- Utilizza questa impostazione per richiedere una precisione della posizione entro un isolato della città, ovvero una precisione di circa 100 metri. Questo è considerato un livello di precisione approssimativo e probabilmente consuma meno energia. Con questa impostazione, i servizi di localizzazione probabilmente utilizzeranno il Wi-Fi e il posizionamento dei ripetitori di telefonia mobile. Tieni presente, tuttavia, che la scelta del fornitore di servizi di localizzazione dipende da molti altri fattori, ad esempio dalle fonti disponibili. -
PRIORITY_HIGH_ACCURACY
- Utilizza questa impostazione per richiedere la posizione più precisa possibile. Con questa impostazione, i servizi di localizzazione hanno maggiori probabilità di utilizzare il GPS per determinare la posizione. PRIORITY_LOW_POWER
- Utilizza questa impostazione per richiedere una precisione a livello di città, che è un'accuratezza di circa 10 chilometri. Questo è considerato un livello di precisione grossolano e probabilmente consuma meno energia.PRIORITY_PASSIVE
- Utilizza questa impostazione se hai bisogno di un impatto trascurabile sul consumo energetico, ma vuoi ricevere aggiornamenti della posizione quando disponibili. Con questa impostazione, l'app non attiva aggiornamenti della posizione, ma riceve le posizioni attivate da altre app.
-
Crea la richiesta di localizzazione e imposta i parametri come mostrato in questo esempio di codice:
Kotlin
fun createLocationRequest() { val locationRequest = LocationRequest.Builder(Priority.PRIORITY_HIGH_ACCURACY, 10000) .setMinUpdateIntervalMillis(5000) .build() }
Java
protected void createLocationRequest() { LocationRequest locationRequest = new LocationRequest.Builder(Priority.PRIORITY_HIGH_ACCURACY, 10000) .setMinUpdateIntervalMillis(5000) .build(); }
La priorità di
PRIORITY_HIGH_ACCURACY
,
combinata con l'impostazione
dell'autorizzazione ACCESS_FINE_LOCATION
che hai definito nel file manifest dell'app e un intervallo di aggiornamento
rapido di 5000 millisecondi (5 secondi), fa sì che il provider di geolocalizzazione
combinata restituisca aggiornamenti della posizione precisi al metro.
Questo approccio è appropriato per le app di mappe che mostrano la posizione in
tempo reale.
Suggerimento per il rendimento:se la tua app accede alla rete o esegue altre operazioni a lunga esecuzione dopo aver ricevuto un aggiornamento della posizione, imposta l'intervallo più veloce su un valore più lento. Questo aggiustamento impedisce alla tua app di ricevere aggiornamenti che non può utilizzare. Una volta completata l'operazione a lunga esecuzione, imposta di nuovo l'intervallo più veloce su un valore rapido.
Ottenere le impostazioni di localizzazione attuali
Una volta connesso a Google Play Services e all'API
dei servizi di localizzazione, puoi ottenere le impostazioni di localizzazione attuali del dispositivo di un utente. Per farlo,
crea un
LocationSettingsRequest.Builder
e aggiungi una o più richieste di posizione. Il seguente snippet di codice mostra come
aggiungere la richiesta di localizzazione creata nel passaggio precedente:
Kotlin
val builder = LocationSettingsRequest.Builder() .addLocationRequest(locationRequest)
Java
LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder() .addLocationRequest(locationRequest);
Successivamente, controlla se le impostazioni di localizzazione attuali sono soddisfatte:
Kotlin
val builder = LocationSettingsRequest.Builder() // ... val client: SettingsClient = LocationServices.getSettingsClient(this) val task: Task<LocationSettingsResponse> = client.checkLocationSettings(builder.build())
Java
LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder(); // ... SettingsClient client = LocationServices.getSettingsClient(this); Task<LocationSettingsResponse> task = client.checkLocationSettings(builder.build());
Al termine di Task
, la tua app può controllare le impostazioni di geolocalizzazione esaminando il codice di stato dell'oggetto LocationSettingsResponse
. Per ottenere ancora più dettagli sullo stato attuale delle impostazioni di geolocalizzazione pertinenti, la tua app può chiamare il metodo LocationSettingsResponse
dell'oggetto getLocationSettingsStates()
.
Chiedere all'utente di modificare le impostazioni di geolocalizzazione
Per determinare se le impostazioni di geolocalizzazione sono appropriate per la richiesta di posizione, aggiungi un
OnFailureListener
all'oggetto
Task
che convalida le impostazioni di geolocalizzazione. Quindi, verifica
se l'oggetto
Exception
passato al metodo
onFailure()
è un'istanza della classe
ResolvableApiException
, il che indica che le impostazioni
devono essere modificate. Poi, visualizza una finestra di dialogo che chiede all'utente l'autorizzazione a
modificare le impostazioni di geolocalizzazione chiamando
startResolutionForResult()
.
Il seguente snippet di codice mostra come determinare se le impostazioni di geolocalizzazione dell'utente consentono ai servizi di localizzazione di creare un
LocationRequest
, nonché come chiedere all'utente
l'autorizzazione a modificare le impostazioni di localizzazione, se necessario:
Kotlin
task.addOnSuccessListener { locationSettingsResponse -> // All location settings are satisfied. The client can initialize // location requests here. // ... } task.addOnFailureListener { exception -> if (exception is ResolvableApiException){ // Location settings are not satisfied, but this can be fixed // by showing the user a dialog. try { // Show the dialog by calling startResolutionForResult(), // and check the result in onActivityResult(). exception.startResolutionForResult(this@MainActivity, REQUEST_CHECK_SETTINGS) } catch (sendEx: IntentSender.SendIntentException) { // Ignore the error. } } }
Java
task.addOnSuccessListener(this, new OnSuccessListener<LocationSettingsResponse>() { @Override public void onSuccess(LocationSettingsResponse locationSettingsResponse) { // All location settings are satisfied. The client can initialize // location requests here. // ... } }); task.addOnFailureListener(this, new OnFailureListener() { @Override public void onFailure(@NonNull Exception e) { if (e instanceof ResolvableApiException) { // Location settings are not satisfied, but this can be fixed // by showing the user a dialog. try { // Show the dialog by calling startResolutionForResult(), // and check the result in onActivityResult(). ResolvableApiException resolvable = (ResolvableApiException) e; resolvable.startResolutionForResult(MainActivity.this, REQUEST_CHECK_SETTINGS); } catch (IntentSender.SendIntentException sendEx) { // Ignore the error. } } } });
La lezione successiva, Richiedere aggiornamenti della posizione, mostra come ricevere aggiornamenti periodici della posizione.