Cómo revertir la geocodificación de una ubicación

Desarrolladores del Espacio Económico Europeo (EEE)

La geocodificación inversa convierte una ubicación del mapa en una dirección legible por humanos. La ubicación del mapa se representa con las coordenadas de latitud y longitud de la ubicación.

Cuando geocodificas una ubicación de forma inversa, la respuesta contiene lo siguiente:

Esta API muestra diferentes tipos de direcciones, desde la dirección más específica hasta entidades políticas menos específicas, como vecindarios, ciudades, condados y estados. Por lo general, la dirección más exacta es el primer resultado. Si deseas buscar coincidencias con un tipo específico de dirección, usa el types parámetro.

Solicitud de geocodificación inversa

Una solicitud de geocodificación inversa es una solicitud HTTP GET. Puedes especificar la ubicación como una cadena no estructurada:

https://geocode.googleapis.com/v4/geocode/location/LATITUDE,LONGITUDE

O como un conjunto estructurado de coordenadas de latitud y longitud representadas por parámetros de búsqueda:

https://geocode.googleapis.com/v4/geocode/location?location.latitude=LATITUDE&location.longitude=LONGITUDE

Por lo general, se usa el formato estructurado cuando se procesan los componentes de ubicación capturados en un formulario HTML.

Pasa todos los demás parámetros como parámetros de URL o, para parámetros como la clave de API o la máscara de campo, en los encabezados como parte de la solicitud GET. Por ejemplo:

Pasa una cadena de ubicación no estructurada

Una ubicación no estructurada es una ubicación con el formato de una cadena separada por comas de coordenadas de latitud y longitud:

https://geocode.googleapis.com/v4/geocode/location/37.4225508,-122.0846338?key=API_KEY

O en un comando curl:

curl -X GET -H 'Content-Type: application/json' \
-H "X-Goog-Api-Key: API_KEY" \
"https://geocode.googleapis.com/v4/geocode/location/37.4225508,-122.0846338"

Pasa una ubicación estructurada

Para especificar la ubicación estructurada, usa el parámetro de búsqueda location, del tipo LatLng. El objeto LatLng te permite especificar la latitud y la longitud como parámetros de búsqueda independientes:

https://geocode.googleapis.com/v4/geocode/location?location.latitude=37.4225508&location.longitude=-122.0846338&key=API_KEY

Usa OAuth para realizar una solicitud

La API de Geocoding v4 admite OAuth 2.0 para la autenticación. Para usar OAuth con la API de Geocoding, el token de OAuth debe tener asignado el alcance correcto. La API de Geocoding admite los siguientes alcances para usar con la geocodificación inversa:

  • https://www.googleapis.com/auth/maps-platform.geocode : Se usa con todos los métodos de la API de Geocoding.
  • https://www.googleapis.com/auth/maps-platform.geocode.location : Se usa solo con GeocodeLocation para la geocodificación inversa.

Además, puedes usar el alcance general https://www.googleapis.com/auth/cloud-platform para todos los métodos de la API de Geocoding. Ese alcance es útil durante el desarrollo, pero no en la producción, ya que es un alcance general que permite el acceso a todos los métodos.

Para obtener más información y ejemplos, consulta Usar OAuth.

Respuesta de geocodificación inversa

La geocodificación inversa muestra un GeocodeLocationResponse objeto que contiene lo siguiente:

  • El array results de GeocodeResult objetos que representa el lugar.

    Las respuestas de la API de Geocoding incluyen types arrays en dos lugares principales dentro de GeocodeResult:

    1. GeocodeResult.types: Este array indica el tipo o los tipos generales del resultado. Los valores posibles se extraen de la Tabla A y la Tabla B en la página Tipos de lugares (nuevo).
    2. GeocodeResult.addressComponents[].types: Cada componente de dirección tiene un types array que indica el tipo de esa parte específica de la dirección. Estos valores se extraen de la tabla Tipos de dirección y tipos de componentes de dirección en la página Tipos de lugares (nuevo).

    El geocodificador inverso muestra más de un resultado en el array results. Los resultados no solo representan direcciones postales, sino que permiten hacer referencia a cualquier ubicación geográfica. Por ejemplo, cuando se geocodifica un punto en la ciudad de Chicago, dicha ubicación puede etiquetarse como una dirección, como una ciudad (Chicago), como un estado (Illinois) o como un país (Estados Unidos). Todas las direcciones corresponden al geocodificador. El geocodificador inverso muestra cualquiera de estos tipos como resultados válidos.

  • El campo plusCode, del tipo PlusCode, contiene el código plus que mejor se aproxima a la latitud y la longitud de la solicitud. Además, cada elemento del results array contiene un código plus. La distancia entre el código plus decodificado y el punto de solicitud es inferior a 10 metros.

    Nota: La API no siempre muestra códigos plus.

