Yükseklik istekleri
Elevation API istekleri bir URL dizesi olarak oluşturulur. API, dünyadaki konumların yükseklik verilerini döndürür. Konum verilerini iki şekilde belirtebilirsiniz:
- Bir veya daha fazla
locationskümesi olarak. pathboyunca birbirine bağlı noktalar dizisi olarak.
Bu yaklaşımların her ikisinde de konumları veya yol köşelerini tanımlamak için enlem/boylam koordinatları kullanılır. Bu belgede, Elevation API URL'lerinin gerekli biçimi ve kullanılabilir parametreler açıklanmaktadır.
Elevation API, tek noktalı sorgular için mümkün olan en yüksek doğrulukta veriler döndürür. Birden fazla konum içeren toplu sorgular, özellikle konumlar birbirinden uzaksa verilerin bir kısmı düzeltildiğinden daha az doğru veriler döndürebilir.
Elevation API isteği aşağıdaki biçimde olur:
https://maps.googleapis.com/maps/api/elevation/outputFormat?parameters
burada outputFormat aşağıdaki değerlerden biri olabilir:
json(önerilir), çıktının JavaScript Object Notation (JSON) biçiminde olduğunu gösterir veyaxml, XML'deki çıktıyı gösterir ve<ElevationResponse>düğümü içinde sarmalanır.
Not: URL'lerin geçerli olması için düzgün şekilde kodlanması gerekir ve tüm web hizmetleri için 16.384 karakterle sınırlıdır. URL'lerinizi oluştururken bu sınıra dikkat edin. Farklı tarayıcıların, proxy'lerin ve sunucuların URL karakter sınırlarının da farklı olabileceğini unutmayın.
API anahtarı kullanan istekler için HTTPS gereklidir.
İstek parametreleri
Elevation API'ye yapılan isteklerde, isteğin ayrı konumlar için mi yoksa sıralı bir yol için mi olduğuna bağlı olarak farklı parametreler kullanılır. Ayrı konumlar için yükseklik istekleri, istekte iletilen belirli konumlara ilişkin verileri döndürür. Yollar için ise yükseklik istekleri, verilen yol boyunca örneklenir.
Tüm URL'lerde standart olduğu gibi, parametreler "ve" işareti (&) kullanılarak ayrılır. Parametrelerin listesi ve olası değerleri aşağıda belirtilmiştir.
Tüm istekler
key-- (zorunlu) Uygulamanızın API anahtarı. Bu anahtar, kota yönetimi amacıyla uygulamanızı tanımlar. Nasıl anahtar alacağınızı öğrenin.
Konumsal istekler
locations(zorunlu), yükseklik verilerinin döndürüleceği yerleri tanımlar. Bu parametre, virgülle ayrılmış {enlem,boylam} çifti olarak tek bir konum (ör. "40.714728,-73.998672") veya dizi ya da kodlanmış çoklu çizgi olarak iletilen birden fazla enlem/boylam çifti alır. Bu parametre için 512 puan sınırı vardır. Daha fazla bilgi için aşağıdaki Konumları Belirleme bölümünü inceleyin.
Örneklenen yol istekleri
path(zorunlu), yükseklik verilerinin döndürüleceği yeryüzündeki bir yolu tanımlar. Bu parametre, yeryüzünde bir yolu tanımlayan iki veya daha fazla sıralı {enlem,boylam} çiftini tanımlar. Bu parametre, aşağıda açıklanansamplesparametresiyle birlikte kullanılmalıdır. Bu parametre için 512 puan sınırı vardır. Daha fazla bilgi için aşağıdaki Yolları Belirtme bölümüne bakın.samples(zorunlu), bir yol boyunca yükseklik verilerinin döndürüleceği örnek nokta sayısını belirtir.samplesparametresi, verilenpathdeğerini yol boyunca eşit aralıklı noktaların sıralı bir kümesine böler.
Konumları belirtme
Konum istekleri, locations parametresi kullanılarak belirtilir. Bu parametre, enlem/boylam değerleri olarak iletilen belirli konumlar için yükseklik isteklerini gösterir.
locations parametresi aşağıdaki bağımsız değişkenleri alabilir:
- Tek bir koordinat:
locations=40.714728,-73.998672 - Dikey çizgi ("
|") karakteriyle ayrılmış bir koordinat dizisi:locations=40.714728,-73.998672|-34.397,150.644 - Encoded Polyline Algorithm kullanılarak kodlanmış bir dizi koordinat:
locations=enc:gfo}EtohhU
Enlem ve boylam koordinat dizeleri, virgülle ayrılmış bir metin dizesindeki rakamlar kullanılarak tanımlanır. Örneğin, "40.714728,-73.998672"
geçerli bir locations değeridir. Enlem ve boylam değerleri, yeryüzünde geçerli bir konuma karşılık gelmelidir. Enlem değerleri -90 ile 90 arasında, boylam değerleri ise -180 ile 180 arasında herhangi bir değer alabilir. Geçersiz bir enlem veya boylam değeri belirtirseniz isteğiniz hatalı istek olarak reddedilir.
Geçerli bir URL oluşturmaya devam ederken bir dizi veya kodlanmış çoklu çizgi içinde en fazla 512 koordinat iletebilirsiniz. Birden fazla koordinat iletilirken döndürülen verilerin doğruluğunun, tek bir koordinat için veri isteğinde bulunulduğunda elde edilen verilerin doğruluğundan daha düşük çözünürlüklü olabileceğini unutmayın. "locations" veya "path" parametrelerinde 512 noktayı ya da koordinatı aşmak INVALID_REQUEST yanıtı döndürür.
Yolları belirtme
Örneklenmiş yol istekleri, path ve samples parametreleri kullanılarak belirtilir. Bu parametreler, belirli aralıklarla bir yol boyunca yükseklik verileri isteğini gösterir. locations parametresinin kullanıldığı konumsal isteklerde olduğu gibi, path parametresi de bir dizi enlem ve boylam değeri belirtir. Ancak, konumsal bir isteğin aksine, path sıralı bir köşe kümesi belirtir. Yalnızca köşelerde yükseklik verileri döndürmek yerine, yol istekleri samples belirtilen sayıya (uç noktalar dahil) göre yolun uzunluğu boyunca örneklenir.
path parametresi aşağıdaki bağımsız değişkenlerden birini alabilir:
- Dikey çizgi ("
|") karakteriyle ayrılmış, virgülle ayrılmış iki veya daha fazla koordinat metni dizisi:path=40.714728,-73.998672|-34.397,150.644 - Encoded Polyline Algorithm kullanılarak kodlanmış koordinatlar:
path=enc:gfo}EtohhUxD@bAxJmGF
Enlem ve boylam koordinat dizeleri, virgülle ayrılmış bir metin dizesindeki rakamlar kullanılarak tanımlanır. Örneğin, "40.714728,-73.998672|-34.397,
150.644" geçerli bir path değeridir. Enlem ve boylam değerleri, yeryüzünde geçerli bir konuma karşılık gelmelidir. Enlem değerleri -90 ile 90 arasında, boylam değerleri ise -180 ile 180 arasında herhangi bir değeri alabilir. Geçersiz bir enlem veya boylam değeri belirtirseniz isteğiniz kötü istek olarak reddedilir.
Geçerli bir URL oluşturmaya devam ederken bir dizi veya kodlanmış çoklu çizgi içinde en fazla 512 koordinat iletebilirsiniz. Birden fazla koordinat iletilirken döndürülen verilerin doğruluğunun, tek bir koordinat için veri isteğinde bulunulduğunda elde edilen verilerin doğruluğundan daha düşük çözünürlüklü olabileceğini unutmayın. "locations" veya "path" parametrelerinde 512 noktayı ya da koordinatı aşmak INVALID_REQUEST yanıtı döndürür.
Yükseklik yanıtları
- Dikey çizgi ("
|") karakteriyle ayrılmış, virgülle ayrılmış iki veya daha fazla koordinat metni dizisi:path=40.714728,-73.998672|-34.397,150.644 - Encoded Polyline Algorithm kullanılarak kodlanmış koordinatlar:
path=enc:gfo}EtohhUxD@bAxJmGF
Enlem ve boylam koordinat dizeleri, virgülle ayrılmış bir metin dizesindeki rakamlar kullanılarak tanımlanır. Örneğin, "40.714728,-73.998672|-34.397,
150.644" geçerli bir path değeridir. Enlem ve boylam değerleri, yeryüzünde geçerli bir konuma karşılık gelmelidir. Enlemler -90 ile 90 arasında herhangi bir değeri alabilirken boylam değerleri -180 ile -180 arasında herhangi bir değeri alabilir. Geçersiz bir enlem veya boylam değeri belirtirseniz isteğiniz kötü istek olarak reddedilir.
Geçerli bir URL oluşturmaya devam ederken bir dizi veya kodlanmış çoklu çizgi içinde en fazla 512 koordinat iletebilirsiniz. Birden fazla koordinat iletilirken döndürülen verilerin doğruluğunun, tek bir koordinat için veri isteğinde bulunulduğunda elde edilen verilerin doğruluğundan daha düşük çözünürlüklü olabileceğini unutmayın. "locations" veya "path" parametrelerinde 512 noktayı ya da koordinatı aşmak INVALID_REQUEST yanıtı döndürür.
Yükseklik yanıtları
Yükseklik hizmeti, her geçerli istek için istek URL'sinde belirtilen biçimde bir yükseklik yanıtı döndürür.
ElevationResponse
| Alan | Zorunlu | Tür | Açıklama |
|---|---|---|---|
|
required | Array<ElevationResult> | Daha fazla bilgi için ElevationResult sayfasına bakın. |
|
required | ElevationStatus | Daha fazla bilgi için ElevationStatus'a bakın. |
|
isteğe bağlı | dize |
Hizmet |
ElevationStatus
Hizmet tarafından döndürülen durum kodları.
OK, API isteğinin başarılı olduğunu gösterir.DATA_NOT_AVAILABLE, giriş konumları için kullanılabilir veri olmadığını gösterir.INVALID_REQUEST, API isteğinin hatalı biçimlendirildiğini gösterir.OVER_DAILY_LIMITaşağıdakilerden herhangi birini gösteriyorsa:- API anahtarı eksik veya geçersiz.
- Hesabınızda faturalandırma etkinleştirilmemiştir.
- Kendiniz belirlediğiniz kullanım sınırı aşıldı.
- Belirtilen ödeme yöntemi artık geçerli değil (örneğin, kredi kartının süresi dolmuş).
OVER_QUERY_LIMIT, isteği gönderenin kotayı aştığını gösterir.REQUEST_DENIEDAPI'nin isteği tamamlamadığını gösterir.UNKNOWN_ERRORbilinmeyen bir hatayı gösterir.
Durum kodu OK dışında bir değer olduğunda, Elevation yanıt nesnesinde ek bir error_message alanı olabilir. Bu alan, verilen durum kodunun nedenleri hakkında daha ayrıntılı bilgiler içerir.
Yanıtta aşağıdaki öğeleri içeren bir results dizisi bulunur:
ElevationResult
| Alan | Zorunlu | Tür | Açıklama |
|---|---|---|---|
|
required | sayı |
Konumun metre cinsinden yüksekliği. |
|
required | LatLngLiteral |
Yükseklik verilerinin hesaplandığı konumun bir yer öğesi. Yol isteklerinde, konum öğeleri kümesinin yol boyunca örneklenmiş noktaları içereceğini unutmayın. Daha fazla bilgi için LatLngLiteral sayfasına bakın. |
|
isteğe bağlı | sayı |
Yüksekliğin enterpolasyonla hesaplandığı veri noktaları arasındaki maksimum mesafeyi metre cinsinden gösteren değer. Çözünürlük bilinmiyorsa bu özellik eksik olur. Birden fazla nokta iletildiğinde yükseklik verilerinin daha kaba (daha büyük çözünürlük değerleri) hale geldiğini unutmayın. Bir nokta için en doğru yükseklik değerini elde etmek istiyorsanız bu noktayı bağımsız olarak sorgulamanız gerekir. |
LatLngLiteral
Ondalık derece cinsinden enlem ve boylam içeren belirli bir konumu açıklayan bir nesne.
| Alan | Zorunlu | Tür | Açıklama |
|---|---|---|---|
|
required | sayı |
Ondalık derece cinsinden enlem |
|
required | sayı |
Ondalık derece cinsinden boylam |
Konumsal yükseklik örnekleri
Aşağıdaki örnekte, "Mile High City" (Bir Mil Yüksekliğindeki Şehir) olarak bilinen Denver, Colorado'nun yüksekliği istenmektedir:
URL
https://maps.googleapis.com/maps/api/elevation/json
?locations=39.7391536%2C-104.9847034
&key=YOUR_API_KEY
cURL
curl -L -X GET 'https://maps.googleapis.com/maps/api/elevation/json?locations=39.7391536%2C-104.9847034&key=YOUR_API_KEY'
JSON
{ "results": [ { "elevation": 1608.637939453125, "location": { "lat": 39.7391536, "lng": -104.9847034 }, "resolution": 4.771975994110107, }, ], "status": "OK", }
XML
<ElevationResponse> <status>OK</status> <result> <location> <lat>39.7391536</lat> <lng>-104.9847034</lng> </location> <elevation>1608.6379395</elevation> <resolution>4.7719760</resolution> </result> </ElevationResponse>
Aşağıdaki örnekte birden fazla yanıt (Denver, CO ve Death Valley, CA için) gösterilmektedir.
Bu istekte, JSON output işaretinin kullanımı gösterilmektedir:
URL
https://maps.googleapis.com/maps/api/elevation/json
?locations=39.7391536%2C-104.9847034%7C36.455556%2C-116.866667
&key=YOUR_API_KEY
cURL
curl -L -X GET 'https://maps.googleapis.com/maps/api/elevation/json?locations=39.7391536%2C-104.9847034%7C36.455556%2C-116.866667&key=YOUR_API_KEY'
Bu istekte, XML output işaretinin kullanımı gösterilmektedir:
https://maps.googleapis.com/maps/api/elevation/xml?locations=39.7391536,-104.9847034|36.455556,-116.866667&key=YOUR_API_KEY
Örnek JSON ve XML yanıtlarını görmek için aşağıdaki sekmeleri seçin.
JSON
{ "results": [ { "elevation": 1608.637939453125, "location": { "lat": 39.7391536, "lng": -104.9847034 }, "resolution": 4.771975994110107, }, { "elevation": -52.79492568969727, "location": { "lat": 36.455556, "lng": -116.866667 }, "resolution": 19.08790397644043, }, ], "status": "OK", }
XML
<ElevationResponse> <status>OK</status> <result> <location> <lat>39.7391536</lat> <lng>-104.9847034</lng> </location> <elevation>1608.6379395</elevation> <resolution>4.7719760</resolution> </result> <result> <location> <lat>36.4555560</lat> <lng>-116.8666670</lng> </location> <elevation>-52.7949257</elevation> <resolution>19.0879040</resolution> </result> </ElevationResponse>
Aşağıdaki örneklerde, ABD'nin en yüksek ve en alçak noktaları olan Kaliforniya'daki Whitney Dağı'ndan Kaliforniya'daki Badwater'a path düz bir çizgi boyunca yükseklik verileri istenmektedir. Üç samples istiyoruz. Bu nedenle iki uç nokta ve yarı yol noktası dahil edilir.
URL
https://maps.googleapis.com/maps/api/elevation/json ?path=36.578581%2C-118.291994%7C36.23998%2C-116.83171 &samples=3 &key=YOUR_API_KEY
cURL
curl -L -X GET 'https://maps.googleapis.com/maps/api/elevation/json?path=36.578581%2C-118.291994%7C36.23998%2C-116.83171&samples=3&key=YOUR_API_KEY'
JSON
{ "results": [ { "elevation": 4411.94189453125, "location": { "lat": 36.578581, "lng": -118.291994 }, "resolution": 19.08790397644043, }, { "elevation": 1372.8359375, "location": { "lat": 36.41150289067028, "lng": -117.5602607523847 }, "resolution": 9.543951988220215, }, { "elevation": -84.51690673828125, "location": { "lat": 36.23998, "lng": -116.83171 }, "resolution": 9.543951988220215, }, ], "status": "OK", }
XML
<ElevationResponse> <status>OK</status> <result> <location> <lat>36.5785810</lat> <lng>-118.2919940</lng> </location> <elevation>4411.9418945</elevation> <resolution>19.0879040</resolution> </result> <result> <location> <lat>36.4115029</lat> <lng>-117.5602608</lng> </location> <elevation>1372.8359375</elevation> <resolution>9.5439520</resolution> </result> <result> <location> <lat>36.2399800</lat> <lng>-116.8317100</lng> </location> <elevation>-84.5169067</elevation> <resolution>9.5439520</resolution> </result> </ElevationResponse>