Permintaan dan respons geocoding terbalik (pencarian alamat)

Istilah geocoding umumnya mengacu pada proses menerjemahkan kode ke suatu lokasi pada peta. Proses melakukan hal yang sebaliknya, menerjemahkan lokasi pada peta menjadi alamat yang dapat dibaca manusia, dikenal sebagai geocoding terbalik.

Membalikkan permintaan geocoding

Parameter wajib

  • latlng — Lintang dan bujur yang menentukan lokasi yang Anda inginkan terdekat, yang dapat dibaca manusia.
  • key — Kunci API aplikasi Anda. Kunci ini mengidentifikasi aplikasi Anda untuk tujuan manajemen kuota. Pelajari cara mendapatkan kunci.

Parameter opsional

Ini adalah parameter opsional yang dapat Anda sertakan dalam metode permintaan geocoding:

  • language — Bahasa yang digunakan untuk menampilkan hasil.
    • Lihat daftar layanan yang didukung bahasa. Google sering memperbarui bahasa yang didukung, sehingga mungkin tidak lengkap.
    • Jika language tidak diberikan, geocoder akan mencoba untuk gunakan bahasa pilihan seperti yang ditentukan dalam header Accept-Language, atau bahasa asli domain tempat permintaan dikirim.
    • Geocoder akan melakukan yang terbaik untuk menyediakan alamat yang dapat dibaca oleh pengguna dan lokal. Untuk mencapai sasaran tersebut, mengembalikan alamat dalam bahasa lokal, ditransliterasi ke skrip yang dapat dibaca oleh pengguna jika diperlukan, dengan mengamati di bahasa target. Semua alamat lain dikembalikan ke instance di bahasa target. Semua komponen alamat dikembalikan dalam bahasa yang sama, yang dipilih dari komponen pertama.
    • Jika sebuah nama tidak tersedia dalam bahasa yang dipilih, geocoder akan menggunakan padanan terdekat.
  • region — Kode wilayah, yang ditetapkan sebagai ccTLD nilai yang terdiri dari dua karakter ("domain level teratas"). Parameter ini juga bisa memengaruhi hasil penelusuran berdasarkan hukum yang berlaku.
  • result_type — Filter dari satu atau beberapa jenis alamat, dipisahkan oleh pipa (|). Jika parameter berisi beberapa jenis alamat, API akan menampilkan semua alamat yang cocok dengan jenis mana pun. Catatan tentang pemrosesan: Parameter result_type tidak membatasi penelusuran ke jenis alamat yang ditentukan. Sebaliknya, result_type bertindak sebagai filter pasca-penelusuran: API mengambil semua hasil untuk latlng yang ditentukan, lalu menghapus hasil tersebut tidak cocok dengan jenis alamat yang ditetapkan. Nilai berikut didukung:
    • street_address menunjukkan alamat yang akurat.
    • route menunjukkan rute yang telah diberi nama (seperti "US 101").
    • intersection menunjukkan persimpangan utama, biasanya persimpangan dua jalan utama.
    • political menunjukkan entitas politik. Biasanya, jenis ini menunjukkan poligon dari pemerintahan sipil tertentu.
    • country menunjukkan entitas politik nasional, dan biasanya merupakan jenis urutan tertinggi yang ditampilkan oleh Geocoder.
    • administrative_area_level_1 menunjukkan entitas sipil urutan pertama di bawah tingkat negara. Di Amerika Serikat, tingkat administratif ini adalah negara bagian. Tidak semua negara memiliki tingkat administratif ini. Di hampir semua kasus, nama pendek administrative_area_level_1 akan hampir cocok dengan subdivisi ISO 3166-2 dan daftar lainnya yang beredar luas; akan tetapi, hal ini bukan jaminan karena hasil geocoding kita didasarkan pada aneka macam sinyal dan data lokasi.
    • administrative_area_level_2 menunjukkan entitas sipil urutan kedua di bawah tingkat negara. Di Amerika Serikat, tingkat administratif ini adalah county. Tidak semua negara memiliki tingkat administratif ini.
    • administrative_area_level_3 menunjukkan entitas sipil urutan ketiga di bawah tingkat negara. Jenis ini menunjukkan divisi sipil kecil. Tidak semua negara memiliki tingkat administratif ini.
    • administrative_area_level_4 menunjukkan entitas sipil urutan keempat di bawah tingkat negara. Jenis ini menunjukkan divisi sipil kecil. Tidak semua negara memiliki tingkat administratif ini.
    • administrative_area_level_5 menunjukkan entitas sipil urutan kelima di bawah tingkat negara. Jenis ini menunjukkan divisi sipil kecil. Tidak semua negara memiliki tingkat administratif ini.
    • administrative_area_level_6 menunjukkan entitas sipil urutan keenam di bawah tingkat negara. Jenis ini menunjukkan divisi sipil kecil. Tidak semua negara memiliki tingkat administratif ini.
    • administrative_area_level_7 menunjukkan entitas sipil urutan ketujuh di bawah tingkat negara. Jenis ini menunjukkan divisi sipil kecil. Tidak semua negara memiliki tingkat administratif ini.
    • colloquial_area menunjukkan nama alternatif yang biasa digunakan untuk entitas.
    • locality menunjukkan gabungan entitas politik kota besar atau kota kecil.
    • sublocality menunjukkan entitas sipil urutan pertama di bawah lokalitas. Beberapa lokasi dapat menerima salah satu dari jenis tambahan: sublocality_level_1 hingga sublocality_level_5. Setiap tingkat sublokalitas adalah entitas sipil. Angka yang lebih besar menunjukkan area geografis yang lebih kecil.
    • neighborhood menunjukkan daerah sekitar yang telah diberi nama
    • premise menunjukkan lokasi yang telah diberi nama, biasanya bangunan atau sekumpulan bangunan dengan nama umum
    • subpremise menunjukkan entitas urutan pertama di bawah lokasi yang telah diberi nama, biasanya sebuah bangunan dalam sekumpulan bangunan dengan nama umum
    • plus_code menunjukkan referensi lokasi yang dienkode, yang berasal dari lintang dan bujur. Plus Codes dapat digunakan sebagai pengganti alamat di tempat tanpa alamat jelas (jika bangunan tidak diberi nomor atau jalan tidak diberi nama). Lihat https://plus.codes untuk mengetahui detailnya.
    • postal_code menunjukkan kode pos seperti yang biasa digunakan untuk penulisan alamat pos dalam negara tersebut.
    • natural_feature menunjukkan fitur alam terkemuka.
    • airport menunjukkan bandara.
    • park menunjukkan taman yang telah diberi nama.
    • point_of_interest menunjukkan lokasi menarik yang telah diberi nama. Biasanya, "POI" ini adalah entitas lokal terkenal yang tidak mudah dimasukkan ke dalam kategori lain, seperti "Empire State Building" atau "Eiffel Tower".
  • location_type — Filter dari satu atau beberapa jenis lokasi, dipisahkan oleh pipa (|). Jika parameter berisi beberapa jenis lokasi, API akan menampilkan semua alamat yang cocok dengan jenis mana pun. Catatan tentang pemrosesan: Parameter location_type tidak membatasi penelusuran ke jenis lokasi yang ditentukan. Sebaliknya, location_type bertindak sebagai filter pasca-penelusuran: API mengambil semua hasil untuk latlng yang ditentukan, kemudian menghapus hasil tersebut yang tidak sesuai dengan jenis lokasi yang ditentukan. Nilai-nilai berikut ini didukung:
    • "ROOFTOP" hanya menampilkan alamat yang memiliki informasi lokasi yang akurat hingga ke alamat yang tepat.
    • "RANGE_INTERPOLATED" hanya menampilkan alamat yang mencerminkan perkiraan (biasanya di jalan) interpolasi antara dua titik akurat (seperti persimpangan). Rentang terinterpolasi umumnya menunjukkan bahwa geocode atap tidak tersedia untuk alamat jalan.
    • "GEOMETRIC_CENTER" hanya menampilkan nilai geometris pusat lokasi seperti polyline (misalnya, jalan) atau poligon (region).
    • "APPROXIMATE" hanya menampilkan alamat yang ditunjukkan sebagai perkiraan.
  • extra_computations — Gunakan parameter ini untuk menentukan fitur tambahan berikut ini dalam responsnya: Untuk mengaktifkan beberapa fitur ini untuk permintaan API yang sama, sertakan atribut extra_computations dalam permintaan untuk setiap fitur, misalnya:
    extra_computations=ADDRESS_DESCRIPTORS&extra_computations=BUILDING_AND_ENTRANCES

