Ricerca di testo (novità)

Seleziona la piattaforma:Android iOS JavaScript Servizio web

Sviluppatori dello Spazio economico europeo (SEE)

Ricerca di testo (novità) restituisce informazioni su un insieme di luoghi in base a una stringa, ad esempio "pizza a New York", "negozi di scarpe vicino a Ottawa" o "123 Main Street". Il servizio risponde con un elenco di luoghi che corrispondono alla stringa di testo e a qualsiasi preferenza di località impostata.

Il servizio è particolarmente utile per eseguire query di indirizzi ambigui in un sistema automatizzato e i componenti non indirizzo della stringa possono corrispondere ad attività e indirizzi. Esempi di query di indirizzi ambigui sono indirizzi formattati in modo errato o richieste che includono componenti non indirizzo, come i nomi delle attività. Le richieste come i primi due esempi potrebbero restituire zero risultati a meno che non sia impostata una località, ad esempio una regione, una limitazione della località o una preferenza della località.

La ricerca di testo (novità) è simile alla ricerca nelle vicinanze (novità). La differenza principale tra le due è che Text Search (New) ti consente di specificare una stringa di ricerca arbitraria, mentre Nearby Search (New) richiede un'area specifica in cui eseguire la ricerca.

"10 High Street, UK" o "123 Main Street, US" Più "High Street" nel Regno Unito; più "Main Street" negli Stati Uniti. La query non restituisce i risultati desiderati a meno che non sia impostata una limitazione della località.
"ChainRestaurant New York" Più sedi di "ChainRestaurant" a New York; nessun indirizzo o neanche nome della via.
"10 High Street, Escher UK" o "123 Main Street, Pleasanton US" Solo una "High Street" nella città di Escher nel Regno Unito; solo una "Main Street" nella città di Pleasanton, in California, negli Stati Uniti.
"UniqueRestaurantName New York" Un solo stabilimento con questo nome a New York; non è necessario un indirizzo per differenziarlo.
"pizzerie a New York" Questa query contiene la limitazione della località e "pizzerie" è un tipo di luogo ben definito. Restituisce più risultati.
"+1 514-670-8700"

Questa query contiene un numero di telefono. Restituisce più risultati per i luoghi associati a quel numero di telefono.

Richieste di ricerca testuale

Una richiesta di ricerca di testo ha il seguente formato:

// 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();
    });

In questo esempio:

  • Imposta l'elenco dei campi in modo che includa solo Place.Field.ID e Place.Field.DISPLAY_NAME. Ciò significa che gli oggetti Place nella risposta che rappresentano ogni luogo corrispondente contengono solo questi due campi.

  • Utilizza SearchByTextRequest.Builder per creare un oggetto SearchByTextRequest che definisce la ricerca.

    • Imposta la stringa di query di testo su "Spicy Vegetarian Food" (Cibo vegetariano piccante).

    • Imposta il numero massimo di posizioni dei risultati su 10. Il valore predefinito e massimo è 20.

    • Limita l'area di ricerca al rettangolo definito dalle coordinate di latitudine e longitudine. Non vengono restituiti risultati al di fuori di questa area.

  • Aggiungi un OnSuccessListener e ottieni i luoghi corrispondenti dall'oggetto SearchByTextResponse.

Risposte della ricerca testuale

La classe SearchByTextResponse rappresenta la risposta a una richiesta di ricerca. Un oggetto SearchByTextResponse contiene:

  • Un elenco di oggetti Place che rappresentano tutti i luoghi corrispondenti, con un oggetto Place per ogni luogo corrispondente.

  • Ogni oggetto Place contiene solo i campi definiti dall'elenco dei campi trasmesso nella richiesta.

Ad esempio, nella richiesta hai definito un elenco di campi come:

// Specify the list of fields to return.
final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.DISPLAY_NAME);

Questo elenco di campi indica che ogni oggetto Place nella risposta contiene solo l'ID luogo e il nome di ogni luogo corrispondente. Puoi quindi utilizzare i metodi Place.getId() e Place.getName() per accedere a questi campi in ogni oggetto Place.

Per altri esempi di accesso ai dati in un oggetto Place, vedi Accedere ai campi di dati dell'oggetto Place.

Parametri obbligatori

