Permintaan Nearby Search (Baru) menggunakan wilayah sebagai input untuk ditelusuri yang ditentukan sebagai lingkaran, yang ditentukan oleh koordinat lintang dan bujur titik tengah lingkaran dan radius dalam meter. Permintaan ini menampilkan daftar tempat yang cocok, masing-masing diwakili oleh objek Place
, dalam area penelusuran yang ditentukan.
Secara default, respons berisi semua jenis tempat dalam area penelusuran. Anda dapat memfilter respons secara opsional dengan menentukan daftar jenis tempat yang akan secara eksplisit disertakan dalam atau dikecualikan dari respons. Misalnya, Anda dapat menentukan untuk hanya menyertakan tempat dalam respons yang berjenis "restoran", "toko roti", dan "kafe", atau mengecualikan semua tempat berjenis "sekolah".
Permintaan Nearby Search (Baru)
Buat permintaan Nearby Search (Baru) dengan memanggil
PlacesClient.searchNearby
,
meneruskan objek
SearchNearbyRequest
yang menentukan parameter permintaan.
Objek SearchNearbyRequest
menentukan semua parameter wajib dan opsional
untuk permintaan. Parameter yang diperlukan meliputi:
- Daftar kolom yang akan ditampilkan dalam objek
Place
, yang juga dikenal sebagai mask kolom. Jika Anda tidak menentukan setidaknya satu kolom dalam daftar kolom, atau jika Anda menghapus daftar kolom, panggilan akan menampilkan error. - Pembatasan lokasi untuk area penelusuran, yang ditentukan sebagai pasangan lintang/bujur dan nilai radius, dalam meter.
Contoh permintaan penelusuran terdekat ini menentukan bahwa objek Place
respons
berisi kolom tempat Place.Field.ID
dan Place.Field.DISPLAY_NAME
untuk
setiap objek Place
dalam hasil penelusuran. Kode ini juga memfilter respons agar hanya menampilkan tempat dengan jenis "restaurant" dan "cafe", tetapi mengecualikan tempat dengan jenis "pizza_restaurant" dan "american_restaurant".
// Define a list of fields to include in the response for each returned place. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME); // Define the search area as a 1000 meter diameter circle in New York, NY. LatLng center = new LatLng(40.7580, -73.9855); CircularBounds circle = CircularBounds.newInstance(center, /* radius = */ 1000); // Define a list of types to include. final List<String> includedTypes = Arrays.asList("restaurant", "cafe"); // Define a list of types to exclude. final List<String> excludedTypes = Arrays.asList("pizza_restaurant", "american_restaurant"); // Use the builder to create a SearchNearbyRequest object. final SearchNearbyRequest searchNearbyRequest = SearchNearbyRequest.builder(/* location restriction = */ circle, placeFields) .setIncludedTypes(includedTypes) .setExcludedTypes(excludedTypes) .setMaxResultCount(10) .build()); // Call placesClient.searchNearby() to perform the search. // Define a response handler to process the returned List of Place objects. placesClient.searchNearby(searchNearbyRequest) .addOnSuccessListener(response -> { List<Place> places = response.getPlaces(); });
Respons Nearby Search (Baru)
Class
SearchNearbyResponse
mewakili respons dari permintaan penelusuran. Objek SearchNearbyResponse
berisi:
- Daftar objek
Place
yang mewakili semua tempat yang cocok, dengan satu objekPlace
per tempat yang cocok. - Setiap objek
Place
hanya berisi kolom yang ditentukan oleh daftar kolom yang diteruskan dalam permintaan.
Misalnya, dalam permintaan, Anda menentukan daftar kolom sebagai:
// Define a list of fields to include in the response for each returned place. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.NAME);
Daftar kolom ini berarti setiap objek Place
dalam respons hanya berisi
ID tempat dan nama setiap tempat yang cocok. Kemudian, Anda dapat menggunakan metode Place.getId()
dan Place.getName()
untuk mengakses kolom ini di setiap objek Place
.
Untuk contoh lain tentang cara mengakses data dalam objek Place
, lihat Mengakses kolom data objek Tempat.
Parameter wajib
Gunakan objek
SearchNearbyRequest
untuk menentukan parameter yang diperlukan untuk penelusuran.
Daftar kolom
Saat meminta detail tempat, Anda harus menentukan data yang akan ditampilkan dalam objek
Place
untuk tempat tersebut sebagai mask kolom. Untuk menentukan mask kolom, teruskan array nilai dariPlace.Field
ke objekSearchNearbyRequest
. Penyamaran kolom adalah praktik desain yang baik untuk memastikan Anda tidak meminta data yang tidak diperlukan. Cara ini akan membantu Anda menghindari waktu pemrosesan dan biaya penagihan yang tidak perlu.Tentukan satu atau beberapa kolom berikut:
Kolom berikut memicu SKU Nearby Search (Basic):
Place.Field.ADDRESS_COMPONENTS
,Place.Field.BUSINESS_STATUS
,Place.Field.ADDRESS
,Place.Field.ICON_BACKGROUND_COLOR
,Place.Field.ICON_URL
,Place.Field.LAT_LNG
,Place.Field.PHOTO_METADATAS
,Place.Field.PLUS_CODE
,Place.Field.PRIMARY_TYPE
,Place.Field.PRIMARY_TYPE_DISPLAY_NAME
,Place.Field.ID
,Place.Field.NAME
,Place.Field.TYPES
,Place.Field.UTC_OFFSET
,Place.Field.VIEWPORT
,Place.Field.WHEELCHAIR_ACCESSIBLE_ENTRANCE
Kolom berikut memicu SKU Nearby Search (Advanced):
Place.Field.CURRENT_OPENING_HOURS
,Place.Field.CURRENT_SECONDARY_OPENING_HOURS
Place.Field.INTERNATIONAL_PHONE_NUMBER
,Place.Field.NATIONAL_PHONE_NUMBER
Place.Field.OPENING_HOURS
,Place.Field.PRICE_LEVEL
,Place.Field.RATING
,Place.Field.SECONDARY_OPENING_HOURS
,Place.Field.USER_RATING_COUNT
Place.Field.WEBSITE_URI
Kolom berikut memicu SKU Nearby Search (Preferred):
Place.Field.ALLOWS_DOGS
,Place.Field.CURBSIDE_PICKUP
,Place.Field.DELIVERY
,Place.Field.DINE_IN
,Place.Field.EDITORIAL_SUMMARY
,Place.Field.EV_CHARGE_OPTIONS
,Place.Field.FUEL_OPTIONS
,Place.Field.GOOD_FOR_CHILDREN
,Place.Field.GOOD_FOR_GROUPS
,Place.Field.GOOD_FOR_WATCHING_SPORTS
,Place.Field.LIVE_MUSIC
,Place.Field.MENU_FOR_CHILDREN
,Place.Field.OUTDOOR_SEATING
,Place.Field.PARKING_OPTIONS
,Place.Field.PAYMENT_OPTIONS
,Place.Field.RESERVABLE
,Place.Field.RESTROOM
,Place.Field.REVIEWS
,Place.Field.SERVES_BEER
,Place.Field.SERVES_BREAKFAST
,Place.Field.SERVES_BRUNCH
,Place.Field.SERVES_COCKTAILS
,Place.Field.SERVES_COFFEE
,Place.Field.SERVES_DESSERT
,Place.Field.SERVES_DINNER
,Place.Field.SERVES_LUNCH
,Place.Field.SERVES_VEGETARIAN_FOOD
,Place.Field.SERVES_WINE
,Place.Field.TAKEOUT
Untuk menetapkan parameter daftar kolom, panggil metode
setPlaceFields()
saat mem-build objekSearchNearbyRequest
.Contoh berikut menentukan daftar dua nilai kolom untuk menentukan bahwa objek
Place
yang ditampilkan oleh permintaan berisi kolomPlace.Field.ID
danPlace.Field.DISPLAY_NAME
:
// Define a list of fields to include in the response for each returned place. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME);
Pembatasan lokasi
Objek
LocationRestriction
yang menentukan wilayah yang akan ditelusuri yang ditentukan sebagai lingkaran, yang ditentukan oleh titik tengah dan radius dalam meter. Radius harus lebih besar dari 0.0 dan kurang dari atau sama dengan 50000.0, dengan mengingat bahwa menentukan radius yang terlalu kecil akan menampilkanZERO_RESULTS
sebagai respons.Untuk menetapkan parameter pembatasan lokasi, panggil metode
setLocationRestriction()
saat mem-build objekSearchNearbyRequest
.
Parameter opsional
Gunakan objek
SearchNearbyRequest
untuk menentukan parameter opsional untuk penelusuran.
-
Jenis dan jenis utama
Memungkinkan Anda menentukan daftar jenis dari jenis Tabel A yang digunakan untuk memfilter hasil penelusuran. Maksimal 50 jenis dapat ditentukan di setiap kategori batasan jenis.
Tempat hanya dapat memiliki satu jenis utama dari jenis Tabel A yang terkait dengan tempat tersebut. Misalnya, jenis utama mungkin
"mexican_restaurant"
atau"steak_house"
. GunakanincludedPrimaryTypes
danexcludedPrimaryTypes
untuk memfilter hasil pada jenis utama tempat.Tempat juga dapat memiliki beberapa nilai jenis dari jenis Tabel A yang terkait dengannya. Misalnya, restoran mungkin memiliki jenis berikut:
"seafood_restaurant"
,"restaurant"
,"food"
,"point_of_interest"
,"establishment"
. GunakanincludedTypes
danexcludedTypes
untuk memfilter hasil pada daftar jenis yang terkait dengan tempat.Saat Anda menentukan jenis utama umum, seperti
"restaurant"
atau"hotel"
, respons dapat berisi tempat dengan jenis utama yang lebih spesifik daripada yang ditentukan. Misalnya, Anda menentukan untuk menyertakan jenis utama"restaurant"
. Respons kemudian dapat berisi tempat dengan jenis utama"restaurant"
, tetapi respons juga dapat berisi tempat dengan jenis utama yang lebih spesifik, seperti"chinese_restaurant"
atau"seafood_restaurant"
.Jika penelusuran ditentukan dengan beberapa batasan jenis, hanya tempat yang memenuhi semua batasan yang akan ditampilkan. Misalnya, jika Anda menentukan
includedTypes = Arrays.asList("restaurant")
danexcludedPrimaryTypes = Arrays.asList("steak_house")
, tempat yang ditampilkan akan menyediakan layanan terkait"restaurant"
, tetapi tidak beroperasi terutama sebagai"steak_house"
.Untuk contoh cara menggunakan
includedTypes
danexcludedTypes
, lihat permintaan Nearby Search (Baru).Jenis yang disertakan
Daftar jenis tempat dari Tabel A yang akan ditelusuri. Jika parameter ini dihilangkan, semua jenis tempat akan ditampilkan.
Untuk menetapkan parameter jenis yang disertakan, panggil metode
setIncludedTypes()
saat mem-build objekSearchNearbyRequest
.Jenis yang dikecualikan
Daftar jenis tempat dari Tabel A yang akan dikecualikan dari penelusuran.
Jika Anda menentukan
includedTypes
(seperti"school"
) danexcludedTypes
(seperti"primary_school"
) dalam permintaan, respons akan menyertakan tempat yang dikategorikan sebagai"school"
, tetapi bukan sebagai"primary_school"
. Responsnya mencakup tempat yang cocok dengan setidaknya satu dariincludedTypes
dan tidak satu pun dariexcludedTypes
.Jika ada jenis yang bertentangan, seperti jenis yang muncul di
includedTypes
danexcludedTypes
, errorINVALID_REQUEST
akan ditampilkan.Untuk menetapkan parameter jenis yang dikecualikan, panggil metode
setExcludedTypes()
saat mem-build objekSearchNearbyRequest
.Jenis utama yang disertakan
Daftar jenis tempat utama dari Tabel A untuk disertakan dalam penelusuran.
Untuk menetapkan parameter jenis utama yang disertakan, panggil metode
setIncludedPrimaryTypes()
saat mem-build objekSearchNearbyRequest
.Jenis utama yang dikecualikan
Daftar jenis tempat utama dari Tabel A untuk dikecualikan dari penelusuran.
Jika ada jenis utama yang bertentangan, seperti jenis yang muncul di
includedPrimaryTypes
danexcludedPrimaryTypes
, errorINVALID_ARGUMENT
akan ditampilkan.Untuk menetapkan parameter jenis utama yang dikecualikan, panggil metode
setExcludedPrimaryTypes()
saat mem-build objekSearchNearbyRequest
. -
Jumlah hasil maksimum
Menentukan jumlah maksimum hasil tempat yang akan ditampilkan. Harus antara 1 dan 20 (default) inklusif.
Untuk menetapkan parameter jumlah hasil maksimum, panggil metode
setMaxResultCount()
saat mem-build objekSearchNearbyRequest
. -
Preferensi peringkat
Jenis peringkat yang akan digunakan. Jika parameter ini dihilangkan, hasil akan diberi peringkat berdasarkan popularitas. Dapat berupa salah satu dari hal berikut:
POPULARITY
(default) Mengurutkan hasil berdasarkan popularitasnya.DISTANCE
Mengurutkan hasil dalam urutan menaik berdasarkan jaraknya dari lokasi yang ditentukan.
Untuk menetapkan parameter preferensi peringkat, panggil metode
setRankPreference()
saat mem-build objekSearchNearbyRequest
. -
Kode wilayah
Kode wilayah yang digunakan untuk memformat respons, yang ditentukan sebagai nilai kode CLDR dua karakter. Tidak ada nilai default.
Jika nama negara kolom
FORMATTED_ADDRESS
dalam respons cocok denganregionCode
, kode negara akan dihilangkan dariFORMATTED_ADDRESS
.Sebagian besar kode CLDR identik dengan kode ISO 3166-1, dengan beberapa pengecualian. Misalnya, ccTLD Inggris Raya adalah "uk" (.co.uk) sedangkan kode ISO 3166-1-nya adalah "gb" (secara teknis untuk entitas "The United Kingdom of Great Britain and Northern Ireland"). Parameter ini dapat memengaruhi hasil berdasarkan hukum yang berlaku.
Untuk menetapkan parameter kode wilayah, panggil metode
setRegionCode()
saat mem-build objekSearchNearbyRequest
.
Menampilkan atribusi dalam aplikasi Anda
Saat aplikasi Anda menampilkan informasi yang diperoleh dari
PlacesClient
,
seperti foto dan ulasan, aplikasi juga harus menampilkan atribusi yang diperlukan.
Untuk informasi selengkapnya, lihat Kebijakan untuk Places SDK for Android.