IDs de lugares identificam um local de modo exclusivo no banco de dados do Google Places e no Google Maps. Os IDs de lugares são aceitos nas seguintes solicitações às APIs Maps:
- Recuperar o endereço de um ID de lugar no serviço da Web da API Geocoding e no serviço Geocoding da API Maps JavaScript.
- Especificar waypoints de origem, destino e intermediários no serviço da Web da API Routes e Directions e no serviço Directions da API Maps JavaScript.
- Especificar as origens e os destinos no serviço da Web da API Routes e Distance Matrix e no serviço Distance Matrix da API Maps JavaScript.
- Recuperar detalhes do lugar no serviço da Web da API Places, no SDK do Places para Android, no SDK do Places para iOS e na biblioteca Places.
- Usar parâmetros de ID do lugar na API Maps Embed.
- Recuperar consultas de pesquisa em URLs do Maps
- Mostrar limites de velocidade na API Roads.
- Encontrar e estilizar polígonos de limites com base em dados.
Encontrar o ID de um lugar específico
Está procurando o ID de um lugar específico? Use o localizador abaixo para pesquisar um lugar e conseguir o ID dele:
Também é possível usar o localizador de IDs de lugares com o respectivo código na documentação da API Maps JavaScript.
Visão geral
O ID de lugar é um indicador textual que identifica um local de forma exclusiva. O tamanho do identificador pode variar. Não há tamanho máximo para os IDs de lugar. Exemplos:
-
ChIJgUbEo8cfqokR5lP9_Wh_DaM
-
GhIJQWDl0CIeQUARxks3icF8U8A
-
EicxMyBNYXJrZXQgU3QsIFdpbG1pbmd0b24sIE5DIDI4NDAxLCBVU0EiGhIYChQKEgnRTo6ixx-qiRHo_bbmkCm7ZRAN
-
EicxMyBNYXJrZXQgU3QsIFdpbG1pbmd0b24sIE5DIDI4NDAxLCBVU0E
-
IhoSGAoUChIJ0U6OoscfqokR6P225pApu2UQDQ
Os IDs de lugares estão disponíveis para a maioria dos locais, incluindo empresas, pontos turísticos, parques e cruzamentos. Cada local pode ter vários IDs, que estão sujeitos a mudança com o passar do tempo.
Você pode usar o mesmo ID de lugar na API Places e em várias APIs da Plataforma Google Maps. Por exemplo, use o mesmo ID para identificar um lugar nas APIs Places, Maps JavaScript, Geocoding, Maps Embed e Roads.
Recuperar detalhes usando o ID de lugar
Uma maneira comum de utilizar IDs de lugares é procurar um local usando a API Places ou a biblioteca Places na API Maps JavaScript, por exemplo, e depois aproveitar o ID de lugar retornado para recuperar os detalhes. Armazene o ID de lugar e use posteriormente para recuperar os detalhes do mesmo local. Leia abaixo sobre como salvar IDs de lugares.
Exemplo de uso do SDK do Places para Android
No SDK do Places para Android, é possível recuperar o ID de um lugar chamando
Place.getId()
.
O serviço Place Autocomplete também retorna um ID de lugar para cada lugar que corresponde à consulta de pesquisa e ao filtro fornecidos. Use o ID do lugar para recuperar o objeto Place
novamente mais tarde.
Para receber um lugar por ID, chame
PlacesClient.fetchPlace()
,
transmitindo um FetchPlaceRequest
.
A API retorna um
FetchPlaceResponse
em um
Task
.
O
FetchPlaceResponse
contém um objeto
Place
correspondente ao ID de lugar fornecido.
O exemplo de código a seguir mostra como chamar fetchPlace()
para
receber detalhes do lugar especificado.
Kotlin
// Define a Place ID. val placeId = "INSERT_PLACE_ID_HERE" // Specify the fields to return. val placeFields = listOf(Place.Field.ID, Place.Field.NAME) // Construct a request object, passing the place ID and fields array. val request = FetchPlaceRequest.newInstance(placeId, placeFields) placesClient.fetchPlace(request) .addOnSuccessListener { response: FetchPlaceResponse -> val place = response.place Log.i(PlaceDetailsActivity.TAG, "Place found: ${place.name}") }.addOnFailureListener { exception: Exception -> if (exception is ApiException) { Log.e(TAG, "Place not found: ${exception.message}") val statusCode = exception.statusCode TODO("Handle error with given status code") } }
Java
// Define a Place ID. final String placeId = "INSERT_PLACE_ID_HERE"; // Specify the fields to return. final List<Place.Field> placeFields = Arrays.asList(Place.Field.ID, Place.Field.NAME); // Construct a request object, passing the place ID and fields array. final FetchPlaceRequest request = FetchPlaceRequest.newInstance(placeId, placeFields); placesClient.fetchPlace(request).addOnSuccessListener((response) -> { Place place = response.getPlace(); Log.i(TAG, "Place found: " + place.getName()); }).addOnFailureListener((exception) -> { if (exception instanceof ApiException) { final ApiException apiException = (ApiException) exception; Log.e(TAG, "Place not found: " + exception.getMessage()); final int statusCode = apiException.getStatusCode(); // TODO: Handle error with given status code. } });
Salvar IDs de lugares para uso posterior
Os IDs de lugares estão isentos das restrições de armazenamento em cache definidas na Seção 3.2.3(b) dos Termos de Serviço da Plataforma Google Maps. Portanto, você pode armazenar os valores desses IDs para usar depois.
Atualizar IDs de lugares armazenados
O Google recomenda atualizar os IDs de lugares com mais de 12 meses. Atualize os IDs de lugares sem custos financeiros fazendo uma solicitação do Place Details e especifique apenas o campo Place.Field.ID
no parâmetro fields
.
Essa chamada aciona a SKU Places Details – ID Refresh.
Essa solicitação também pode retornar o código de status
NOT_FOUND
. Uma estratégia é armazenar a solicitação original que retornou cada ID de lugar. Se um deles se tornar inválido, repita a solicitação para gerar novos resultados, que podem ou não incluir o lugar original. No entanto, essa solicitação
é passível de cobrança.
Códigos de erro ao usar IDs de lugares
O código de status INVALID_REQUEST
indica que o ID de lugar especificado não é válido. É possível que INVALID_REQUEST
seja retornado quando o ID for truncado ou modificado e não estiver mais correto.
O código de status NOT_FOUND
indica que o ID de lugar especificado está obsoleto. Um ID se torna obsoleto quando uma empresa fecha ou muda para outro local. Ele pode mudar devido a atualizações no banco de dados do Google Maps. Nesses casos, um lugar recebe um novo ID, e o ID antigo retorna uma resposta NOT_FOUND
.
Especificamente, alguns tipos de IDs de lugares podem gerar uma resposta NOT_FOUND
, ou a API pode retornar um ID diferente. Esses tipos de ID de lugar incluem:
- Endereços que não são exatos no Google Maps, mas são inferidos de um intervalo de endereços.
- Trechos de um trajeto longo, em que a solicitação também especifica uma cidade ou região administrativa.
- Cruzamentos.
- Lugares com um componente de endereço do tipo
subpremise
.
Esses IDs geralmente assumem a forma de uma string longa (não há tamanho máximo). Por exemplo:
EpID4LC14LC_4LCo4LCv4LGN4LCo4LCX4LCw4LGNIC0g4LC44LGI4LCm4LGN4LCs4LC-4LCm4LGNIOCwsOCxi-CwoeCxjeCwoeCxgSAmIOCwteCwv-CwqOCwr-CxjSDgsKjgsJfgsLDgsY0g4LCu4LGG4LCv4LC_4LCo4LGNIOCwsOCxi-CwoeCxjeCwoeCxgSwg4LC14LC_4LCo4LCv4LGNIOCwqOCwl-CwsOCxjSDgsJXgsL7gsLLgsKjgsYAsIOCwsuCwleCxjeCwt-CxjeCwruCwv-CwqOCwl-CwsOCxjSDgsJXgsL7gsLLgsKjgsYAsIOCwuOCwsOCxguCwsOCxjSDgsKjgsJfgsLDgsY0g4LC14LGG4LC44LGN4LCf4LGNLCDgsLjgsK_gsYDgsKbgsL7gsKzgsL7gsKbgsY0sIOCwueCxiOCwpuCwsOCwvuCwrOCwvuCwpuCxjSwg4LCk4LGG4LCy4LCC4LCX4LC-4LCjIDUwMDA1OSwg4LCt4LC-4LCw4LCk4LCm4LGH4LC24LCCImYiZAoUChIJ31l5uGWYyzsR9zY2qk9lDiASFAoSCd9ZebhlmMs7Efc2NqpPZQ4gGhQKEglDz61OZpjLOxHgDJCFY-o1qBoUChIJi37TW2-YyzsRr_uv50r7tdEiCg1MwFcKFS_dyy4