Текстовый поиск (новое) возвращает информацию о наборе мест на основе строки — например, «пицца в Нью-Йорке», «обувные магазины недалеко от Оттавы» или «Мейн-стрит, 123». Служба отвечает списком мест, соответствующих текстовой строке, и любым установленным смещениям местоположения.
Эта служба особенно полезна для выполнения неоднозначных адресных запросов в автоматизированной системе, поскольку неадресные компоненты строки могут соответствовать как предприятиям, так и адресам. Примерами неоднозначных адресных запросов являются плохо отформатированные адреса или запросы, которые включают неадресные компоненты, такие как названия компаний. Запросы, подобные первым двум примерам, могут возвращать нулевые результаты, если не установлено местоположение, например регион, ограничение местоположения или смещение местоположения.
Текстовый поиск (новое) аналогичен поиску поблизости (новое) . Основное различие между ними заключается в том, что текстовый поиск (новый) позволяет указать произвольную строку поиска, а поиск поблизости (новый) требует определенной области для поиска.
«10 High Street, Великобритания» или «123 Main Street, США». | Несколько «Хай-стрит» в Великобритании; несколько «Мейн-стрит» в США. Запрос не возвращает желаемых результатов, если не установлено ограничение местоположения. |
«Сеть ресторанов Нью-Йорк» | Несколько ресторанов ChainRestaurant в Нью-Йорке; ни адреса, ни даже названия улицы. |
«10 High Street, Escher UK» или «123 Main Street, Pleasanton US» | Единственная «Хай-стрит» в британском городе Эшер; только одна «Мейн-стрит» в американском городе Плезантон, Калифорния. |
«UniqueRestaurantName Нью-Йорк» | В Нью-Йорке только одно заведение с таким названием; никакой адрес не нужен для различения. |
"пиццерии в Нью-Йорке" | Этот запрос содержит ограничение по местоположению, а «рестораны-пиццерии» – это четко определенный тип места. Он возвращает несколько результатов. |
"+1 514-670-8700" | Этот запрос содержит номер телефона. Он возвращает несколько результатов для мест, связанных с этим номером телефона. |
Запросы текстового поиска
Запрос текстового поиска имеет форму:
// Specify the list of fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME); // Define latitude and longitude coordinates of the search area. LatLng southWest = new LatLng(37.38816277477739, -122.08813770258874); LatLng northEast = new LatLng(37.39580487866437, -122.07702325966572); // Use the builder to create a SearchByTextRequest object. final SearchByTextRequest searchByTextRequest = SearchByTextRequest.builder("Spicy Vegetarian Food", placeFields) .setMaxResultCount(10) .setLocationRestriction(RectangularBounds.newInstance(southWest, northEast)).build(); // Call PlacesClient.searchByText() to perform the search. // Define a response handler to process the returned List of Place objects. placesClient.searchByText(searchByTextRequest) .addOnSuccessListener(response -> { List<Place> places = response.getPlaces(); });
В этом примере вы:
Настройте список полей, включив в него только
Place.Field.ID
иPlace.Field.DISPLAY_NAME
. Это означает, что объектыPlace
в ответе, представляющие каждое совпадающее место, содержат только эти два поля.Используйте
SearchByTextRequest.Builder
, чтобы создать объектSearchByTextRequest
, определяющий поиск.Установите текстовую строку запроса «Острая вегетарианская еда».
Установите максимальное количество мест в результате равным 10. Значение по умолчанию и максимальное значение — 20.
Ограничьте область поиска прямоугольником, определяемым координатами широты и долготы. Никакие совпадения за пределами этой области не возвращаются.
Добавьте
OnSuccessListener
и получите соответствующие места из объектаSearchByTextResponse
.
Ответы на текстовый поиск
Класс SearchByTextResponse
представляет ответ на поисковый запрос. Объект SearchByTextResponse
содержит:
Список объектов
Place
, представляющих все подходящие места, по одному объектуPlace
на каждое подходящее место.Каждый объект
Place
содержит только поля, определенные списком полей, переданным в запросе.
Например, в запросе вы определили список полей как:
// Specify the list of fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME);
Этот список полей означает, что каждый объект Place
в ответе содержит только идентификатор места и название каждого соответствующего места. Затем вы можете использовать методы Place.getId()
и Place.getName()
для доступа к этим полям в каждом объекте Place
.
Дополнительные примеры доступа к данным в объекте Place
см. в разделе Доступ к полям данных объекта Place.
Обязательные параметры
Обязательные параметры для SearchByTextRequest
:
Список полей
Укажите, какие поля данных места нужно вернуть. Передайте список значений
Place.Field
определяющих возвращаемые поля данных. В ответе нет списка возвращаемых полей по умолчанию.Списки полей — это хорошая практика проектирования, позволяющая избежать запроса ненужных данных, что помогает избежать ненужного времени обработки и расходов по счетам.
Укажите одно или несколько из следующих полей:
Следующие поля запускают SKU текстового поиска (только идентификатор) :
Place.Field.DISPLAY_NAME
,Place.Field.ID
,Place.Field.RESOURCE_NAME
Следующие поля активируют SKU текстового поиска (базовый) :
Place.Field.ACCESSIBILITY_OPTIONS
,Place.Field.ADDRESS_COMPONENTS
,Place.Field.ADR_FORMAT_ADDRESS
,Place.Field.BUSINESS_STATUS
,Place.Field.FORMATTED_ADDRESS
,Place.Field.GOOGLE_MAPS_URI
,Place.Field.ICON_BACKGROUND_COLOR
,Place.Field.ICON_MASK_URL
,Place.Field.LOCATION
,Place.Field.PHOTO_METADATAS
,Place.Field.PLUS_CODE
,Place.Field.PRIMARY_TYPE_DISPLAY_NAME
,Place.Field.SHORT_FORMATTED_ADDRESS
,Place.Field.SUB_DESTINATIONS
,Place.Field.TYPES
,Place.Field.UTC_OFFSET
,Place.Field.VIEWPORT
Следующие поля активируют SKU текстового поиска (расширенный) :
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
. SECONDARY_OPENING_HOURS ,Place.Field.USER_RATING_COUNT
Place.Field.WEBSITE_URI
Следующие поля активируют SKU текстового поиска (предпочтительный) :
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
d.SERVES_DINNER ,Place.Field.SERVES_LUNCH
,Place.Field.SERVES_VEGETARIAN_FOOD
,Place.Field.SERVES_WINE
,Place.Field.TAKEOUT
Чтобы задать параметр списка полей, вызовите метод
setPlaceFields()
при построении объектаSearchByTextRequest
.Текстовый запрос
Текстовая строка для поиска, например: «ресторан», «123 Main Street» или «лучшее место для посещения в Сан-Франциско». API возвращает совпадения кандидатов на основе этой строки и упорядочивает результаты на основе их предполагаемой релевантности.
Чтобы задать параметр текстового запроса, вызовите метод
setTextQuery()
при построении объектаSearchByTextRequest
.
Дополнительные параметры
Используйте объект SearchByTextRequest
, чтобы указать необязательные параметры вашего запроса.
Включенный тип
Ограничивает результаты местами, соответствующими указанному типу, определенному в таблице A. Можно указать только один тип. Например:
-
setIncludedType("bar")
-
setIncludedType("pharmacy")
Чтобы установить параметр включенного типа, вызовите метод
setIncludedType()
при построении объектаSearchByTextRequest
.-
Предвзятость местоположения
Указывает область для поиска. Это местоположение служит смещением, что означает, что могут быть возвращены результаты вокруг указанного местоположения, включая результаты за пределами указанной области.
Вы можете указать ограничение местоположения или смещение местоположения, но не то и другое. Подумайте об ограничении местоположения как об указании региона, в котором должны находиться результаты, а о смещении местоположения как об указании региона, рядом с которым результаты должны находиться, но могут находиться за его пределами.
Укажите область в виде прямоугольного видового экрана или круга.
Круг определяется центральной точкой и радиусом в метрах. Радиус должен находиться в диапазоне от 0,0 до 50000,0 включительно. Например:
// Define latitude and longitude coordinates of the center of the search area. LatLng searchCenter = new LatLng(37.38816277477739, -122.08813770258874); // Use the builder to create a SearchByTextRequest object. // Set the radius of the search area to 500.0 meters. final SearchByTextRequest searchByTextRequest = SearchByTextRequest.builder("Spicy Vegetarian Food", placeFields) .setMaxResultCount(10) .setLocationBias(CircularBounds.newInstance(searchCenter, 500.0)).build();
Прямоугольник — это окно просмотра широты и долготы, представленное в виде двух диагонально противоположных нижней и верхней точек. Нижняя точка обозначает юго-западный угол прямоугольника, а верхняя точка представляет собой северо-восточный угол прямоугольника.
Область просмотра считается закрытой областью, то есть включает в себя ее границу. Границы широты должны находиться в диапазоне от -90 до 90 градусов включительно, а границы долготы должны находиться в диапазоне от -180 до 180 градусов включительно:
- Если
low
=high
, область просмотра состоит из этой единственной точки. - Если
low.longitude
>high.longitude
, диапазон долготы инвертируется (окно просмотра пересекает линию долготы в 180 градусов). - Если
low.longitude
= -180 градусов иhigh.longitude
= 180 градусов, область просмотра включает все значения долготы. - Если
low.longitude
= 180 градусов иhigh.longitude
= -180 градусов, диапазон долготы пуст. - Если
low.latitude
>high.latitude
, диапазон широт пуст.
Оба значения low и high должны быть заполнены, а представленное поле не может быть пустым. Пустое окно просмотра приводит к ошибке.
Например, о прямоугольном окне просмотра см. Запросы текстового поиска .
Чтобы установить параметр смещения местоположения, вызовите метод
setLocationBias()
при построении объектаSearchByTextRequest
.- Если
Ограничение местоположения
Указывает область для поиска. Результаты за пределами указанной области не возвращаются. Укажите регион в виде прямоугольного видового экрана. См. описание смещения местоположения для получения информации об определении области просмотра.
Вы можете указать ограничение местоположения или смещение местоположения, но не то и другое. Подумайте об ограничении местоположения как об указании региона, в котором должны находиться результаты, а о смещении местоположения как об указании региона, в котором результаты должны находиться рядом, но могут находиться за его пределами.
Чтобы установить параметр ограничения местоположения, вызовите метод
setLocationRestriction()
при построении объектаSearchByTextRequest
.Максимальное количество результатов
Указывает максимальное количество возвращаемых результатов по местам. Должно быть от 1 до 20 (по умолчанию) включительно.
Чтобы установить параметр максимального количества результатов, вызовите метод
setMaxResultCount()
при построении объектаSearchByTextRequest
.Минимальный рейтинг
Ограничивает результаты только теми, чей средний рейтинг пользователей больше или равен этому пределу. Значения должны находиться в диапазоне от 0,0 до 5,0 (включительно) с шагом 0,5. Например: 0, 0,5, 1,0, ..., 5,0 включительно. Значения округляются до ближайших 0,5. Например, значение 0,6 исключает все результаты с рейтингом менее 1,0.
Чтобы установить параметр минимального рейтинга, вызовите метод
setMinRating()
при построении объектаSearchByTextRequest
.Открыть сейчас
Если
true
, возвращать только те места, которые открыты для бизнеса на момент отправки запроса. Еслиfalse
, вернуть все предприятия независимо от их открытого статуса. Места, для которых не указаны часы работы в базе данных Google Адресов, возвращаются, если для этого параметра установлено значениеfalse
.Чтобы установить параметр «Открыть сейчас», вызовите метод
setOpenNow()
при создании объектаSearchByTextRequest
.Уровни цен
По умолчанию результаты включают места, предоставляющие услуги всех ценовых уровней. Чтобы ограничить результаты, включив в них только места с определенным уровнем цен, вы можете передать список целочисленных значений, соответствующих уровням цен для мест, которые вы хотите вернуть:
-
1
– Место предоставляет недорогие услуги. -
2
– Место предоставляет услуги по умеренным ценам. -
3
– Место предоставляет дорогие услуги. -
4
– Место предоставляет очень дорогие услуги.
Чтобы установить параметр уровней цен, вызовите метод
setPriceLevels()
при построении объектаSearchByTextRequest
.-
Предпочтение ранга
Указывает, как результаты ранжируются в ответе в зависимости от типа запроса:
- Для категориального запроса, такого как «Рестораны в Нью-Йорке», по умолчанию используется
SearchByTextRequest.RankPreference.RELEVANCE
(ранжирование результатов по релевантности поиска). Вы можете установить предпочтение рангаSearchByTextRequest.RankPreference.RELEVANCE
илиSearchByTextRequest.RankPreference.DISTANCE
(ранжировать результаты по расстоянию). - Для некатегорийного запроса, такого как «Маунтин-Вью, Калифорния», мы рекомендуем оставить параметр предпочтения ранга неустановленным.
Чтобы установить параметр предпочтения ранга, вызовите метод
setRankPreference()
при построении объектаSearchByTextRequest
.- Для категориального запроса, такого как «Рестораны в Нью-Йорке», по умолчанию используется
Код региона
Код региона, используемый для форматирования ответа в виде двухсимвольного значения кода CLDR . Этот параметр также может оказывать влияние на результаты поиска. Значения по умолчанию нет.
Если название страны в поле адреса в ответе соответствует коду региона, код страны в адресе опускается.
Большинство кодов CLDR идентичны кодам ISO 3166-1, за некоторыми заметными исключениями. Например, нДВУ Соединенного Королевства — «uk» (.co.uk), а его код ISO 3166-1 — «gb» (технически для организации «Соединенное Королевство Великобритании и Северной Ирландии»). Параметр может повлиять на результаты в соответствии с действующим законодательством.
Чтобы задать параметр кода региона, вызовите метод
setRegionCode()
при построении объектаSearchByTextRequest
.Строгая фильтрация типов
Используется с параметром типа включения. Если установлено значение
true
, возвращаются только места, соответствующие указанным типам, заданным типом включения. Еслиfalse
, значение по умолчанию, ответ может содержать места, не соответствующие указанным типам.Чтобы установить параметр фильтрации строгого типа, вызовите метод
setStrictTypeFiltering()
при построении объектаSearchByTextRequest
.
Текстовый поиск (новое) возвращает информацию о наборе мест на основе строки — например, «пицца в Нью-Йорке», «обувные магазины недалеко от Оттавы» или «Мейн-стрит, 123». Служба отвечает списком мест, соответствующих текстовой строке, и любым установленным смещениям местоположения.
Эта служба особенно полезна для выполнения неоднозначных адресных запросов в автоматизированной системе, поскольку неадресные компоненты строки могут соответствовать как предприятиям, так и адресам. Примерами неоднозначных адресных запросов являются плохо отформатированные адреса или запросы, которые включают неадресные компоненты, такие как названия компаний. Запросы, подобные первым двум примерам, могут возвращать нулевые результаты, если не установлено местоположение, например регион, ограничение местоположения или смещение местоположения.
Текстовый поиск (новое) аналогичен поиску поблизости (новое) . Основное различие между ними заключается в том, что текстовый поиск (новый) позволяет указать произвольную строку поиска, а поиск поблизости (новый) требует определенной области для поиска.
«10 High Street, Великобритания» или «123 Main Street, США». | Несколько «Хай-стрит» в Великобритании; несколько «Мейн-стрит» в США. Запрос не возвращает желаемых результатов, если не установлено ограничение местоположения. |
«Сеть ресторанов Нью-Йорк» | Несколько ресторанов ChainRestaurant в Нью-Йорке; ни адреса, ни даже названия улицы. |
«10 High Street, Escher UK» или «123 Main Street, Pleasanton US» | Единственная «Хай-стрит» в британском городе Эшер; только одна «Мейн-стрит» в американском городе Плезантон, Калифорния. |
«UniqueRestaurantName Нью-Йорк» | В Нью-Йорке только одно заведение с таким названием; никакой адрес не нужен для различения. |
"пиццерии в Нью-Йорке" | Этот запрос содержит ограничение по местоположению, а «рестораны-пиццерии» – это четко определенный тип места. Он возвращает несколько результатов. |
"+1 514-670-8700" | Этот запрос содержит номер телефона. Он возвращает несколько результатов для мест, связанных с этим номером телефона. |
Запросы текстового поиска
Запрос текстового поиска имеет форму:
// Specify the list of fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME); // Define latitude and longitude coordinates of the search area. LatLng southWest = new LatLng(37.38816277477739, -122.08813770258874); LatLng northEast = new LatLng(37.39580487866437, -122.07702325966572); // Use the builder to create a SearchByTextRequest object. final SearchByTextRequest searchByTextRequest = SearchByTextRequest.builder("Spicy Vegetarian Food", placeFields) .setMaxResultCount(10) .setLocationRestriction(RectangularBounds.newInstance(southWest, northEast)).build(); // Call PlacesClient.searchByText() to perform the search. // Define a response handler to process the returned List of Place objects. placesClient.searchByText(searchByTextRequest) .addOnSuccessListener(response -> { List<Place> places = response.getPlaces(); });
В этом примере вы:
Настройте список полей, включив в него только
Place.Field.ID
иPlace.Field.DISPLAY_NAME
. Это означает, что объектыPlace
в ответе, представляющие каждое совпадающее место, содержат только эти два поля.Используйте
SearchByTextRequest.Builder
, чтобы создать объектSearchByTextRequest
, определяющий поиск.Установите текстовую строку запроса «Острая вегетарианская еда».
Установите максимальное количество мест в результате равным 10. Значение по умолчанию и максимальное значение — 20.
Ограничьте область поиска прямоугольником, определяемым координатами широты и долготы. Никакие совпадения за пределами этой области не возвращаются.
Добавьте
OnSuccessListener
и получите соответствующие места из объектаSearchByTextResponse
.
Ответы на текстовый поиск
Класс SearchByTextResponse
представляет ответ на поисковый запрос. Объект SearchByTextResponse
содержит:
Список объектов
Place
, представляющих все подходящие места, по одному объектуPlace
на каждое подходящее место.Каждый объект
Place
содержит только поля, определенные списком полей, переданным в запросе.
Например, в запросе вы определили список полей как:
// Specify the list of fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME);
Этот список полей означает, что каждый объект Place
в ответе содержит только идентификатор места и название каждого соответствующего места. Затем вы можете использовать методы Place.getId()
и Place.getName()
для доступа к этим полям в каждом объекте Place
.
Дополнительные примеры доступа к данным в объекте Place
см. в разделе Доступ к полям данных объекта Place.
Обязательные параметры
Обязательные параметры для SearchByTextRequest
:
Список полей
Укажите, какие поля данных места нужно вернуть. Передайте список значений
Place.Field
определяющих возвращаемые поля данных. В ответе нет списка возвращаемых полей по умолчанию.Списки полей — это хорошая практика проектирования, позволяющая избежать запроса ненужных данных, что помогает избежать ненужного времени обработки и расходов по счетам.
Укажите одно или несколько из следующих полей:
Следующие поля активируют SKU текстового поиска (только идентификатор) :
Place.Field.DISPLAY_NAME
,Place.Field.ID
,Place.Field.RESOURCE_NAME
Следующие поля активируют SKU текстового поиска (базовый) :
Place.Field.ACCESSIBILITY_OPTIONS
,Place.Field.ADDRESS_COMPONENTS
,Place.Field.ADR_FORMAT_ADDRESS
,Place.Field.BUSINESS_STATUS
,Place.Field.FORMATTED_ADDRESS
,Place.Field.GOOGLE_MAPS_URI
,Place.Field.ICON_BACKGROUND_COLOR
,Place.Field.ICON_MASK_URL
,Place.Field.LOCATION
,Place.Field.PHOTO_METADATAS
,Place.Field.PLUS_CODE
,Place.Field.PRIMARY_TYPE_DISPLAY_NAME
,Place.Field.SHORT_FORMATTED_ADDRESS
,Place.Field.SUB_DESTINATIONS
,Place.Field.TYPES
,Place.Field.UTC_OFFSET
,Place.Field.VIEWPORT
Следующие поля активируют SKU текстового поиска (расширенный) :
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
. SECONDARY_OPENING_HOURS ,Place.Field.USER_RATING_COUNT
Place.Field.WEBSITE_URI
Следующие поля активируют SKU текстового поиска (предпочтительный) :
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
d.SERVES_DINNER ,Place.Field.SERVES_LUNCH
,Place.Field.SERVES_VEGETARIAN_FOOD
,Place.Field.SERVES_WINE
,Place.Field.TAKEOUT
Чтобы задать параметр списка полей, вызовите метод
setPlaceFields()
при построении объектаSearchByTextRequest
.Текстовый запрос
Текстовая строка для поиска, например: «ресторан», «123 Main Street» или «лучшее место для посещения в Сан-Франциско». API возвращает совпадения кандидатов на основе этой строки и упорядочивает результаты на основе их предполагаемой релевантности.
Чтобы задать параметр текстового запроса, вызовите метод
setTextQuery()
при построении объектаSearchByTextRequest
.
Дополнительные параметры
Используйте объект SearchByTextRequest
, чтобы указать необязательные параметры вашего запроса.
Включенный тип
Ограничивает результаты местами, соответствующими указанному типу, определенному в таблице A. Можно указать только один тип. Например:
-
setIncludedType("bar")
-
setIncludedType("pharmacy")
Чтобы установить параметр включенного типа, вызовите метод
setIncludedType()
при построении объектаSearchByTextRequest
.-
Предвзятость местоположения
Указывает область для поиска. Это местоположение служит смещением, что означает, что могут быть возвращены результаты вокруг указанного местоположения, включая результаты за пределами указанной области.
Вы можете указать ограничение местоположения или смещение местоположения, но не то и другое. Подумайте об ограничении местоположения как об указании региона, в котором должны находиться результаты, а о смещении местоположения как об указании региона, рядом с которым результаты должны находиться, но могут находиться за его пределами.
Укажите область в виде прямоугольного видового экрана или круга.
Круг определяется центральной точкой и радиусом в метрах. Радиус должен находиться в диапазоне от 0,0 до 50000,0 включительно. Например:
// Define latitude and longitude coordinates of the center of the search area. LatLng searchCenter = new LatLng(37.38816277477739, -122.08813770258874); // Use the builder to create a SearchByTextRequest object. // Set the radius of the search area to 500.0 meters. final SearchByTextRequest searchByTextRequest = SearchByTextRequest.builder("Spicy Vegetarian Food", placeFields) .setMaxResultCount(10) .setLocationBias(CircularBounds.newInstance(searchCenter, 500.0)).build();
Прямоугольник — это окно просмотра широты и долготы, представленное в виде двух диагонально противоположных нижней и верхней точек. Нижняя точка обозначает юго-западный угол прямоугольника, а верхняя точка представляет собой северо-восточный угол прямоугольника.
Область просмотра считается закрытой областью, то есть включает в себя ее границу. Границы широты должны находиться в диапазоне от -90 до 90 градусов включительно, а границы долготы должны находиться в диапазоне от -180 до 180 градусов включительно:
- Если
low
=high
, область просмотра состоит из этой единственной точки. - Если
low.longitude
>high.longitude
, диапазон долготы инвертируется (окно просмотра пересекает линию долготы в 180 градусов). - Если
low.longitude
= -180 градусов иhigh.longitude
= 180 градусов, область просмотра включает все значения долготы. - Если
low.longitude
= 180 градусов иhigh.longitude
= -180 градусов, диапазон долготы пуст. - Если
low.latitude
>high.latitude
, диапазон широт пуст.
Оба значения low и high должны быть заполнены, а представленное поле не может быть пустым. Пустое окно просмотра приводит к ошибке.
Например, о прямоугольном окне просмотра см. Запросы текстового поиска .
Чтобы установить параметр смещения местоположения, вызовите метод
setLocationBias()
при построении объектаSearchByTextRequest
.- Если
Ограничение местоположения
Указывает область для поиска. Результаты за пределами указанной области не возвращаются. Укажите регион в виде прямоугольного видового экрана. См. описание смещения местоположения для получения информации об определении области просмотра.
Вы можете указать ограничение местоположения или смещение местоположения, но не то и другое. Подумайте об ограничении местоположения как об указании региона, в котором должны находиться результаты, а о смещении местоположения как об указании региона, в котором результаты должны находиться рядом, но могут находиться за его пределами.
Чтобы установить параметр ограничения местоположения, вызовите метод
setLocationRestriction()
при построении объектаSearchByTextRequest
.Максимальное количество результатов
Указывает максимальное количество возвращаемых результатов размещения. Должно быть от 1 до 20 (по умолчанию) включительно.
Чтобы установить параметр максимального количества результатов, вызовите метод
setMaxResultCount()
при построении объектаSearchByTextRequest
.Минимальный рейтинг
Ограничивает результаты только теми, чей средний рейтинг пользователей больше или равен этому пределу. Значения должны находиться в диапазоне от 0,0 до 5,0 (включительно) с шагом 0,5. Например: 0, 0,5, 1,0, ..., 5,0 включительно. Значения округляются до ближайших 0,5. Например, значение 0,6 исключает все результаты с рейтингом менее 1,0.
Чтобы установить параметр минимального рейтинга, вызовите метод
setMinRating()
при построении объектаSearchByTextRequest
.Открыть сейчас
Если
true
, возвращать только те места, которые открыты для бизнеса на момент отправки запроса. Еслиfalse
, вернуть все предприятия независимо от их открытого статуса. Места, для которых не указаны часы работы в базе данных Google Адресов, возвращаются, если для этого параметра установлено значениеfalse
.Чтобы установить параметр «Открыть сейчас», вызовите метод
setOpenNow()
при создании объектаSearchByTextRequest
.Уровни цен
По умолчанию результаты включают места, предоставляющие услуги всех ценовых уровней. Чтобы ограничить результаты, включив в них только места с определенным уровнем цен, вы можете передать список целочисленных значений, соответствующих уровням цен для мест, которые вы хотите вернуть:
-
1
– Место предоставляет недорогие услуги. -
2
– Место предоставляет услуги по умеренным ценам. -
3
– Место предоставляет дорогие услуги. -
4
– Место предоставляет очень дорогие услуги.
Чтобы установить параметр уровней цен, вызовите метод
setPriceLevels()
при построении объектаSearchByTextRequest
.-
Предпочтение ранга
Указывает, как результаты ранжируются в ответе в зависимости от типа запроса:
- Для категориального запроса, такого как «Рестораны в Нью-Йорке», по умолчанию используется
SearchByTextRequest.RankPreference.RELEVANCE
(ранжирование результатов по релевантности поиска). Вы можете установить предпочтение рангаSearchByTextRequest.RankPreference.RELEVANCE
илиSearchByTextRequest.RankPreference.DISTANCE
(ранжировать результаты по расстоянию). - Для некатегорийного запроса, такого как «Маунтин-Вью, Калифорния», мы рекомендуем оставить параметр предпочтения ранга неустановленным.
Чтобы установить параметр предпочтения ранга, вызовите метод
setRankPreference()
при построении объектаSearchByTextRequest
.- Для категориального запроса, такого как «Рестораны в Нью-Йорке», по умолчанию используется
Код региона
Код региона, используемый для форматирования ответа в виде двухсимвольного значения кода CLDR . Этот параметр также может оказывать влияние на результаты поиска. Значения по умолчанию нет.
Если название страны в поле адреса в ответе соответствует коду региона, код страны в адресе опускается.
Большинство кодов CLDR идентичны кодам ISO 3166-1, за некоторыми заметными исключениями. Например, нДВУ Соединенного Королевства — «uk» (.co.uk), а его код ISO 3166-1 — «gb» (технически для организации «Соединенное Королевство Великобритании и Северной Ирландии»). Параметр может повлиять на результаты в соответствии с действующим законодательством.
Чтобы задать параметр кода региона, вызовите метод
setRegionCode()
при построении объектаSearchByTextRequest
.Строгая фильтрация типов
Используется с параметром типа включения. Если установлено значение
true
, возвращаются только места, соответствующие указанным типам, заданным типом включения. Еслиfalse
, значение по умолчанию, ответ может содержать места, не соответствующие указанным типам.Чтобы установить параметр фильтрации строгого типа, вызовите метод
setStrictTypeFiltering()
при построении объектаSearchByTextRequest
.
Текстовый поиск (новое) возвращает информацию о наборе мест на основе строки — например, «пицца в Нью-Йорке», «обувные магазины недалеко от Оттавы» или «Мейн-стрит, 123». Служба отвечает списком мест, соответствующих текстовой строке, и любым установленным смещениям местоположения.
Эта служба особенно полезна для выполнения неоднозначных адресных запросов в автоматизированной системе, поскольку неадресные компоненты строки могут соответствовать как предприятиям, так и адресам. Примерами неоднозначных адресных запросов являются плохо отформатированные адреса или запросы, которые включают неадресные компоненты, такие как названия компаний. Запросы, подобные первым двум примерам, могут возвращать нулевые результаты, если не установлено местоположение, например регион, ограничение местоположения или смещение местоположения.
Текстовый поиск (новое) аналогичен поиску поблизости (новое) . Основное различие между ними заключается в том, что текстовый поиск (новый) позволяет указать произвольную строку поиска, а поиск поблизости (новый) требует определенной области для поиска.
«10 High Street, Великобритания» или «123 Main Street, США». | Несколько «Хай-стрит» в Великобритании; несколько «Мейн-стрит» в США. Запрос не возвращает желаемых результатов, если не установлено ограничение местоположения. |
«Сеть ресторанов Нью-Йорк» | Несколько ресторанов «ChainRestaurant» в Нью-Йорке; ни адреса, ни даже названия улицы. |
«10 High Street, Escher UK» или «123 Main Street, Pleasanton US» | Единственная «Хай-стрит» в британском городе Эшер; только одна «Мейн-стрит» в американском городе Плезантон, Калифорния. |
«UniqueRestaurantName Нью-Йорк» | В Нью-Йорке только одно заведение с таким названием; никакой адрес не нужен для различения. |
"пиццерии в Нью-Йорке" | Этот запрос содержит ограничение по местоположению, а «рестораны-пиццерии» – это четко определенный тип места. Он возвращает несколько результатов. |
"+1 514-670-8700" | Этот запрос содержит номер телефона. Он возвращает несколько результатов для мест, связанных с этим номером телефона. |
Запросы на текстовый поиск
Запрос на текстовый поиск находится в форме:
// Specify the list of fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME); // Define latitude and longitude coordinates of the search area. LatLng southWest = new LatLng(37.38816277477739, -122.08813770258874); LatLng northEast = new LatLng(37.39580487866437, -122.07702325966572); // Use the builder to create a SearchByTextRequest object. final SearchByTextRequest searchByTextRequest = SearchByTextRequest.builder("Spicy Vegetarian Food", placeFields) .setMaxResultCount(10) .setLocationRestriction(RectangularBounds.newInstance(southWest, northEast)).build(); // Call PlacesClient.searchByText() to perform the search. // Define a response handler to process the returned List of Place objects. placesClient.searchByText(searchByTextRequest) .addOnSuccessListener(response -> { List<Place> places = response.getPlaces(); });
В этом примере вы:
Установите список поля, чтобы включить только
Place.Field.ID
иPlace.Field.DISPLAY_NAME
. Это означает, чтоPlace
объекта в ответе, представляющее каждое место сопоставления, содержат только эти две поля.Используйте
SearchByTextRequest.Builder
для создания объектаSearchByTextRequest
, который определяет поиск.Установите строку текстового запроса на «острую вегетарианскую еду».
Установите максимальное количество мест результата на 10. По умолчанию и максимум - 20.
Ограничьте область поиска прямоугольником, определяемым координатами широты и долготы. Никакие матчи за пределами этой области не возвращаются.
Добавьте
OnSuccessListener
и получите подходящие места из объектаSearchByTextResponse
.
Ответы на текстовый поиск
Класс SearchByTextResponse
представляет ответ из запроса поиска. Объект SearchByTextResponse
содержит:
Список объектов
Place
, которые представляют все соответствующие места, с одним объектомPlace
на подходящее место.Каждый объект
Place
содержит только поля, определенные в списке поле, передаваемых в запросе.
Например, в запросе вы определили список полевых вещей как:
// Specify the list of fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME);
Этот список поля означает, что каждое объект Place
в ответе содержит только идентификатор места и имя каждого подходящего места. Затем вы можете использовать методы Place.getId()
и Place.getName()
для доступа к этим полям в каждом объекте Place
.
Для получения дополнительных примеров доступа к данным в объекте Place
см. Поля данных Access Place.
Обязательные параметры
Требуемые параметры для SearchByTextRequest
являются:
Полевой список
Укажите, какие поля данных поместите поля данных для возврата. Передайте список значений
Place.Field
указанные поля данных для возврата. В ответе нет списка возвращаемых полей по умолчанию.Полевые списки являются хорошей практикой дизайна, чтобы гарантировать, что вы не запросите ненужные данные, что помогает избежать ненужного времени обработки и платежных платежей.
Укажите одно или несколько из следующих полей:
Следующие поля запускают текстовый поиск (только идентификатор) SKU :
Place.Field.DISPLAY_NAME
,Place.Field.ID
,Place.Field.RESOURCE_NAME
Следующие поля запускают текстовый поиск (базовый) SKU :
Place.Field.ACCESSIBILITY_OPTIONS
,Place.Field.ADDRESS_COMPONENTS
,Place.Field.ADR_FORMAT_ADDRESS
,Place.Field.BUSINESS_STATUS
,Place.Field.GOOGLE_MAPS_URI
, place.icon_mask_url,Place.Field.ICON_MASK_URL
, place.icon_mask_url,Place.Field.ICON_BACKGROUND_COLOR
,Place.Field.FORMATTED_ADDRESS
Place.Field.LOCATION
,Place.Field.PHOTO_METADATAS
,Place.Field.PLUS_CODE
,Place.Field.PRIMARY_TYPE_DISPLAY_NAME
,Place.Field.SHORT_FORMATTED_ADDRESS
,Place.Field.SUB_DESTINATIONS
,Place.Field.TYPES
,Place.Field.UTC_OFFSET
,Place.Field.VIEWPORT
Следующие поля запускают текстовый поиск (расширенный) SKU :
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.rating,Place.Field.PRICE_LEVEL
,Place.Field.RATING
,Place.Field.SECONDARY_OPENING_HOURS
, place.field.ration.rating,Place.Field.USER_RATING_COUNT
Place.Field.WEBSITE_URI
Следующие поля запускают текстовый поиск (предпочтительный) SKU :
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.SERVES_DESSERT
Place.Field.REVIEWS
,Place.Field.SERVES_BEER
,Place.Field.SERVES_BREAKFAST
,Place.Field.SERVES_COFFEE
Place.Field.SERVES_DINNER
Place.Field.SERVES_BRUNCH
,Place.Field.SERVES_COCKTAILS
Place.Field.SERVES_LUNCH
,Place.Field.SERVES_VEGETARIAN_FOOD
,Place.Field.SERVES_WINE
,Place.Field.TAKEOUT
Чтобы установить параметр списка поля, вызовите метод
setPlaceFields()
при создании объектаSearchByTextRequest
.Текстовый запрос
Текстовая строка, на которой можно найти, например: «Ресторан», «123 Main Street» или «Лучшее место для посещения в Сан -Франциско». API возвращает соответствия кандидата на основе этой строки и заказывает результаты на основе их предполагаемой актуальности.
Чтобы установить параметр текстового запроса, вызовите метод
setTextQuery()
при создании объектаSearchByTextRequest
.
Дополнительные параметры
Используйте объект SearchByTextRequest
, чтобы указать необязательные параметры для вашего запроса.
Включен тип
Ограничивает результаты местами, соответствующими указанному типу, определяемому таблицей A. Может быть указан только один тип. Например:
-
setIncludedType("bar")
-
setIncludedType("pharmacy")
Чтобы установить включенный параметр типа, вызовите метод
setIncludedType()
при создании объектаSearchByTextRequest
.-
Расположение смещение
Указывает область для поиска. Это место служит смещением, что означает, что результаты вокруг указанного места могут быть возвращены, включая результаты за пределами указанной области.
Вы можете указать ограничение местоположения или смещение местоположения, но не оба. Подумайте об ограничении местоположения как о указании области, в которой должны быть результаты, и смещение местоположения как указание области, в которой результаты должны быть близки, но могут быть за пределами области.
Укажите область как прямоугольный просмотр или круг.
Круг определяется центральной точкой и радиусом в метрах. Радиус должен быть от 0,0 до 50000,0, включительно. Например:
// Define latitude and longitude coordinates of the center of the search area. LatLng searchCenter = new LatLng(37.38816277477739, -122.08813770258874); // Use the builder to create a SearchByTextRequest object. // Set the radius of the search area to 500.0 meters. final SearchByTextRequest searchByTextRequest = SearchByTextRequest.builder("Spicy Vegetarian Food", placeFields) .setMaxResultCount(10) .setLocationBias(CircularBounds.newInstance(searchCenter, 500.0)).build();
Прямоугольник представляет собой широту длительного просмотра, представленный как два диагонали напротив низких и высоких точек. Низкая точка отмечает юго -западный угол прямоугольника, а высокая точка представляет северо -восточный угол прямоугольника.
Viewport считается закрытой областью, что означает, что он включает в себя свою границу. Границы широты должны варьироваться от -90 до 90 градусов включено, а границы долготы должны варьироваться от -180 до 180 градусов включено:
- Если
low
=high
, область просмотра состоит из этой единственной точки. - Если
low.longitude
>high.longitude
, диапазон долготы инвертируется (окно просмотра пересекает линию долготы в 180 градусов). - Если
low.longitude
= -180 градусов иhigh.longitude
= 180 градусов, область просмотра включает все значения долготы. - Если
low.longitude
= 180 градусов иhigh.longitude
= -180 градусов, диапазон долготы пуст. - Если
low.latitude
>high.latitude
, диапазон широт пуст.
Как низкий, так и высокий, должен быть заполнен, а представленная коробка не может быть пустой. Пустой просмотр приводит к ошибке.
Например, прямоугольного просмотра см. Запросы на текстовый поиск .
Чтобы установить параметр смещения местоположения, вызовите метод
setLocationBias()
при создании объектаSearchByTextRequest
.- Если
Ограничение местоположения
Указывает область для поиска. Результаты за пределами указанной области не возвращаются. Укажите область как прямоугольный просмотр. См. Описание смещения местоположения для получения информации о определении просмотра.
Вы можете указать ограничение местоположения или смещение местоположения, но не оба. Подумайте об ограничении местоположения как о указании области, в которой должны быть результаты, и смещение местоположения как указание области, в которой результаты должны быть близки, но могут быть за пределами области.
Чтобы установить параметр ограничения местоположения, вызовите метод
setLocationRestriction()
при создании объектаSearchByTextRequest
.Максимальное количество результатов
Указывает максимальное количество результатов места для возврата. Должен быть от 1 до 20 (по умолчанию) включительно.
Чтобы установить параметр максимального количества результатов, вызовите метод
setMaxResultCount()
при создании объектаSearchByTextRequest
.Минимальный рейтинг
Ограничивает результаты только теми, чьи средний пользовательский рейтинг больше или равен этому пределу. Значения должны быть от 0,0 до 5,0 (включительно) с шагом 0,5. Например: 0, 0,5, 1,0, ..., 5,0 включительно. Значения окружаются до ближайшего 0,5. Например, значение 0,6 устраняет все результаты с рейтингом менее 1,0.
Чтобы установить минимальный параметр рейтинга, вызовите метод
setMinRating()
при создании объектаSearchByTextRequest
.Открыть сейчас
Если
true
, верните только те места, которые открыты для бизнеса в то время, когда запрос отправлен. Еслиfalse
, верните все предприятия независимо от открытого статуса. Места, в которых не указываются часы работы в базе данных Google Place, возвращаются, если вы установите этот параметр вfalse
.Чтобы установить параметр Open Now, вызовите метод
setOpenNow()
при создании объектаSearchByTextRequest
.Цены уровней
По умолчанию результаты включают места, которые предоставляют услуги на всех уровнях цен. Чтобы ограничить результаты, включать только места на определенных уровнях цен, вы можете пройти список целочисленных значений, которые соответствуют уровням цен для мест, которые вы хотите вернуть:
-
1
- Место предоставляет недорогие услуги. -
2
- Place предоставляет услуги по умеренной цене. -
3
- Place предоставляет дорогие услуги. -
4
- Place предоставляет очень дорогие услуги.
Чтобы установить параметр уровней цен, вызовите метод
setPriceLevels()
при создании объектаSearchByTextRequest
.-
Ранга предпочтения
Указывает, как результаты ранжируются в ответ на основе типа запроса:
- Для категориального запроса, такого как «рестораны в Нью -Йорке»,
SearchByTextRequest.RankPreference.RELEVANCE
(Результаты ранга по релевантности поиска) - это дефолт. Вы можете установить предпочтения ранга наSearchByTextRequest.RankPreference.RELEVANCE
илиSearchByTextRequest.RankPreference.DISTANCE
(результаты ранга по расстоянию). - Для некатегорического запроса, такого как «Mountain View, CA», мы рекомендуем вам оставить параметр предпочтения ранга.
Чтобы установить параметр предпочтения ранга, вызовите метод
setRankPreference()
при создании объектаSearchByTextRequest
.- Для категориального запроса, такого как «рестораны в Нью -Йорке»,
Регион код
Код региона, используемый для форматирования ответа, указанный как двуххарактерное значение CLDR . Этот параметр также может иметь эффект смещения на результаты поиска. Там нет значения по умолчанию.
Если название страны поля адреса в ответе соответствует коду региона, код страны опущен по адресу.
Большинство кодов CLDR идентичны кодам ISO 3166-1, за некоторыми заметными исключениями. Например, CCTLD в Великобритании-«Великобритания» (.co.uk), в то время как его ISO 3166-1-«ГБ» (технически для сущности «Соединенное Королевство Великобритании и Северная Ирландия»). Параметр может повлиять на результаты на основе применимого закона.
Чтобы установить параметр кода региона, вызовите метод
setRegionCode()
при создании объектаSearchByTextRequest
.Строгий тип фильтрации
Используется с параметром включения типа. При установке
true
, возвращаются только места, которые соответствуют указанным типам, указанным в соответствии с типом. Приfalse
, по умолчанию, ответ может содержать места, которые не соответствуют указанным типам.Чтобы установить параметр фильтрации строгих типов, вызовите метод
setStrictTypeFiltering()
при создании объектаSearchByTextRequest
.
Поиск текста (новый) возвращает информацию о наборе мест на основе строки - например, «Пицца в Нью -Йорке» или «Обу обувные магазины возле Оттавы» или «123 Main Street». Служба отвечает списком мест, соответствующих текстовой строке, и любым предвзятости местоположения, которое было установлено.
Служба особенно полезна для неоднозначных запросов адресов в автоматизированной системе, а компоненты неадресса строки могут соответствовать предприятиям, а также адресам. Примерами неоднозначных запросов адресов являются плохо форматированные адреса или запросы, которые включают компоненты без адапта, такие как названия бизнеса. Подобные запросы, такие как первые два примера, могут вернуть нулевые результаты, если не будет установлено местоположение, такое как регион, ограничение местоположения или смещение местоположения.
Текстовый поиск (новый) похож на ближайший поиск (новый) . Основное различие между ними заключается в том, что текстовый поиск (новый) позволяет вам указать произвольную строку поиска, в то время как близлежащий поиск (новый) требует определенной области для поиска.
"10 High Street, UK" или "123 Main Street, США" | Несколько "Хай -стрит" в Великобритании; Несколько "Main Street" в США. Запрос не возвращает желательные результаты, если не установлено ограничение местоположения. |
"CheanRestaurant New York" | Многочисленные «цепные» местоположения в Нью -Йорке; нет уличного адреса или даже названия улицы. |
"10 High Street, Escher UK" или "123 Main Street, Pleasanton US" | Только одна «главная улица» в британском городе Эшер; Только одна "главная улица" в городе США Плезантон, Калифорния. |
"UniquerestaurantName New York" | Только одно учреждение с этим именем в Нью -Йорке; Уличный адрес не требуется для дифференциации. |
"Пицца рестораны в Нью -Йорке" | Этот запрос содержит ограничение местоположения, а «рестораны пиццы»-четко определенный тип места. Он возвращает несколько результатов. |
"+1 514-670-8700" | Этот запрос содержит номер телефона. Он возвращает несколько результатов для мест, связанных с этим номером телефона. |
Запросы на текстовый поиск
Запрос на текстовый поиск находится в форме:
// Specify the list of fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME); // Define latitude and longitude coordinates of the search area. LatLng southWest = new LatLng(37.38816277477739, -122.08813770258874); LatLng northEast = new LatLng(37.39580487866437, -122.07702325966572); // Use the builder to create a SearchByTextRequest object. final SearchByTextRequest searchByTextRequest = SearchByTextRequest.builder("Spicy Vegetarian Food", placeFields) .setMaxResultCount(10) .setLocationRestriction(RectangularBounds.newInstance(southWest, northEast)).build(); // Call PlacesClient.searchByText() to perform the search. // Define a response handler to process the returned List of Place objects. placesClient.searchByText(searchByTextRequest) .addOnSuccessListener(response -> { List<Place> places = response.getPlaces(); });
В этом примере вы:
Установите список поля, чтобы включить только
Place.Field.ID
иPlace.Field.DISPLAY_NAME
. Это означает, чтоPlace
объекта в ответе, представляющее каждое место сопоставления, содержат только эти две поля.Используйте
SearchByTextRequest.Builder
для создания объектаSearchByTextRequest
, который определяет поиск.Установите строку текстового запроса на «острую вегетарианскую еду».
Установите максимальное количество мест результата на 10. По умолчанию и максимум - 20.
Ограничьте область поиска прямоугольником, определяемым координатами широты и долготы. Никакие матчи за пределами этой области не возвращаются.
Добавьте
OnSuccessListener
и получите подходящие места из объектаSearchByTextResponse
.
Ответы на текстовый поиск
Класс SearchByTextResponse
представляет ответ из запроса поиска. Объект SearchByTextResponse
содержит:
Список объектов
Place
, которые представляют все соответствующие места, с одним объектомPlace
на подходящее место.Каждый объект
Place
содержит только поля, определенные в списке поле, передаваемых в запросе.
Например, в запросе вы определили список полевых вещей как:
// Specify the list of fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME);
Этот список поля означает, что каждое объект Place
в ответе содержит только идентификатор места и имя каждого подходящего места. Затем вы можете использовать методы Place.getId()
и Place.getName()
для доступа к этим полям в каждом объекте Place
.
Для получения дополнительных примеров доступа к данным в объекте Place
см. Поля данных Access Place.
Обязательные параметры
Требуемые параметры для SearchByTextRequest
являются:
Полевой список
Укажите, какие поля данных поместите поля данных для возврата. Передайте список значений
Place.Field
указанные поля данных для возврата. В ответе нет списка возвращаемых полей по умолчанию.Полевые списки являются хорошей практикой дизайна, чтобы гарантировать, что вы не запросите ненужные данные, что помогает избежать ненужного времени обработки и платежных платежей.
Укажите одно или несколько из следующих полей:
Следующие поля запускают текстовый поиск (только идентификатор) SKU :
Place.Field.DISPLAY_NAME
,Place.Field.ID
,Place.Field.RESOURCE_NAME
Следующие поля запускают текстовый поиск (базовый) SKU :
Place.Field.ACCESSIBILITY_OPTIONS
,Place.Field.ADDRESS_COMPONENTS
,Place.Field.ADR_FORMAT_ADDRESS
,Place.Field.BUSINESS_STATUS
,Place.Field.GOOGLE_MAPS_URI
, place.icon_mask_url,Place.Field.ICON_MASK_URL
, place.icon_mask_url,Place.Field.ICON_BACKGROUND_COLOR
,Place.Field.FORMATTED_ADDRESS
Place.Field.LOCATION
,Place.Field.PHOTO_METADATAS
,Place.Field.PLUS_CODE
,Place.Field.PRIMARY_TYPE_DISPLAY_NAME
,Place.Field.SHORT_FORMATTED_ADDRESS
,Place.Field.SUB_DESTINATIONS
,Place.Field.TYPES
,Place.Field.UTC_OFFSET
,Place.Field.VIEWPORT
Следующие поля запускают текстовый поиск (расширенный) SKU :
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.rating,Place.Field.PRICE_LEVEL
,Place.Field.RATING
,Place.Field.SECONDARY_OPENING_HOURS
, place.field.ration.rating,Place.Field.USER_RATING_COUNT
Place.Field.WEBSITE_URI
Следующие поля запускают текстовый поиск (предпочтительный) SKU :
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.SERVES_DESSERT
Place.Field.REVIEWS
,Place.Field.SERVES_BEER
,Place.Field.SERVES_BREAKFAST
,Place.Field.SERVES_COFFEE
Place.Field.SERVES_DINNER
Place.Field.SERVES_BRUNCH
,Place.Field.SERVES_COCKTAILS
Place.Field.SERVES_LUNCH
,Place.Field.SERVES_VEGETARIAN_FOOD
,Place.Field.SERVES_WINE
,Place.Field.TAKEOUT
Чтобы установить параметр списка поля, вызовите метод
setPlaceFields()
при создании объектаSearchByTextRequest
.Текстовый запрос
Текстовая строка, на которой можно найти, например: «Ресторан», «123 Main Street» или «Лучшее место для посещения в Сан -Франциско». API возвращает соответствия кандидата на основе этой строки и заказывает результаты на основе их предполагаемой актуальности.
Чтобы установить параметр текстового запроса, вызовите метод
setTextQuery()
при создании объектаSearchByTextRequest
.
Дополнительные параметры
Используйте объект SearchByTextRequest
, чтобы указать необязательные параметры для вашего запроса.
Включен тип
Ограничивает результаты местами, соответствующими указанному типу, определяемому таблицей A. Может быть указан только один тип. Например:
-
setIncludedType("bar")
-
setIncludedType("pharmacy")
Чтобы установить включенный параметр типа, вызовите метод
setIncludedType()
при создании объектаSearchByTextRequest
.-
Расположение смещение
Указывает область для поиска. Это место служит смещением, что означает, что результаты вокруг указанного места могут быть возвращены, включая результаты за пределами указанной области.
Вы можете указать ограничение местоположения или смещение местоположения, но не оба. Подумайте об ограничении местоположения как о указании области, в которой должны быть результаты, и смещение местоположения как указание области, в которой результаты должны быть близки, но могут быть за пределами области.
Укажите область как прямоугольный просмотр или круг.
Круг определяется центральной точкой и радиусом в метрах. Радиус должен быть от 0,0 до 50000,0, включительно. Например:
// Define latitude and longitude coordinates of the center of the search area. LatLng searchCenter = new LatLng(37.38816277477739, -122.08813770258874); // Use the builder to create a SearchByTextRequest object. // Set the radius of the search area to 500.0 meters. final SearchByTextRequest searchByTextRequest = SearchByTextRequest.builder("Spicy Vegetarian Food", placeFields) .setMaxResultCount(10) .setLocationBias(CircularBounds.newInstance(searchCenter, 500.0)).build();
Прямоугольник представляет собой широту длительного просмотра, представленный как два диагонали напротив низких и высоких точек. Низкая точка отмечает юго -западный угол прямоугольника, а высокая точка представляет северо -восточный угол прямоугольника.
Viewport считается закрытой областью, что означает, что он включает в себя свою границу. Границы широты должны варьироваться от -90 до 90 градусов включено, а границы долготы должны варьироваться от -180 до 180 градусов включено:
- Если
low
=high
, область просмотра состоит из этой единственной точки. - Если
low.longitude
>high.longitude
, диапазон долготы инвертируется (окно просмотра пересекает линию долготы в 180 градусов). - Если
low.longitude
= -180 градусов иhigh.longitude
= 180 градусов, область просмотра включает все значения долготы. - Если
low.longitude
= 180 градусов иhigh.longitude
= -180 градусов, диапазон долготы пуст. - Если
low.latitude
>high.latitude
, диапазон широт пуст.
Как низкий, так и высокий, должен быть заполнен, а представленная коробка не может быть пустой. Пустой просмотр приводит к ошибке.
Например, прямоугольного просмотра см. Запросы на текстовый поиск .
Чтобы установить параметр смещения местоположения, вызовите метод
setLocationBias()
при создании объектаSearchByTextRequest
.- Если
Ограничение местоположения
Указывает область для поиска. Результаты за пределами указанной области не возвращаются. Укажите область как прямоугольный просмотр. См. Описание смещения местоположения для получения информации о определении просмотра.
Вы можете указать ограничение местоположения или смещение местоположения, но не оба. Подумайте об ограничении местоположения как о указании области, в которой должны быть результаты, и смещение местоположения как указание области, в которой результаты должны быть близки, но могут быть за пределами области.
Чтобы установить параметр ограничения местоположения, вызовите метод
setLocationRestriction()
при создании объектаSearchByTextRequest
.Максимальное количество результатов
Указывает максимальное количество результатов места для возврата. Должен быть от 1 до 20 (по умолчанию) включительно.
Чтобы установить параметр максимального количества результатов, вызовите метод
setMaxResultCount()
при создании объектаSearchByTextRequest
.Минимальный рейтинг
Ограничивает результаты только теми, чьи средний пользовательский рейтинг больше или равен этому пределу. Значения должны быть от 0,0 до 5,0 (включительно) с шагом 0,5. Например: 0, 0,5, 1,0, ..., 5,0 включительно. Значения окружаются до ближайшего 0,5. Например, значение 0,6 устраняет все результаты с рейтингом менее 1,0.
Чтобы установить минимальный параметр рейтинга, вызовите метод
setMinRating()
при создании объектаSearchByTextRequest
.Открыть сейчас
Если
true
, верните только те места, которые открыты для бизнеса в то время, когда запрос отправлен. Еслиfalse
, верните все предприятия независимо от открытого статуса. Места, в которых не указываются часы работы в базе данных Google Place, возвращаются, если вы установите этот параметр вfalse
.Чтобы установить параметр Open Now, вызовите метод
setOpenNow()
при создании объектаSearchByTextRequest
.Цены уровней
По умолчанию результаты включают места, которые предоставляют услуги на всех уровнях цен. Чтобы ограничить результаты, включать только места на определенных уровнях цен, вы можете пройти список целочисленных значений, которые соответствуют уровням цен для мест, которые вы хотите вернуть:
-
1
- Место предоставляет недорогие услуги. -
2
- Place предоставляет услуги по умеренной цене. -
3
- Place предоставляет дорогие услуги. -
4
- Place предоставляет очень дорогие услуги.
Чтобы установить параметр уровней цен, вызовите метод
setPriceLevels()
при создании объектаSearchByTextRequest
.-
Ранга предпочтения
Указывает, как результаты ранжируются в ответ на основе типа запроса:
- Для категориального запроса, такого как «рестораны в Нью -Йорке»,
SearchByTextRequest.RankPreference.RELEVANCE
(Результаты ранга по релевантности поиска) - это дефолт. Вы можете установить предпочтения ранга наSearchByTextRequest.RankPreference.RELEVANCE
илиSearchByTextRequest.RankPreference.DISTANCE
(результаты ранга по расстоянию). - Для некатегорического запроса, такого как «Mountain View, CA», мы рекомендуем вам оставить параметр предпочтения ранга.
Чтобы установить параметр предпочтения ранга, вызовите метод
setRankPreference()
при создании объектаSearchByTextRequest
.- Для категориального запроса, такого как «рестораны в Нью -Йорке»,
Регион код
Код региона, используемый для форматирования ответа, указанный как двуххарактерное значение CLDR . Этот параметр также может иметь эффект смещения на результаты поиска. Там нет значения по умолчанию.
Если название страны поля адреса в ответе соответствует коду региона, код страны опущен по адресу.
Большинство кодов CLDR идентичны кодам ISO 3166-1, за некоторыми заметными исключениями. Например, CCTLD в Великобритании-«Великобритания» (.co.uk), в то время как его ISO 3166-1-«ГБ» (технически для сущности «Соединенное Королевство Великобритании и Северная Ирландия»). Параметр может повлиять на результаты на основе применимого закона.
Чтобы установить параметр кода региона, вызовите метод
setRegionCode()
при создании объектаSearchByTextRequest
.Строгий тип фильтрации
Используется с параметром включения типа. При установке
true
, возвращаются только места, которые соответствуют указанным типам, указанным в соответствии с типом. Приfalse
, по умолчанию, ответ может содержать места, которые не соответствуют указанным типам.Чтобы установить параметр фильтрации строгих типов, вызовите метод
setStrictTypeFiltering()
при создании объектаSearchByTextRequest
.