El objeto JSON completo tiene el siguiente formato:

{
  "results": [
    {
      "place": "//places.googleapis.com/places/ChIJV-FZF7i7j4ARo4ZOUoecZFU",
      "placeId": "ChIJV-FZF7i7j4ARo4ZOUoecZFU",
      "location": {
        "latitude": 37.422588300000008,
        "longitude": -122.0846489
      },
      "granularity": "ROOFTOP",
      "viewport": {
        "low": {
          "latitude": 37.421239319708512,
          "longitude": -122.0859978802915
        },
        "high": {
          "latitude": 37.423937280291511,
          "longitude": -122.08329991970851
        }
      },
      "formattedAddress": "1600 Amphitheatre Pkwy, Mountain View, CA 94043, USA",
      "addressComponents": [
        {
          "longText": "1600",
          "shortText": "1600",
          "types": [
            "street_number"
          ]
        },
        {
          "longText": "Amphitheatre Parkway",
          "shortText": "Amphitheatre Pkwy",
          "types": [
            "route"
          ],
          "languageCode": "en"
        },
        {
          "longText": "Mountain View",
          "shortText": "Mountain View",
          "types": [
            "locality",
            "political"
          ],
          "languageCode": "en"
        },
        {
          "longText": "Santa Clara County",
          "shortText": "Santa Clara County",
          "types": [
            "administrative_area_level_2",
            "political"
          ],
          "languageCode": "en"
        },
        {
          "longText": "California",
          "shortText": "CA",
          "types": [
            "administrative_area_level_1",
            "political"
          ],
          "languageCode": "en"
        },
        {
          "longText": "United States",
          "shortText": "US",
          "types": [
            "country",
            "political"
          ],
          "languageCode": "en"
        },
        {
          "longText": "94043",
          "shortText": "94043",
          "types": [
            "postal_code"
          ]
        }
      ],
      "types": [
        "street_address"
      ],
      "plusCode": {
        "globalCode": "849VCW83+PM",
        "compoundCode": "CW83+PM Mountain View, CA, USA"
      }
    },
    {
      "place": "//places.googleapis.com/places/ChIJj61dQgK6j4AR4GeTYWZsKWw",
      "placeId": "ChIJj61dQgK6j4AR4GeTYWZsKWw",
      "location": {
        "latitude": 37.4220541,
        "longitude": -122.08532419999999
      },
      "granularity": "ROOFTOP",
      "viewport": {
        "low": {
          "latitude": 37.4207051197085,
          "longitude": -122.08667318029148
        },
        "high": {
          "latitude": 37.423403080291493,
          "longitude": -122.08397521970851
        }
      },
      "formattedAddress": "1600 Amphitheatre Pkwy, Mountain View, CA 94043, USA",
      "addressComponents": [
        {
          "longText": "1600",
          "shortText": "1600",
          "types": [
            "street_number"
          ]
        },
        {
          "longText": "Amphitheatre Parkway",
          "shortText": "Amphitheatre Pkwy",
          "types": [
            "route"
          ],
          "languageCode": "en"
        },
        {
          "longText": "Mountain View",
          "shortText": "Mountain View",
          "types": [
            "locality",
            "political"
          ],
          "languageCode": "en"
        },
        {
          "longText": "Santa Clara County",
          "shortText": "Santa Clara County",
          "types": [
            "administrative_area_level_2",
            "political"
          ],
          "languageCode": "en"
        },
        {
          "longText": "California",
          "shortText": "CA",
          "types": [
            "administrative_area_level_1",
            "political"
          ],
          "languageCode": "en"
        },
        {
          "longText": "United States",
          "shortText": "US",
          "types": [
            "country",
            "political"
          ],
          "languageCode": "en"
        },
        {
          "longText": "94043",
          "shortText": "94043",
          "types": [
            "postal_code"
          ]
        }
      ],
      "types": [
        "establishment",
        "point_of_interest"
      ],
      "plusCode": {
        "globalCode": "849VCWC7+RV",
        "compoundCode": "CWC7+RV Mountain View, CA, USA"
      }
    },
   ...
  ],
  "plusCode": {
    "globalCode": "849VCWF8+24H",
    "compoundCode": "CWF8+24H Mountain View, CA, USA"
  }
}

Parámetros obligatorios

  • ubicación

    Las coordenadas de latitud y longitud que especifican dónde deseas obtener la dirección legible por humanos más cercana.