Jika filter result_type dan location_type ada, berarti API hanya menampilkan hasil yang cocok dengan result_type dan location_type nilai. Jika tidak ada nilai filter yang dapat diterima, API menampilkan ZERO_RESULTS.

Contoh geocoding terbalik

Kueri berikut berisi nilai garis lintang/garis bujur untuk lokasi di Brooklyn:

https://maps.googleapis.com/maps/api/geocode/json?latlng=40.714224,-73.961452&key=YOUR_API_KEY

Kueri di atas mengembalikan hasil berikut:

{
   "results" : [
      {
         "address_components" : [
            {
               "long_name" : "277",
               "short_name" : "277",
               "types" : [ "street_number" ]
            },
            {
               "long_name" : "Bedford Avenue",
               "short_name" : "Bedford Ave",
               "types" : [ "route" ]
            },
            {
               "long_name" : "Williamsburg",
               "short_name" : "Williamsburg",
               "types" : [ "neighborhood", "political" ]
            },
            {
               "long_name" : "Brooklyn",
               "short_name" : "Brooklyn",
               "types" : [ "sublocality", "political" ]
            },
            {
               "long_name" : "Kings",
               "short_name" : "Kings",
               "types" : [ "administrative_area_level_2", "political" ]
            },
            {
               "long_name" : "New York",
               "short_name" : "NY",
               "types" : [ "administrative_area_level_1", "political" ]
            },
            {
               "long_name" : "United States",
               "short_name" : "US",
               "types" : [ "country", "political" ]
            },
            {
               "long_name" : "11211",
               "short_name" : "11211",
               "types" : [ "postal_code" ]
            }
         ],
         "formatted_address" : "277 Bedford Avenue, Brooklyn, NY 11211, USA",
         "geometry" : {
            "location" : {
               "lat" : 40.714232,
               "lng" : -73.9612889
            },
            "location_type" : "ROOFTOP",
            "viewport" : {
               "northeast" : {
                  "lat" : 40.7155809802915,
                  "lng" : -73.9599399197085
               },
               "southwest" : {
                  "lat" : 40.7128830197085,
                  "lng" : -73.96263788029151
               }
            }
         },
         "place_id" : "ChIJd8BlQ2BZwokRAFUEcm_qrcA",
         "types" : [ "street_address" ]
      },

  ... Additional <code>results[]</code> ...

Perhatikan, geocoder terbalik akan mengembalikan lebih dari satu hasil. Tujuan Hasil "formatted_address" bukan hanya alamat pos, melainkan cara apa pun untuk menamai lokasi secara geografis. Misalnya, saat melakukan geocoding terhadap suatu titik di kota Chicago, titik yang diberi geocode dapat dilambangkan sebagai alamat jalan, sebagai kota (Chicago), sebagai negara bagian (Illinois), atau sebagai negara (Amerika Serikat Negara Bagian). Semua adalah "alamat" ke geocoder tersebut. Geocoder terbalik akan menampilkan salah satu dari jenis ini sebagai hasil yang valid.

Geocoder terbalik akan mencocokkan entitas politik (negara, provinsi, kota dan kawasan), alamat jalan, dan kode pos.

Daftar lengkap nilai formatted_address yang ditampilkan oleh kueri sebelumnya ditampilkan di bawah ini.

{
   "plus_code" : {
      "compound_code" : "P27Q+MCM New York, NY, USA",
      "global_code" : "87G8P27Q+MCM"
   },
   "results" : [
      {
         "formatted_address" : "277 Bedford Ave, Brooklyn, NY 11211, USA",
         ...
         "types" : [ "street_address" ]
      },
      {
         "formatted_address" : "279 Bedford Ave, Brooklyn, NY 11211, USA",
         ...
         "types" : [ "premise" ]
      },
      {
         "formatted_address" : "277 Bedford Ave, Brooklyn, NY 11211, USA",
         ...
         "types" : [ "establishment", "point_of_interest" ]
      },
      {
         "formatted_address" : "291-275 Bedford Ave, Brooklyn, NY 11211, USA",
         ...
         "types" : [ "route" ]
      },
      {
         "formatted_address" : "P27Q+MC New York, NY, USA",
         ...
         "types" : [ "plus_code" ]
      },
      {
         "formatted_address" : "South Williamsburg, Brooklyn, NY, USA",
         ...
         "types" : [ "neighborhood", "political" ]
      },
      {
         "formatted_address" : "Brooklyn, NY 11211, USA",
         ...
         "types" : [ "postal_code" ]
      },
      {
         "formatted_address" : "Williamsburg, Brooklyn, NY, USA",
         ...
         "types" : [ "neighborhood", "political" ]
      },
      {
         "formatted_address" : "Kings County, Brooklyn, NY, USA",
         ...
         "types" : [ "administrative_area_level_2", "political" ]
      },
      {
         "formatted_address" : "Brooklyn, NY, USA",
         ...
         "types" : [ "political", "sublocality", "sublocality_level_1" ]
      },
      {
         "formatted_address" : "New York, NY, USA",
         ...
         "types" : [ "locality", "political" ]
      },
      {
         "formatted_address" : "New York, USA",
         ...
         "types" : [ "administrative_area_level_1", "political" ]
      },
      {
         "formatted_address" : "United States",
         ...
         "types" : [ "country", "political" ]
      }
   ],
   "status" : "OK"
}

API ini menampilkan berbagai jenis alamat, dari jenis alamat yang alamat ke entitas politik yang kurang spesifik seperti lingkungan, kota, county, dan negara bagian. Alamat yang lebih tepat umumnya hasil yang menonjol, seperti dalam kasus ini. Jika ingin mencocokkan jenis alamat IP eksternal, lihat bagian di bawah tentang membatasi hasil menurut jenis. Karena itu, lokasi hasil relatif terhadap satu sama lain dapat bervariasi.

Geocoding terbalik yang difilter menurut jenis

Contoh berikut memfilter alamat yang ditampilkan agar hanya menyertakan alamat dengan jenis lokasi ROOFTOP dan jenis alamat street_address.

https://maps.googleapis.com/maps/api/geocode/json?latlng=40.714224,-73.961452
&location_type=ROOFTOP&result_type=street_address&key=YOUR_API_KEY

Catatan: Filter ini hanya berlaku untuk geocoding terbalik.

Respons geocoding terbalik

Format respons geocoding terbalik sama dengan Geocoding yang dihasilkan. Lihat Respons Geocoding. Di bawah ini adalah kode status yang mungkin dalam respons geocoding terbalik.

Kode status geocoding terbalik

Kolom "status" dalam objek respons Geocoding berisi status permintaan, dan mungkin berisi informasi proses debug untuk membantu Anda melacak mengapa geocoding terbalik tidak berfungsi. "status" dapat berisi nilai berikut:

  • "OK" menunjukkan bahwa tidak terjadi error dan setidaknya satu alamat dikembalikan.
  • "ZERO_RESULTS" menunjukkan bahwa geocoding terbalik berhasil, tetapi tidak memberikan hasil. Hal ini dapat terjadi jika geocoder meneruskan latlng di lokasi terpencil.
  • "OVER_QUERY_LIMIT" menunjukkan bahwa Anda melebihi batas kuota tambahan.
  • "REQUEST_DENIED" menunjukkan permintaan ditolak. Mungkin karena permintaan menyertakan result_type atau location_type, tetapi tidak menyertakan kunci API.
  • "INVALID_REQUEST" secara umum menunjukkan salah satu dari hal berikut:
    • Kueri (address, components, atau latlng) tidak ada.
    • result_type atau location_type yang tidak valid adalah diberikan.
  • "UNKNOWN_ERROR" menunjukkan bahwa permintaan tidak dapat diproses karena error server. Permintaan mungkin berhasil jika Anda mencoba lagi.

Geocoding terbalik kode plus

Kolom plus_code dalam respons Geocoding berisi kode plus yang paling mendekati garis lintang dan bujur yang dikueri. Selain itu, larik hasil JSON biasanya berisi Geocoding lengkap hasil dengan jenis plus_code dan alamat yang berisi tanda tambah pada kode sumber. Jarak antara kode plus yang didekode dan titik permintaan adalah dijamin di bawah 10 meter.