Text Search (nouveau) renvoie des informations sur un ensemble de lieux en fonction d'une chaîne, par exemple "pizza à New York", "magasin de chaussures près d'Ottawa" ou "123 Main Street". Ce service renvoie une liste des lieux correspondant à la chaîne de texte et aux limitations de zone géographique définis.
Ce service est particulièrement utile pour effectuer des requêtes d'adresses ambiguës dans un système automatisé. Les composants non liés à l'adresse de la chaîne peuvent également correspondre à des établissements et à des adresses. Les requêtes d'adresse ambiguës sont, par exemple, les adresses mal formatées ou les demandes qui incluent des composants non liés à l'adresse, comme des noms d'entreprises. Les requêtes comme les deux premiers exemples peuvent renvoyer zéro résultat, sauf si un emplacement (comme une région, une restriction d'emplacement ou un biais d'emplacement) est défini.
Text Search (nouvelle version) est semblable à Nearby Search (nouvelle version). La principale différence entre les deux est que Text Search (nouvelle version) vous permet de spécifier une chaîne de recherche arbitraire, tandis que Nearby Search (nouvelle version) nécessite une zone spécifique dans laquelle effectuer la recherche.
"10 High Street, Royaume-Uni" ou "123 Main Street, États-Unis" | Plusieurs "High Street" au Royaume-Uni, plusieurs "Main Street" aux États-Unis. La requête ne renvoie pas les résultats souhaités, sauf si une restriction géographique est définie. |
"ChainRestaurant New York" | Plusieurs établissements "ChainRestaurant" à New York, sans adresse postale ni nom de rue. |
"10 High Street, Escher UK" ou "123 Main Street, Pleasanton US" | Il n'y a qu'une seule "High Street" dans la ville britannique d'Escher et une seule "Main Street" dans la ville américaine de Pleasanton, en Californie. |
"UniqueRestaurantName New York" | Un seul établissement porte ce nom à New York. Aucune adresse n'est nécessaire pour le différencier. |
"restaurants de pizzas à New York" | Cette requête contient sa restriction d'emplacement et "restaurants de pizzas" est un type de lieu bien défini. Elle renvoie plusieurs résultats. |
"+1 514-670-8700" | Cette requête contient un numéro de téléphone. Elle renvoie plusieurs résultats pour les lieux associés à ce numéro de téléphone. |
Requêtes Text Search
Une requête Text Search se présente comme suit :
// 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(); });
Dans cet exemple, vous :
Définissez la liste des champs de façon à n'inclure que
Place.Field.ID
etPlace.Field.DISPLAY_NAME
. Cela signifie que les objetsPlace
de la réponse qui représentent chaque lieu correspondant ne contiennent que ces deux champs.Utilisez
SearchByTextRequest.Builder
pour créer un objetSearchByTextRequest
qui définit la recherche.Définissez la chaîne de requête textuelle sur "Spicy Vegetarian Food" (Plats végétariens épicés).
Définissez le nombre maximal de lieux de résultats sur 10. La valeur par défaut et maximale est de 20.
Restreignez la zone de recherche au rectangle défini par les coordonnées de latitude et de longitude. Aucune correspondance en dehors de cette zone n'est renvoyée.
Ajoutez un
OnSuccessListener
et obtenez les lieux correspondants à partir de l'objetSearchByTextResponse
.
Réponses Text Search
La classe SearchByTextResponse
représente la réponse à une requête de recherche. Un objet SearchByTextResponse
contient les éléments suivants :
Liste d'objets
Place
représentant tous les lieux correspondants, avec un objetPlace
par lieu correspondant.Chaque objet
Place
ne contient que les champs définis par la liste de champs transmise dans la requête.
Par exemple, dans la requête, vous avez défini une liste de champs comme suit :
// Specify the list of fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME);
Cette liste de champs signifie que chaque objet Place
de la réponse ne contient que l'ID et le nom de chaque lieu correspondant. Vous pouvez ensuite utiliser les méthodes Place.getId()
et Place.getName()
pour accéder à ces champs dans chaque objet Place
.
Pour obtenir d'autres exemples d'accès aux données dans un objet Place
, consultez Accéder aux champs de données de l'objet Place.
Paramètres obligatoires
Les paramètres requis pour SearchByTextRequest
sont les suivants :
-
Liste des champs
Spécifiez les champs de données de lieu à renvoyer. Transmettez une liste de valeurs
Place.Field
spécifiant les champs de données à renvoyer. Il n'existe pas de liste par défaut des champs renvoyés dans la réponse.Les listes de champs sont une bonne pratique à appliquer pour vous assurer de ne pas demander de données inutiles. Vous pourrez ainsi réduire le temps de traitement et les frais facturés.
Spécifiez un ou plusieurs des champs suivants :
Les champs suivants déclenchent le SKU Text Search Essentials ID Only :
Place.Field.DISPLAY_NAME
*
* Utilisez plutôtPlace.Field.NAME
(obsolète dans la version 4.0).
Place.Field.ID
Place.Field.RESOURCE_NAME
*
* Contient le nom de ressource du lieu au formatplaces/PLACE_ID
.
UtilisezDISPLAY_NAME
pour accéder au nom textuel du lieu.Les champs suivants déclenchent le SKU Text Search Pro :
Place.Field.ACCESSIBILITY_OPTIONS
*
Utilisez plutôtPlace.Field.WHEELCHAIR_ACCESSIBLE_ENTRANCE
(obsolète).
Place.Field.ADDRESS_COMPONENTS
Place.Field.ADR_FORMAT_ADDRESS
Place.Field.BUSINESS_STATUS
Place.Field.FORMATTED_ADDRESS
*
À utiliser à la place dePlace.Field.ADDRESS
(obsolète).
Place.Field.GOOGLE_MAPS_URI
Place.Field.ICON_BACKGROUND_COLOR
Place.Field.ICON_MASK_URL
*
À utiliser à la place dePlace.Field.ICON_URL
(obsolète).
Place.Field.LOCATION
*
À utiliser à la place dePlace.Field.LAT_LNG
(obsolète).
Place.Field.PHOTO_METADATAS
Place.Field.PLUS_CODE
Place.Field.PRIMARY_TYPE
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
Les champs suivants déclenchent le SKU Text Search Enterprise :
Place.Field.CURRENT_OPENING_HOURS
Place.Field.CURRENT_SECONDARY_OPENING_HOURS
Place.Field.INTERNATIONAL_PHONE_NUMBER
*
* À utiliser à la place dePlace.Field.PHONE_NUMBER
, qui est obsolète.
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
*
* À utiliser à la place dePlace.Field.USER_RATINGS_TOTAL
, qui est obsolète.
Place.Field.WEBSITE_URI
Les champs suivants déclenchent le SKU Text Search Enterprise Plus :
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
Pour définir le paramètre de liste de champs, appelez la méthode
setPlaceFields()
lors de la création de l'objetSearchByTextRequest
. -
Requête textuelle
Chaîne de texte sur laquelle doit porter la recherche, par exemple "restaurant", "123 Main Street" ou "meilleur endroit à visiter à San Francisco". L'API renvoie les résultats correspondant à cette chaîne et les classe en fonction de leur pertinence estimée.
Pour définir le paramètre de requête textuelle, appelez la méthode
setTextQuery()
lors de la création de l'objetSearchByTextRequest
.
Paramètres facultatifs
Utilisez l'objet SearchByTextRequest
pour spécifier les paramètres facultatifs de votre requête.
Type inclus
Limite les résultats aux lieux correspondant au type spécifié défini par le tableau A. Vous ne pouvez spécifier qu'un seul type. Exemple :
setIncludedType("bar")
setIncludedType("pharmacy")
Pour définir le paramètre de type inclus, appelez la méthode
setIncludedType()
lors de la création de l'objetSearchByTextRequest
.Biais de localisation
Spécifie une zone de recherche. Cet emplacement sert de biais, ce qui signifie que des résultats autour de l'emplacement spécifié peuvent être renvoyés, y compris des résultats en dehors de la zone spécifiée.
Vous pouvez spécifier une restriction géographique ou un biais géographique, mais pas les deux. La restriction d'emplacement consiste à spécifier la région dans laquelle les résultats doivent se trouver, tandis que la pondération géographique consiste à spécifier la région dans laquelle les résultats sont susceptibles de se trouver ou à proximité. N'oubliez pas que, lorsque vous utilisez la pondération géographique, les résultats peuvent toujours se trouver en dehors de la zone spécifiée.
Spécifiez la région sous forme de fenêtre d'affichage rectangulaire ou de cercle.
Un cercle est défini par un point central et un rayon en mètres. Le rayon doit être compris entre 0,0 et 50 000,0 (inclus). Exemple :
// 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();
Un rectangle est une fenêtre d'affichage latitude-longitude, représentée par deux points bas et hauts diagonalement opposés. Le point bas marque l'angle sud-ouest du rectangle, et le point haut représente l'angle nord-est du rectangle.
Une fenêtre d'affichage est considérée comme une région fermée, ce qui signifie qu'elle inclut sa limite. Les limites de latitude doivent être comprises entre -90 et 90 degrés inclus, et les limites de longitude doivent être comprises entre -180 et 180 degrés inclus :
- Si
low
=high
, la fenêtre d'affichage se compose de ce seul point. - Si
low.longitude
>high.longitude
, la plage de longitude est inversée (la fenêtre d'affichage traverse la ligne de longitude de 180 degrés). - Si
low.longitude
= -180 degrés ethigh.longitude
= 180 degrés, la fenêtre d'affichage inclut toutes les longitudes. - Si
low.longitude
= 180 degrés ethigh.longitude
= -180 degrés, la plage de longitude est vide. - Si
low.latitude
>high.latitude
, la plage de latitude est vide.
Les valeurs basse et haute doivent être renseignées, et la boîte représentée ne peut pas être vide. Un viewport vide génère une erreur.
Par exemple, pour une fenêtre d'affichage rectangulaire, consultez Requêtes de recherche de texte.
Pour définir le paramètre de biais de localisation, appelez la méthode
setLocationBias()
lors de la création de l'objetSearchByTextRequest
.- Si
Restriction géographique
Spécifie une zone de recherche. Les résultats en dehors de la zone spécifiée ne sont pas renvoyés. Spécifiez la région en tant que fenêtre d'affichage rectangulaire. Pour savoir comment définir la fenêtre d'affichage, consultez la description du biais de localisation.
Vous pouvez spécifier une restriction géographique ou un biais géographique, mais pas les deux. La restriction d'emplacement consiste à spécifier la région dans laquelle les résultats doivent se trouver, tandis que le biais de localisation consiste à spécifier la région dont les résultats doivent être proches, mais qui peut être en dehors de la zone.
Pour définir le paramètre de restriction géographique, appelez la méthode
setLocationRestriction()
lors de la création de l'objetSearchByTextRequest
.-
Nombre maximal de résultats
Spécifie le nombre maximal de résultats de lieux à renvoyer. Doit être compris entre 1 et 20 (valeur par défaut), inclus.
Pour définir le paramètre du nombre maximal de résultats, appelez la méthode
setMaxResultCount()
lors de la création de l'objetSearchByTextRequest
. Note minimale
Restreint les résultats à ceux dont la note moyenne des utilisateurs est supérieure ou égale à cette limite. Les valeurs doivent être comprises entre 0,0 et 5,0 (inclus), par incréments de 0,5. Par exemple : 0, 0.5, 1.0, ... , 5.0 inclus. Les valeurs sont arrondies à la demi-unité supérieure. Par exemple, une valeur de 0,6 élimine tous les résultats dont la note est inférieure à 1,0.
Pour définir le paramètre de classification minimale, appelez la méthode
setMinRating()
lors de la création de l'objetSearchByTextRequest
.Ouvert
Si la valeur est
true
, ne renvoyez que les lieux ouverts au moment de l'envoi de la requête. Si la valeur estfalse
, renvoie tous les établissements, quel que soit leur état (ouvert ou fermé). Les lieux sans horaires d'ouverture dans la base de données Google Places sont renvoyés si vous définissez ce paramètre surfalse
.Pour définir le paramètre "Ouvert maintenant", appelez la méthode
setOpenNow()
lors de la création de l'objetSearchByTextRequest
.-
Niveaux de prix
Par défaut, les résultats incluent les établissements qui proposent des services à tous les niveaux de prix. Pour limiter les résultats aux lieux situés dans des fourchettes de prix spécifiques, vous pouvez transmettre une liste de valeurs entières correspondant aux fourchettes de prix des lieux que vous souhaitez renvoyer :
1
: l'établissement propose des services bon marché.2
: l'établissement propose des services à des prix modérés.3
: l'établissement propose des services coûteux.4
: l'établissement propose des services très coûteux.
Pour définir le paramètre des niveaux de prix, appelez la méthode
setPriceLevels()
lors de la création de l'objetSearchByTextRequest
. Préférence de classement
Spécifie le classement des résultats dans la réponse en fonction du type de requête :
- Pour une requête par catégorie telle que "Restaurants à New York",
SearchByTextRequest.RankPreference.RELEVANCE
(classer les résultats par pertinence de la recherche) est la valeur par défaut. Vous pouvez définir la préférence de classement surSearchByTextRequest.RankPreference.RELEVANCE
ouSearchByTextRequest.RankPreference.DISTANCE
(classer les résultats par distance). - Pour une requête non catégorielle telle que "Mountain View, CA", nous vous recommandons de ne pas définir le paramètre de préférence de classement.
Pour définir le paramètre de préférence de classement, appelez la méthode
setRankPreference()
lors de la création de l'objetSearchByTextRequest
.- Pour une requête par catégorie telle que "Restaurants à New York",
Code régional
Code de région utilisé pour mettre en forme la réponse, spécifié sous la forme d'une valeur de code CLDR à deux caractères. Ce paramètre peut également avoir un effet de biais sur les résultats de recherche. Il n'existe pas de valeur par défaut.
Si le nom du pays du champ d'adresse dans la réponse correspond au code de région, le code pays est omis de l'adresse.
La plupart des codes CLDR sont identiques aux codes ISO 3166-1, à quelques exceptions près. Par exemple, le ccTLD du Royaume-Uni est "uk" (.co.uk), tandis que son code ISO 3166-1 est "gb" (techniquement pour l'entité "Royaume-Uni de Grande-Bretagne et d'Irlande du Nord"). Ce paramètre peut avoir une incidence sur les résultats en fonction de la loi applicable.
Pour définir le paramètre de code régional, appelez la méthode
setRegionCode()
lors de la création de l'objetSearchByTextRequest
.Filtrage strict par type
Utilisé avec le paramètre de type d'inclusion. Lorsque la valeur est définie sur
true
, seuls les lieux correspondant aux types spécifiés par le type d'inclusion sont renvoyés. Lorsque la valeur estfalse
(par défaut), la réponse peut contenir des lieux qui ne correspondent pas aux types spécifiés.Pour définir le paramètre de filtrage strict des types, appelez la méthode
setStrictTypeFiltering()
lors de la création de l'objetSearchByTextRequest
.