Parámetros opcionales

  • languageCode

    El idioma en el que se muestran los resultados.

    • Consulta la lista de idiomas disponibles. Google actualiza con frecuencia los idiomas admitidos, por lo que es posible que esta lista no sea completa.
    • Si no se proporciona languageCode, la API usa en de forma predeterminada. Si especificas un código de idioma no válido, la API muestra un INVALID_ARGUMENT error.
    • La API hace todo lo posible para proporcionar una dirección que sea legible para el usuario y los locales. Para lograr ese objetivo, muestra direcciones en el idioma local, transliteradas a una secuencia de comandos legible por el usuario si es necesario, respetando el idioma preferido. Todas las demás direcciones se muestran en el idioma preferido. Todos los componentes de la dirección se muestran en el mismo idioma, que se elige del primer componente.
    • Si un nombre no está disponible en el idioma preferido, la API usa la coincidencia más cercana.
    • El idioma preferido tiene una pequeña influencia en el conjunto de resultados que la API elige mostrar y el orden en que se muestran. El geocodificador interpreta las abreviaturas de manera diferente según el idioma, como las abreviaturas de los tipos de calles o los sinónimos que pueden ser válidos en un idioma, pero no en otro.
  • regionCode

    El código de región como un valor de código CLDR de dos caracteres. No hay un valor predeterminado. La mayoría de los códigos CLDR son idénticos a los códigos ISO 3166-1.

    Cuando se geocodifica una dirección, geocodificación directa, este parámetro puede influir en los resultados del servicio para la región especificada, pero no los restringe por completo. Cuando se geocodifica una ubicación o un lugar, geocodificación inversa o geocodificación de lugares, este parámetro se puede usar para dar formato a la dirección. En todos los casos, este parámetro puede afectar los resultados según la ley aplicable.

  • nivel de detalle

    Uno o más niveles de detalle de la ubicación, especificados como parámetros de búsqueda independientes, según lo define Granularity. Si especificas varios parámetros granularity, la API muestra todas las direcciones que coinciden con cualquiera de los niveles de detalle.

    El parámetro granularity no restringe la búsqueda a los niveles de detalle de la ubicación especificados. En cambio, granularity actúa como un filtro posterior a la búsqueda. La API recupera todos los resultados para la location especificada y, luego, descarta los resultados que no coinciden con los niveles de detalle de la ubicación especificados.

    Si especificas types y granularity, la API muestra solo los resultados que coinciden con ambos. Por ejemplo:

    https://geocode.googleapis.com/v4/geocode/location/37.4225508,-122.0846338?granularity=ROOFTOP&granularity=GEOMETRIC_CENTER&key=API_KEY
  • máquinas activas

    Uno o más tipos de direcciones, especificados como parámetros de búsqueda independientes. Los valores posibles se extraen de la tabla Tipos de dirección y tipos de componentes de dirección en la página Tipos de lugares (nuevo). Si especificas varios parámetros types, la API muestra todas las direcciones que coinciden con cualquiera de los tipos.

    El parámetro types no restringe la búsqueda a los tipos de direcciones especificados. En cambio, types actúa como un filtro posterior a la búsqueda. La API recupera todos los resultados para la ubicación especificada y, luego, descarta los resultados que no coinciden con los tipos de direcciones especificados.

    Si especificas types y granularity, la API muestra solo los resultados que coinciden con ambos. Por ejemplo:

    https://geocode.googleapis.com/v4/geocode/location/37.4225508,-122.0846338?types=administrative_area_level_2&types=locality&key=API_KEY
  • FieldMask

    Crea una máscara de campo de respuesta para especificar los campos que se deben mostrar en la respuesta. Pasa la máscara de campo de respuesta al método con el parámetro de URL $fields o fields, o con el encabezado HTTP X-Goog-FieldMask. Por ejemplo, la siguiente solicitud mostrará solo los campos placeID de la respuesta.

    curl -X GET -H 'Content-Type: application/json' \
    -H 'X-Goog-FieldMask: results.placeId' \
    -H "X-Goog-Api-Key: API_KEY" \
    "https://geocode.googleapis.com/v4/geocode/location/37.4225508,-122.0846338"
    
    La respuesta es la siguiente:
    {
      "results": [
        {
          "placeId": "ChIJHRNUiQK6j4ARJ__Hrbt6qsE"
        },
        {
          "placeId": "ChIJj38IfwK6j4ARNcyPDnEGa9g"
        },
        {
          "placeId": "ChIJ1yjFJ1-7j4ARG_RVqFD1h7k"
        },
        {
          "placeId": "ChIJ09H2YwK6j4ARoF7qfCBxhB8"
        },
        ...
      ]
    }

    Consulta Elige los campos que se mostrarán para obtener más detalles.