Introduzione
Gli ID luogo identificano in modo univoco un luogo nel database di Google Places e su Google Maps. Gli ID luogo sono accettati nelle richieste alle seguenti API Maps:
- Recupero di un indirizzo per un ID luogo nell'API Geocoding e nel servizio Geocoding dell'API Maps JavaScript.
- Specificare l'origine, la destinazione e le tappe intermedie nell'API Routes e nell'API Directions (legacy) e nel servizio Directions, API Maps JavaScript (legacy).
- Specifica di origini e destinazioni nelle API Routes e Distance Matrix (legacy) e servizio Distance Matrix, API Maps JavaScript (legacy).
- Recupero dei dettagli del luogo nell'API Places (nuova), Places SDK for Android (nuovo), Places SDK for iOS (nuovo) e Places Library.
- Utilizzo dei parametri ID luogo nell'API Maps Embed.
- Recupero delle query di ricerca negli URL di Maps.
- Visualizzazione dei limiti di velocità nell'API Roads.
- Trovare e personalizzare i poligoni dei confini negli stili basati sui dati per i confini.
Trovare l'ID di un luogo specifico
Stai cercando l'ID luogo di un luogo specifico? Utilizza lo strumento di ricerca dell'ID luogo riportato di seguito per cercare un luogo e ottenere il relativo ID:
In alternativa, puoi visualizzare il cercatore di ID luogo con il relativo codice nella documentazione dell'API Maps JavaScript.
Panoramica
Un ID luogo è un identificatore testuale che identifica in modo univoco un luogo. La lunghezza dell'identificatore può variare (non esiste una lunghezza massima per gli ID luogo). Esempi:
-
ChIJgUbEo8cfqokR5lP9_Wh_DaM
-
GhIJQWDl0CIeQUARxks3icF8U8A
-
EicxMyBNYXJrZXQgU3QsIFdpbG1pbmd0b24sIE5DIDI4NDAxLCBVU0EiGhIYChQKEgnRTo6ixx-qiRHo_bbmkCm7ZRAN
-
EicxMyBNYXJrZXQgU3QsIFdpbG1pbmd0b24sIE5DIDI4NDAxLCBVU0E
-
IhoSGAoUChIJ0U6OoscfqokR6P225pApu2UQDQ
Gli ID luogo sono disponibili per la maggior parte delle località, tra cui attività, punti di riferimento, parchi e incroci. È possibile che lo stesso luogo o la stessa località abbia più ID luogo diversi. Gli ID luogo possono cambiare nel tempo.
Puoi utilizzare lo stesso ID luogo nell'API Places e in diverse API Google Maps Platform. Ad esempio, puoi utilizzare lo stesso ID luogo per fare riferimento a un luogo nell'API Places, nell'API Maps JavaScript, nell'API Geocoding, nell'API Maps Embed e nell'API Roads.
Recuperare i dettagli del luogo utilizzando l'ID luogo
Un modo comune per utilizzare gli ID luogo è cercare un luogo (utilizzando l'API Places o la libreria Places nell'API Maps JavaScript, ad esempio), quindi utilizzare l'ID luogo restituito per recuperare i dettagli del luogo. Puoi memorizzare l'ID luogo e utilizzarlo per recuperare in un secondo momento gli stessi dettagli del luogo. Scopri di più sul salvataggio degli ID luogo di seguito.
Esempio di utilizzo di Places SDK per iOS
Un ID luogo è un identificatore testuale che identifica in modo univoco un luogo. Nell'SDK Places per iOS, puoi recuperare l'ID di un luogo da un oggetto GMSPlace
. Puoi memorizzare l'ID luogo e utilizzarlo per recuperare
l'oggetto GMSPlace
in un secondo momento.
Per ottenere un luogo in base all'ID, chiama
GMSPlacesClient
fetchPlaceFromPlaceID:
, passando i seguenti parametri:
- Una stringa contenente un ID luogo.
- Uno o più
GMSPlaceField
, che specificano i tipi di dati da restituire. - Un token di sessione se la chiamata viene effettuata per concludere una query di completamento automatico. In caso contrario, passa nil.
- Un
GMSPlaceResultCallback
per gestire il risultato.
L'API richiama il metodo di callback specificato, passando un oggetto
GMSPlace
. Se il luogo non viene trovato, l'oggetto luogo è nullo.
Places Swift SDK per iOS
// Initialize Places Swift Client. let placesClient = PlacesClient.shared // A hotel in Saigon with an attribution let placeID = "ChIJV4k8_9UodTERU5KXbkYpSYs" // Fetch Place Request. let fetchPlaceRequest = FetchPlaceRequest( placeID: placeID, placeProperties: [.displayName] ) Task { switch await placesClient.fetchPlace(with: fetchPlaceRequest) { case .success(let place): print("The selected place is: \(place.displayName): \(String(describing: place.description))") case .failure(let placesError): print("Place not found: \(placeID); \(placesError)") } }
Swift
// A hotel in Saigon with an attribution. let placeID = "ChIJV4k8_9UodTERU5KXbkYpSYs" // Specify the place data types to return. let fields: GMSPlaceField = GMSPlaceField(rawValue: UInt(GMSPlaceField.name.rawValue) | UInt(GMSPlaceField.placeID.rawValue))! placesClient?.fetchPlace(fromPlaceID: placeID, placeFields: fields, sessionToken: nil, callback: { (place: GMSPlace?, error: Error?) in if let error = error { print("An error occurred: \(error.localizedDescription)") return } if let place = place { self.lblName?.text = place.name print("The selected place is: \(place.name)") } })
Objective-C
// A hotel in Saigon with an attribution. NSString *placeID = @"ChIJV4k8_9UodTERU5KXbkYpSYs"; // Specify the place data types to return. GMSPlaceField fields = (GMSPlaceFieldName | GMSPlaceFieldPlaceID); [_placesClient fetchPlaceFromPlaceID:placeID placeFields:fields sessionToken:nil callback:^(GMSPlace * _Nullable place, NSError * _Nullable error) { if (error != nil) { NSLog(@"An error occurred %@", [error localizedDescription]); return; } if (place != nil) { NSLog(@"The selected place is: %@", [place name]); } }];
Salvare gli ID luogo per un utilizzo futuro
Gli ID luogo sono esenti dalle limitazioni della memorizzazione nella cache indicate nella sezione 3.2.3(b) dei Termini di servizio di Google Maps Platform. Pertanto, puoi memorizzare i valori dell'ID luogo per utilizzarli in un secondo momento.
Aggiornare gli ID luogo memorizzati
Poiché gli ID luogo potrebbero cambiare a causa degli aggiornamenti del database di Google Maps, Google consiglia
di aggiornarli se hanno più di 12 mesi. Puoi aggiornare gli ID luogo senza
costi effettuando una
richiesta Place Details,
specificando solo il campo GMSPlaceFieldPlaceID
nel parametro fields
.
Questa chiamata attiva lo SKU Places Details - ID Refresh.
Codici di errore durante l'utilizzo degli ID luogo
INVALID_REQUEST
Il codice di stato INVALID_REQUEST
indica che l'ID luogo specificato non è valido. INVALID_REQUEST
può essere restituito quando l'ID luogo è stato troncato o modificato in altro modo e non è più corretto.
NOT_FOUND
Il codice di stato NOT_FOUND
indica che l'ID luogo specificato
è obsoleto. Un ID luogo può diventare obsoleto se un'attività chiude o si trasferisce in una nuova sede. Gli ID luogo possono cambiare anche a causa di aggiornamenti del database di Google Maps. In questi casi, un luogo potrebbe ricevere un nuovo ID luogo e il vecchio
ID restituisce una risposta NOT_FOUND
.
Per aggiornare i risultati in caso di ID luogo obsoleto, memorizza la richiesta originale che ha restituito ogni ID luogo ed emetti nuovamente la richiesta in base alle esigenze. Tieni presente che la richiesta riemessa viene fatturata in base allo SKU appropriato.
Alcuni tipi di ID luogo a volte possono causare una
risposta NOT_FOUND
oppure l'API può restituire un ID luogo diverso nella
risposta. Questi tipi di ID luogo includono:
- Indirizzi stradali che non esistono in Google Maps come indirizzi precisi, ma vengono dedotti da un intervallo di indirizzi.
- Segmenti di un percorso lungo, in cui la richiesta specifica anche una città o una località.
- Incroci.
- Luoghi con un componente di indirizzo di tipo
subpremise
.
Questi ID spesso assumono la forma di una stringa lunga (non esiste una lunghezza massima per gli ID luogo). Ad esempio:
EpID4LC14LC_4LCo4LCv4LGN4LCo4LCX4LCw4LGNIC0g4LC44LGI4LCm4LGN4LCs4LC-4LCm4LGNIOCwsOCxi-CwoeCxjeCwoeCxgSAmIOCwteCwv-CwqOCwr-CxjSDgsKjgsJfgsLDgsY0g4LCu4LGG4LCv4LC_4LCo4LGNIOCwsOCxi-CwoeCxjeCwoeCxgSwg4LC14LC_4LCo4LCv4LGNIOCwqOCwl-CwsOCxjSDgsJXgsL7gsLLgsKjgsYAsIOCwsuCwleCxjeCwt-CxjeCwruCwv-CwqOCwl-CwsOCxjSDgsJXgsL7gsLLgsKjgsYAsIOCwuOCwsOCxguCwsOCxjSDgsKjgsJfgsLDgsY0g4LC14LGG4LC44LGN4LCf4LGNLCDgsLjgsK_gsYDgsKbgsL7gsKzgsL7gsKbgsY0sIOCwueCxiOCwpuCwsOCwvuCwrOCwvuCwpuCxjSwg4LCk4LGG4LCy4LCC4LCX4LC-4LCjIDUwMDA1OSwg4LCt4LC-4LCw4LCk4LCm4LGH4LC24LCCImYiZAoUChIJ31l5uGWYyzsR9zY2qk9lDiASFAoSCd9ZebhlmMs7Efc2NqpPZQ4gGhQKEglDz61OZpjLOxHgDJCFY-o1qBoUChIJi37TW2-YyzsRr_uv50r7tdEiCg1MwFcKFS_dyy4