Odwrotne geokodowanie przekształca lokalizację na mapie w adres zrozumiały dla człowieka. Lokalizację na mapie reprezentujesz za pomocą współrzędnych geograficznych (szerokości i długości geograficznej).
Gdy wykonujesz odwrotne geokodowanie lokalizacji, odpowiedź zawiera:
- Identyfikator miejsca adresu
- kody Plus Code adresu,
- Szczegóły adresu
Ten interfejs API zwraca różne typy adresów, od najbardziej szczegółowych adresów ulic po mniej szczegółowe jednostki polityczne, takie jak dzielnice, miasta, hrabstwa i stany. Najdokładniejszy adres jest zwykle pierwszym wynikiem. Jeśli chcesz dopasować określony typ adresu, użyj parametru types.
Żądanie odwrotnego geokodowania
Żądanie odwrotnego geokodowania to żądanie HTTP GET. Lokalizację możesz podać jako nieustrukturyzowany ciąg znaków:
https://geocode.googleapis.com/v4beta/geocode/location/LATITUDE,LONGITUDE
lub jako strukturalny zestaw współrzędnych geograficznych (szerokości i długości) reprezentowanych przez parametry zapytania:
https://geocode.googleapis.com/v4beta/geocode/location?location.latitude=LATITUDE&location.longitude=LONGITUDE
Format strukturalny jest zwykle używany podczas przetwarzania komponentów lokalizacji przechwytywanych w formularzu HTML.
Wszystkie pozostałe parametry przekazuj jako parametry adresu URL lub w przypadku parametrów takich jak klucz interfejsu API czy maska pola w nagłówkach w ramach żądania GET. Na przykład:
Przekazywanie nieustrukturyzowanego ciągu znaków lokalizacji
Nieustrukturyzowana lokalizacja to lokalizacja sformatowana jako ciąg znaków zawierający rozdzielone przecinkami współrzędne szerokości i długości geograficznej:
https://geocode.googleapis.com/v4beta/geocode/location/37.4225508,-122.0846338?key=API_KEY
Możesz też użyć polecenia curl:
curl -X GET -H 'Content-Type: application/json' \ -H "X-Goog-Api-Key: API_KEY" \ "https://geocode.googleapis.com/v4beta/geocode/location/37.4225508,-122.0846338"
Przekazywanie lokalizacji strukturalnej
Określ lokalizację strukturalną za pomocą parametru zapytania location typu LatLng.
Obiekt LatLng umożliwia określenie szerokości i długości geograficznej jako oddzielnych parametrów zapytania:
https://geocode.googleapis.com/v4beta/geocode/location?location.latitude=37.4225508&location.longitude=-122.0846338 &key=API_KEY
Wysyłanie żądania za pomocą protokołu OAuth
Interfejs Geocoding API w wersji 4 obsługuje OAuth 2.0 na potrzeby uwierzytelniania. Aby używać protokołu OAuth z interfejsem Geocoding API, token OAuth musi mieć przypisany odpowiedni zakres. Interfejs Geocoding API obsługuje te zakresy do użycia z odwrotnym geokodowaniem:
https://www.googleapis.com/auth/maps-platform.geocode– używaj ze wszystkimi punktami końcowymi Geocoding API.https://www.googleapis.com/auth/maps-platform.geocode.location– używaj tylko z parametremGeocodeLocationdo odwrotnego geokodowania.
Możesz też użyć ogólnego https://www.googleapis.com/auth/cloud-platformzakresu dla wszystkich punktów końcowych interfejsu Geocoding API. Ten zakres jest przydatny podczas programowania, ale nie w środowisku produkcyjnym, ponieważ jest to zakres ogólny, który umożliwia dostęp do wszystkich punktów końcowych.
Więcej informacji i przykładów znajdziesz w artykule Korzystanie z OAuth.
Odpowiedź odwrotnego geokodowania
Odwrotne geokodowanie zwraca obiektGeocodeLocationResponse, który zawiera:
Tablica
resultsobiektówGeocodeResult, która reprezentuje miejsce.Geokoder zwrotny zwraca więcej niż jeden wynik w tablicy
results. Wyniki to nie tylko adresy pocztowe, ale też inne sposoby geograficznego określania lokalizacji. Na przykład podczas geokodowania punktu w Chicago może on być oznaczony jako adres ulicy, miasto (Chicago), stan (Illinois) lub kraj (Stany Zjednoczone). Wszystkie te elementy są dla geokodera „adresami”. Geokoder zwrotny zwraca dowolny z tych typów jako prawidłowy wynik.Pole
plusCodetypuPlusCodezawiera kod Plus Code, który najlepiej przybliża szerokość i długość geograficzną w żądaniu. Dodatkowo każdy element tablicyresultszawiera kod plus. Odległość między zdekodowanym kodem plus a punktem żądania wynosi mniej niż 10 metrów.
Pełny obiekt JSON ma postać:
{ "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" } }
Wymagane parametry
lokalizacja
Współrzędne szerokości i długości geograficznej określające miejsce, dla którego chcesz uzyskać najbliższy adres w formacie czytelnym dla człowieka.
Parametry opcjonalne
languageCode
Język, w którym mają być zwracane wyniki.
- Zobacz listę obsługiwanych języków. Google często aktualizuje listę obsługiwanych języków, więc może ona nie być kompletna.
-
Jeśli nie podasz wartości
languageCode, interfejs API domyślnie użyje wartościen. Jeśli podasz nieprawidłowy kod języka, interfejs API zwróci błądINVALID_ARGUMENT. - Interfejs API stara się podać adres ulicy, który jest czytelny zarówno dla użytkownika, jak i mieszkańców. Aby to osiągnąć, zwraca adresy w języku lokalnym, a w razie potrzeby transliteruje je na pismo czytelne dla użytkownika, uwzględniając preferowany język. Wszystkie pozostałe adresy są zwracane w preferowanym języku. Wszystkie komponenty adresu są zwracane w tym samym języku, który jest wybierany na podstawie pierwszego komponentu.
- Jeśli nazwa nie jest dostępna w preferowanym języku, interfejs API użyje najbliższego dopasowania.
- Preferowany język ma niewielki wpływ na zestaw wyników, które interfejs API wybiera do zwrócenia, oraz na kolejność, w jakiej są one zwracane. Geokoder interpretuje skróty w różny sposób w zależności od języka, np. skróty typów ulic lub synonimy, które mogą być prawidłowe w jednym języku, ale nie w innym.
regionCode
Kod regionu jako dwuznakowy kod CLDR. Nie ma wartości domyślnej. Większość kodów CLDR jest identyczna z kodami ISO 3166-1.
Podczas geokodowania adresu, czyli geokodowania do przodu, ten parametr może wpływać na wyniki usługi, ale nie może ich w pełni ograniczać do określonego regionu. Podczas geokodowania lokalizacji lub miejsca, odwrotnego geokodowania lub geokodowania miejsca ten parametr może służyć do formatowania adresu. W każdym przypadku ten parametr może wpływać na wyniki na podstawie obowiązujących przepisów.
szczegółowość,
Co najmniej jeden poziom szczegółowości lokalizacji określony jako oddzielne parametry zapytania zgodnie z definicją w
Granularity. Jeśli podasz kilka parametrówgranularity, interfejs API zwróci wszystkie adresy, które pasują do dowolnego z tych poziomów szczegółowości.Parametr
granularitynie ogranicza wyszukiwania do określonych poziomów szczegółowości lokalizacji.granularitydziała jako filtr po wyszukiwaniu. Interfejs API pobiera wszystkie wyniki dla określonego parametrulocation, a następnie odrzuca te wyniki, które nie pasują do określonych poziomów szczegółowości lokalizacji.Jeśli określisz zarówno
types, jak igranularity, interfejs API zwróci tylko te wyniki, które pasują do obu tych warunków. Na przykład:https://geocode.googleapis.com/v4beta/geocode/location/37.4225508,-122.0846338?granularity=ROOFTOP
&granularity=GEOMETRIC_CENTER &key=API_KEY typy
Co najmniej 1 typ adresu określony jako osobny parametr zapytania. Jeśli podasz kilka parametrów
types, interfejs API zwróci wszystkie adresy, które pasują do dowolnego z tych typów.Parametr
typesnie ogranicza wyszukiwania do określonych typów adresów.typesdziała jako filtr po wyszukiwaniu. Interfejs API pobiera wszystkie wyniki dla określonej lokalizacji, a następnie odrzuca te, które nie pasują do określonych typów adresów.Jeśli określisz zarówno
types, jak igranularity, interfejs API zwróci tylko te wyniki, które pasują do obu tych warunków. Na przykład:https://geocode.googleapis.com/v4beta/geocode/location/37.4225508,-122.0846338?types=administrative_area_level_2
&types=locality &key=API_KEY Obsługiwane są wartości:
Typy adresów i typy komponentów adresu
Tablica
typesw treściGeocodeResultw odpowiedzi wskazuje typ adresu. Przykłady typów adresów to adres ulicy, kraj lub jednostka polityczna. Tablicatypesw poluAddressComponentstreściGeocodeResultwskazuje typ każdej części adresu. Mogą to być np. numer ulicy lub kraj.Adresy mogą mieć wiele typów. Typy te można uznać za „tagi”. Na przykład wiele miast jest oznaczonych typami
politicalilocality.Obsługiwane są te typy, które są zwracane w tablicach typów adresów i typów komponentów adresu:
Typ adresu Opis street_addressdokładny adres. routeNazwa trasy (np. „US 101”). intersectionGłówne skrzyżowanie, zwykle dwóch głównych dróg. politicalpodmiot polityczny; Zwykle ten typ wskazuje wielokąt przedstawiający jakąś jednostkę administracji cywilnej. countryNarodowy podmiot polityczny, zwykle najwyższy typ zwracany przez geokoder. administrative_area_level_1Jednostka administracyjna pierwszego rzędu poniżej poziomu kraju. W Stanach Zjednoczonych są to stany. Nie wszystkie kraje mają te poziomy administracyjne. W większości przypadków administrative_area_level_1krótkie nazwy będą ściśle odpowiadać podziałom ISO 3166-2 i innym powszechnie używanym listom, ale nie jest to gwarantowane, ponieważ nasze wyniki geokodowania są oparte na różnych sygnałach i danych o lokalizacji.administrative_area_level_2Jednostka administracyjna drugiego rzędu poniżej poziomu kraju. W Stanach Zjednoczonych są to hrabstwa. Nie wszystkie kraje mają te poziomy administracyjne. administrative_area_level_3Jednostka administracyjna trzeciego rzędu poniżej poziomu kraju. Ten typ wskazuje na mniejszy podział administracyjny. Nie wszystkie kraje mają te poziomy administracyjne. administrative_area_level_4Jednostka administracyjna czwartego rzędu poniżej poziomu kraju. Ten typ wskazuje na mniejszy podział administracyjny. Nie wszystkie kraje mają te poziomy administracyjne. administrative_area_level_5Jednostka administracyjna piątego rzędu poniżej poziomu kraju. Ten typ wskazuje na mniejszy podział administracyjny. Nie wszystkie kraje mają te poziomy administracyjne. administrative_area_level_6Jednostka administracyjna szóstego rzędu poniżej poziomu kraju. Ten typ wskazuje na mniejszy podział administracyjny. Nie wszystkie kraje mają te poziomy administracyjne. administrative_area_level_7Jednostka administracyjna siódmego rzędu poniżej poziomu kraju. Ten typ wskazuje na mniejszy podział administracyjny. Nie wszystkie kraje mają te poziomy administracyjne. colloquial_areaPowszechnie używana nazwa alternatywna elementu. localitypodmiot polityczny w postaci miasta lub miejscowości; sublocalityJednostka administracyjna pierwszego rzędu poniżej miejscowości. W przypadku niektórych lokalizacji może być wyświetlany jeden z dodatkowych typów: sublocality_level_1–sublocality_level_5. Każdy poziom podlokalizacji jest jednostką administracyjną. Im większa liczba, tym mniejszy obszar geograficzny.neighborhoodNazwana okolica. premiseNazwana lokalizacja, zwykle budynek lub zespół budynków o wspólnej nazwie. subpremiseAdresowalny obiekt poniżej poziomu budynku, np. mieszkanie, lokal lub apartament. plus_codeZakodowany odnośnik do lokalizacji, który jest wyznaczany na podstawie szerokości i długości geograficznej. Kody Plus Code mogą zastępować adresy w miejscach, w których nie istnieją (gdzie budynki nie mają numerów lub ulice nie mają nazw). Więcej informacji znajdziesz na https://plus.codes. postal_codeKod pocztowy używany do adresowania przesyłek pocztowych na terenie danego kraju. natural_featurewyraźny obiekt naturalny, airportlotnisko, parkNazwany park. point_of_interestNazwane ciekawe miejsce. Zazwyczaj są to ważne lokalne obiekty, które nie pasują do żadnej innej kategorii, np. „Empire State Building” lub „Wieża Eiffla”. Pusta lista typów oznacza, że dla danego komponentu adresu nie ma znanych typów (np. Lieu-dit we Francji).