Modificare le impostazioni di geolocalizzazione

Se l'app deve richiedere la posizione o ricevere aggiornamenti delle autorizzazioni, il dispositivo deve attivare le impostazioni di sistema appropriate, ad esempio la ricerca GPS o Wi-Fi. Anziché abilitare direttamente servizi come il GPS del dispositivo, la tua app specifica il livello richiesto di accuratezza/consumo energetico 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 Impostazioni per verificare quali impostazioni sono attive e presentare la finestra di dialogo Impostazioni di geolocalizzazione per consentire all'utente di aggiornare le proprie impostazioni con un solo tocco.

Configura i servizi di geolocalizzazione

Per utilizzare i servizi di geolocalizzazione forniti da Google Play Services e dal provider di geolocalizzazione unito, connetti la tua app tramite il client Impostazioni, quindi controlla le attuali impostazioni di geolocalizzazione e chiedi all'utente di attivare le impostazioni richieste, se necessario.

Le app le cui funzionalità usano i servizi di geolocalizzazione 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 provider di località integrato, crea un LocationRequest. I parametri determinano il livello di precisione delle richieste di posizione. Per i dettagli di tutte le opzioni di richiesta di posizione disponibili, consulta la documentazione di riferimento della classe LocationRequest. Questa lezione imposta l'intervallo di aggiornamento, l'intervallo di aggiornamento più rapido e la priorità, come descritto di seguito:

Intervallo di aggiornamento
setInterval() - Questo metodo imposta la frequenza in millisecondi alla quale l'app preferisce ricevere gli aggiornamenti della posizione. Tieni presente che gli aggiornamenti della posizione potrebbero essere un po' più rapidi o più lenti di questa velocità per ottimizzare l'utilizzo della batteria oppure potrebbero non esserci aggiornamenti (ad esempio se il dispositivo non ha connettività).
Intervallo di aggiornamento più rapido
setFastestInterval() - Questo metodo imposta la frequenza più veloce in millisecondi con cui la tua app può gestire gli aggiornamenti di posizione. A meno che la tua app non riceva aggiornamenti più rapidamente rispetto alla tariffa specificata in setInterval(), non è necessario chiamare questo metodo.
Priorità

setPriority() - Questo metodo imposta la priorità della richiesta, fornendo ai servizi di geolocalizzazione di Google Play Services un suggerimento deciso sulle origini di geolocalizzazione da utilizzare. Sono supportati i seguenti valori:

  • PRIORITY_BALANCED_POWER_ACCURACY - Utilizza questa impostazione per richiedere la precisione della posizione all'interno di un isolato, con una precisione di circa 100 metri. Questo è considerato un livello di precisione approssimativo e probabilmente consuma meno energia. Con questa impostazione, è probabile che i servizi di geolocalizzazione utilizzino il posizionamento Wi-Fi e del ripetitore di telefonia mobile. Tuttavia, tieni presente che la scelta del provider di località dipende da molti altri fattori, ad esempio dalle origini disponibili.
  • PRIORITY_HIGH_ACCURACY - Utilizza questa impostazione per richiedere la posizione più precisa possibile. Con questa impostazione, è più probabile che i servizi di geolocalizzazione utilizzino il GPS per determinare la posizione.
  • PRIORITY_LOW_POWER - Utilizza questa impostazione per richiedere la precisione a livello di città, ovvero una precisione di circa 10 chilometri. Questo è considerato un livello di precisione approssimativo e probabilmente consuma meno energia.
  • PRIORITY_NO_POWER - Utilizza questa impostazione se hai bisogno di un impatto trascurabile sul consumo energetico, ma vuoi ricevere aggiornamenti sulla posizione quando disponibili. Con questa impostazione, la tua app non attiva alcun aggiornamento della posizione, ma riceve le sedi attivate da altre app.

Crea la richiesta di località e imposta i parametri come mostrato in questo esempio di codice:

Kotlin

fun createLocationRequest() {
  val locationRequest = LocationRequest.Builder()
      .setIntervalMillis(10000)
      .setFastestIntervalMillis(5000)
      .setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY)
      .build()
}

Java

protected void createLocationRequest() {
  LocationRequest locationRequest = LocationRequest.Builder()
      .setIntervalMillis(10000)
      .setFastestIntervalMillis(5000)
      .setPriority(LocationRequest.PRIORITY_HIGH_ACCURACY)
      .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 con un intervallo di aggiornamento rapido di 5000 millisecondi (5 secondi), fa sì che il provider della posizione fuso restituisca aggiornamenti della posizione con una precisione di pochi metri. Questo approccio è appropriato per la mappatura delle app che mostrano la posizione in tempo reale.

Suggerimento per le prestazioni: 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ù rapido su un valore più lento. Questo aggiustamento impedisce all'app di ricevere gli aggiornamenti che non può utilizzare. Una volta terminato il lavoro a lunga esecuzione, imposta l'intervallo più veloce su un valore veloce.

Visualizzare le impostazioni di geolocalizzazione attuali

Dopo aver effettuato la connessione a Google Play Services e all'API dei servizi di geolocalizzazione, puoi ottenere le impostazioni di geolocalizzazione attuali del dispositivo di un utente. Per farlo, crea una LocationSettingsRequest.Builder e aggiungi una o più richieste di posizione. Il seguente snippet di codice mostra come aggiungere la richiesta di località creata nel passaggio precedente:

Kotlin

val builder = LocationSettingsRequest.Builder()
        .addLocationRequest(locationRequest)

Java

LocationSettingsRequest.Builder builder = new LocationSettingsRequest.Builder()
     .addLocationRequest(locationRequest);

Dopodiché controlla se le impostazioni di geolocalizzazione correnti 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());

Una volta completata l'attività Task, la tua app può controllare le impostazioni di geolocalizzazione esaminando il codice di stato dell'oggetto LocationSettingsResponse. Per avere ancora più dettagli sullo stato attuale delle impostazioni di geolocalizzazione pertinenti, la tua app può chiamare il metodo getLocationSettingsStates() dell'oggetto LocationSettingsResponse.

Chiedi all'utente di modificare le impostazioni di geolocalizzazione

Per determinare se le impostazioni di geolocalizzazione sono appropriate per la richiesta di località, aggiungi un elemento OnFailureListener all'oggetto Task che convalida le impostazioni di geolocalizzazione. Poi, controlla se l'oggetto Exception passato al metodo onFailure() è un'istanza di classe ResolvableApiException, il che indica che le impostazioni devono essere modificate. Quindi, visualizza una finestra di dialogo che chiede all'utente l'autorizzazione a modificare le impostazioni di geolocalizzazione chiamando il numero startResolutionForResult().

Il seguente snippet di codice mostra come determinare se le impostazioni di geolocalizzazione dell'utente consentono ai servizi di geolocalizzazione di creare una LocationRequest e come chiedere all'utente l'autorizzazione per modificare le impostazioni di geolocalizzazione, 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.
            }
        }
    }
});

Nella lezione successiva, Ricezione degli aggiornamenti della posizione, viene illustrato come ricevere aggiornamenti periodici sulla posizione.