Za pomocą pakietu Places SDK na Androida możesz odkrywać miejsca w lokalizacji aktualnie zgłaszanej przez urządzenie. Przykłady miejsc to firmy działające lokalnie, ciekawe miejsca i lokalizacje geograficzne.
Uprawnienia
Aby korzystać z biblioteki, nie musisz deklarować w pliku manifestu aplikacji żadnych dodatkowych uprawnień, ponieważ biblioteka deklaruje w swoim pliku manifestu wszystkie uprawnienia, z których korzysta. Jeśli jednak Twoja aplikacja korzysta z PlacesClient.findCurrentPlace()
, musisz poprosić o uprawnienia do lokalizacji w czasie działania.
Jeśli Twoja aplikacja nie korzysta z PlacesClient.findCurrentPlace()
, usuń z niej uprawnienia ACCESS_FINE_LOCATION
i ACCESS_COARSE_LOCATION
wprowadzone przez bibliotekę, dodając do manifestu te wiersze:
<manifest ... xmlns:tools="http://schemas.android.com/tools"> ... <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" tools:node="remove"/> <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" tools:node="remove"/> ... </manifest>
Dowiedz się więcej o uprawnieniach i rozpocznij korzystanie z EasyPermissions.
Pobieranie bieżącej lokalizacji
Aby znaleźć lokalną firmę lub inne miejsce, w którym aktualnie znajduje się urządzenie, wykonaj te czynności:
- Wywołaj
ContextCompat.checkSelfPermission
, aby sprawdzić, czy użytkownik przyznał uprawnienia dostępu do lokalizacji urządzenia. Aplikacja musi też zawierać kod, który wyświetla prośbę o przyznanie uprawnień i obsługuje wynik. Szczegółowe informacje znajdziesz w artykule Prośba o uprawnienia aplikacji. - Utwórz
FindCurrentPlaceRequest
, przekazującList
Place.Field
, określając typy danych o miejscach, o które aplikacja powinna wysyłać prośby. - Wywołaj funkcję
PlacesClient.findCurrentPlace()
, przekazując utworzony w poprzednim kroku parametrFindCurrentPlaceRequest
. - Pobierz listę
PlaceLikelihood
zFindCurrentPlaceResponse
.
Pola odpowiadają wynikom wyszukiwania miejsc i są podzielone na 3 kategorie rozliczeniowe: podstawowe, kontaktowe i atmosfera. Za pola podstawowe naliczana jest stawka podstawowa, bez dodatkowych opłat. Pola Contact i Atmosphere są rozliczane według wyższej stawki. Więcej informacji o tym, jak rozliczane są żądania danych o miejscach, znajdziesz w artykule Użycie i rozliczenia.
Interfejs API zwraca wartość FindCurrentPlaceResponse
w Task
.
Obiekt FindCurrentPlaceResponse
zawiera listę obiektów PlaceLikelihood
, które reprezentują miejsca, w których urządzenie może się znajdować. W przypadku każdego miejsca wynik zawiera informację o prawdopodobieństwie, że jest to właściwe miejsce. Lista może być pusta, jeśli nie ma znanego miejsca odpowiadającego danej lokalizacji urządzenia.
Możesz wywołać funkcję
PlaceLikelihood.getPlace()
, aby pobrać obiekt
Place
, oraz funkcję
PlaceLikelihood.getLikelihood()
, aby uzyskać ocenę prawdopodobieństwa miejsca. Im wyższa wartość, tym większe prawdopodobieństwo, że miejsce jest najlepiej dopasowane.
Poniższy przykładowy kod pobiera listę miejsc, w których urządzenie najprawdopodobniej się znajduje, i rejestruje nazwę oraz prawdopodobieństwo dla każdego miejsca.
Kotlin
// Use fields to define the data types to return. val placeFields = listOf(Place.Field.DISPLAY_NAME, Place.Field.FORMATTED_ADDRESS, Place.Field.LOCATION) val request = FindCurrentPlaceRequest.newInstance(placeFields) // Call findCurrentPlace and handle the response (first check that the user has granted permission). if (ContextCompat.checkSelfPermission(this, permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED ) { placesClient.findCurrentPlace(request).addOnSuccessListener { response -> binding.progressBar.visibility = View.GONE adapter.setPlaceLikelihoods(response.placeLikelihoods) }.addOnFailureListener { exception -> binding.progressBar.visibility = View.GONE if (exception is ApiException) { Log.e(TAG, "Place not found: ${exception.statusCode}") } } } else { // A local method to request required permissions; // See https://developer.android.com/training/permissions/requesting getLocationPermission() }
Java
// Use fields to define the data types to return. List<Place.Field> placeFields = Arrays.asList(Place.Field.DISPLAY_NAME, Place.Field.FORMATTED_ADDRESS, Place.Field.LOCATION); // Use the builder to create a FindCurrentPlaceRequest. FindCurrentPlaceRequest request = FindCurrentPlaceRequest.newInstance(placeFields); // Call findCurrentPlace and handle the response (first check that the user has granted permission). if (ContextCompat.checkSelfPermission(this, ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED) { Task<FindCurrentPlaceResponse> placeResponse = placesClient.findCurrentPlace(request); placeResponse.addOnCompleteListener(task -> { binding.progressBar.setVisibility(View.GONE); if (task.isSuccessful()) { FindCurrentPlaceResponse response = task.getResult(); adapter.setPlaceLikelihoods(response.getPlaceLikelihoods()); } else { Exception exception = task.getException(); if (exception instanceof ApiException apiException) { Log.e("CurrentPlace", "Place not found: " + apiException.getStatusCode()); } } }); } else { // A local method to request required permissions; // See https://developer.android.com/training/permissions/requesting getLocationPermission(); }
Uwagi dotyczące wartości prawdopodobieństwa:
- Prawdopodobieństwo określa względne prawdopodobieństwo, że dane miejsce jest najlepiej dopasowane na liście zwróconych miejsc w przypadku pojedynczego żądania. Nie możesz porównywać prawdopodobieństwa w przypadku różnych żądań.
- Wartość prawdopodobieństwa będzie mieścić się w zakresie od 0,0 do 1,0.
Na przykład, aby przedstawić 55-procentowe prawdopodobieństwo, że prawidłowym miejscem jest Miejsce A, i 35-procentowe prawdopodobieństwo, że jest to Miejsce B, odpowiedź zawiera 2 elementy: Miejsce A z prawdopodobieństwem 0,55 i Miejsce B z prawdopodobieństwem 0,35.
Wyświetlanie atrybucji w aplikacji
Gdy aplikacja wyświetla informacje uzyskane z PlacesClient.findCurrentPlace()
, musi też wyświetlać informacje o autorstwie. Więcej informacji znajdziesz w dokumentacji dotyczącej atrybucji.