I parametri obbligatori per SearchByTextRequest sono:

  • Elenco dei campi

    Specifica quali campi di dati sui luoghi restituire. Passa un elenco di Place.Field valori che specificano i campi di dati da restituire. Nella risposta non è presente un elenco predefinito di campi restituiti.

    Gli elenchi di campi sono una buona pratica di progettazione per assicurarsi di non richiedere dati non necessari, il che aiuta a evitare tempi di elaborazione e addebiti non necessari.

    Specifica uno o più dei seguenti campi:

    • I seguenti campi attivano lo SKU solo ID Text Search Essentials:

      Place.Field.DISPLAY_NAME*
          * Utilizza al posto di Place.Field.NAME (deprecato nella versione 4.0).
      Place.Field.ID
      Place.Field.RESOURCE_NAME*
          * Contiene il nome risorsa del luogo nel formato: places/PLACE_ID.
           Utilizza DISPLAY_NAME per accedere al nome testuale del luogo.
    • I seguenti campi attivano lo SKU Text Search Pro:

      Place.Field.ACCESSIBILITY_OPTIONS*
          Utilizza al posto di Place.Field.WHEELCHAIR_ACCESSIBLE_ENTRANCE (ritirato).
      Place.Field.ADDRESS_COMPONENTS
      Place.Field.ADR_FORMAT_ADDRESS
      Place.Field.BUSINESS_STATUS
      Place.Field.FORMATTED_ADDRESS*
          Utilizza al posto di Place.Field.ADDRESS (deprecato).
      Place.Field.GOOGLE_MAPS_URI
      Place.Field.ICON_BACKGROUND_COLOR
      Place.Field.ICON_MASK_URL *
          Utilizza al posto di Place.Field.ICON_URL (deprecato).
      Place.Field.LOCATION*
          Utilizza al posto di Place.Field.LAT_LNG (ritirato).
      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
    • I seguenti campi attivano lo SKU Text Search Enterprise:

      Place.Field.CURRENT_OPENING_HOURS
      Place.Field.CURRENT_SECONDARY_OPENING_HOURS
      Place.Field.INTERNATIONAL_PHONE_NUMBER*
          * Utilizza al posto di Place.Field.PHONE_NUMBER, che è deprecato.
      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*
          * Utilizza al posto di Place.Field.USER_RATINGS_TOTAL, che è obsoleto.
      Place.Field.WEBSITE_URI
    • I seguenti campi attivano lo 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

    Per impostare il parametro dell'elenco dei campi, chiama il metodo setPlaceFields() durante la creazione dell'oggetto SearchByTextRequest.

  • Query di testo

    La stringa di testo su cui eseguire la ricerca, ad esempio "ristorante", "Via Roma 123" o "il posto migliore da visitare a Roma". L'API restituisce le corrispondenze candidate in base a questa stringa e ordina i risultati in base alla loro pertinenza percepita.

    Per impostare il parametro di query di testo, chiama il metodo setTextQuery() durante la creazione dell'oggetto SearchByTextRequest.

Parametri facoltativi

Utilizza l'oggetto SearchByTextRequest per specificare i parametri facoltativi per la tua richiesta.

  • Tipo incluso

    Limita i risultati ai luoghi che corrispondono al tipo specificato definito nella tabella A. È possibile specificare un solo tipo. Ad esempio:

    • setIncludedType("bar")
    • setIncludedType("pharmacy")

    Per impostare il parametro del tipo incluso, chiama il metodo setIncludedType() durante la creazione dell'oggetto SearchByTextRequest.

  • Bias di località

    Specifica un'area in cui cercare. Questa posizione funge da bias, il che significa che possono essere restituiti risultati intorno alla posizione specificata, inclusi risultati al di fuori dell'area specificata.

    Puoi specificare la limitazione della località o la preferenza per la località, ma non entrambe. Considera la limitazione della località come la specifica della regione in cui devono trovarsi i risultati e la distorsione della località come la specifica della regione in cui è probabile che si trovino i risultati o nelle vicinanze. Tieni presente che, quando utilizzi la distorsione della località, i risultati possono comunque trovarsi al di fuori dell'area specificata.

    Specifica la regione come area visibile rettangolare o come cerchio.

    • Un cerchio è definito dal punto centrale e dal raggio in metri. Il raggio deve essere compreso tra 0,0 e 50.000,0 inclusi. Ad esempio:

      // 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 rettangolo è un'area visibile di latitudine e longitudine, rappresentata da due punti basso e alto diagonalmente opposti. Il punto più basso indica l'angolo sud-ovest del rettangolo, mentre il punto più alto rappresenta l'angolo nord-est del rettangolo.

      Un viewport è considerato una regione chiusa, il che significa che include il suo confine. I limiti di latitudine devono essere compresi tra -90 e 90 gradi inclusi e i limiti di longitudine devono essere compresi tra -180 e 180 gradi inclusi:

      • Se low = high, l'area visibile è costituita da un singolo punto.
      • Se low.longitude > high.longitude, l'intervallo di longitudine è invertito (l'area visibile attraversa la linea di longitudine di 180 gradi).
      • Se low.longitude = -180 gradi e high.longitude = 180 gradi, l'area visibile include tutte le longitudini.
      • Se low.longitude = 180 gradi e high.longitude = -180 gradi, l'intervallo di longitudine è vuoto.
      • Se low.latitude > high.latitude, l'intervallo di latitudine è vuoto.

      Sia il valore di base che il valore finale devono essere compilati e la casella rappresentata non può essere vuota. Un viewport vuoto genera un errore.

      Ad esempio, per un riquadro visibile rettangolare, consulta Richieste di ricerca di testo.

      Per impostare il parametro di distorsione della località, chiama il metodo setLocationBias() durante la creazione dell'oggetto SearchByTextRequest.

  • Limitazione della località

    Specifica un'area in cui cercare. I risultati al di fuori dell'area specificata non vengono restituiti. Specifica la regione come area visibile rettangolare. Consulta la descrizione del bias di località per informazioni sulla definizione dell'area visibile.

    Puoi specificare la limitazione della località o la preferenza per la località, ma non entrambe. Considera la limitazione della località come la specifica della regione in cui devono trovarsi i risultati e la distorsione della località come la specifica della regione in cui devono trovarsi i risultati, che però possono trovarsi al di fuori dell'area.

    Per impostare il parametro di limitazione della località, chiama il metodo setLocationRestriction() durante la creazione dell'oggetto SearchByTextRequest.

  • Numero massimo di risultati

    Specifica il numero massimo di risultati di luoghi da restituire. Deve essere compreso tra 1 e 20 (valore predefinito) inclusi.

    Per impostare il parametro del conteggio massimo dei risultati, chiama il metodo setMaxResultCount() durante la creazione dell'oggetto SearchByTextRequest.

  • Valutazione minima

    Limita i risultati solo a quelli la cui valutazione media degli utenti è maggiore o uguale a questo limite. I valori devono essere compresi tra 0,0 e 5,0 (inclusi) con incrementi di 0,5. Ad esempio: 0, 0.5, 1.0, ... , 5.0 inclusi. I valori vengono arrotondati per eccesso a 0,5. Ad esempio, un valore di 0,6 elimina tutti i risultati con una valutazione inferiore a 1,0.

    Per impostare il parametro di valutazione minima, chiama il metodo setMinRating() durante la creazione dell'oggetto SearchByTextRequest.

  • Aperto adesso

    Se true, restituisci solo i luoghi aperti al pubblico al momento dell'invio della query. Se false, restituisci tutte le attività indipendentemente dallo stato di apertura. I luoghi che non specificano gli orari di apertura nel database di Google Places vengono restituiti se imposti questo parametro su false.

    Per impostare il parametro Apri ora, chiama il metodo setOpenNow() durante la creazione dell'oggetto SearchByTextRequest.

  • Livelli di prezzo

    Per impostazione predefinita, i risultati includono luoghi che forniscono servizi a tutti i livelli di prezzo. Per limitare i risultati in modo da includere solo i luoghi a determinati livelli di prezzo, puoi trasmettere un elenco di valori interi che corrispondono ai livelli di prezzo dei luoghi che vuoi restituire:

    • 1: il luogo offre servizi economici.
    • 2: il luogo offre servizi a prezzi moderati.
    • 3 - Il luogo offre servizi costosi.
    • 4 - Il luogo offre servizi molto costosi.

    Per impostare il parametro dei livelli di prezzo, chiama il metodo setPriceLevels() durante la creazione dell'oggetto SearchByTextRequest.

  • Preferenza di ranking

    Specifica come vengono classificati i risultati nella risposta in base al tipo di query:

    • Per una query categorica come "Ristoranti a New York", SearchByTextRequest.RankPreference.RELEVANCE (ordina i risultati in base alla pertinenza della ricerca) è l'impostazione predefinita. Puoi impostare la preferenza di classificazione su SearchByTextRequest.RankPreference.RELEVANCE o SearchByTextRequest.RankPreference.DISTANCE (classifica i risultati in base alla distanza).
    • Per una query non categorica come "Mountain View, CA", ti consigliamo di lasciare il parametro di preferenza di ranking non impostato.

    Per impostare il parametro di preferenza di ranking, chiama il metodo setRankPreference() durante la creazione dell'oggetto SearchByTextRequest.

  • Codice regione

    Il codice regione utilizzato per formattare la risposta, specificato come valore di un codice CLDR a due caratteri. Questo parametro può anche avere un effetto di distorsione sui risultati di ricerca. Non esiste un valore predefinito.

    Se il nome del paese del campo dell'indirizzo nella risposta corrisponde al codice regione, il codice paese viene omesso dall'indirizzo.

    La maggior parte dei codici CLDR sono identici ai codici ISO 3166-1, con alcune eccezioni degne di nota. Ad esempio, il TLD specifico per paese del Regno Unito è "uk" (.co.uk), mentre il suo codice ISO 3166-1 è"gb " (tecnicamente per l'entità "Regno Unito di Gran Bretagna e Irlanda del Nord"). Il parametro può influire sui risultati in base alla legge vigente.

    Per impostare il parametro del codice regione, chiama il metodo setRegionCode() durante la creazione dell'oggetto SearchByTextRequest.

  • Filtraggio rigoroso dei tipi

    Utilizzato con il parametro del tipo di inclusione. Se impostato su true, vengono restituiti solo i luoghi che corrispondono ai tipi specificati da include_type. Quando false, l'impostazione predefinita, la risposta può contenere luoghi che non corrispondono ai tipi specificati.

    Per impostare il parametro di filtraggio rigoroso dei tipi, chiama il metodo setStrictTypeFiltering() durante la creazione dell'oggetto SearchByTextRequest.