API reference - Points
If you know the discrete points you want to query, you can use the /v1/elevation/points endpoint to get the elevation above sea level of each location in a single request. POST requests are supported for large numbers of points.
Otherwise, GPXZ can evenly sample points along a path using the /v1/elevation/sample endpoint.
/v1/elevation/points
Query elevation at multiple multiple points. This is a batch version of /v1/elevation/point.
HTTP request
GET https://api.gpxz.io/v1/elevation/points?latlons=46.66,14.03|46.60,14.15
Example response
{
"results": [
{
"elevation": 951.740417,
"lat": 46.66,
"lon": 14.03,
"data_source": "austria_10m_dtm",
"resolution": 10
},
{
"elevation": 671.916199,
"lat": 46.6,
"lon": 14.15,
"data_source": "austria_10m_dtm",
"resolution": 10
}
],
"status": "OK"
}
Request query parameters
latlons
:latitude,longitude
pairs separated by a pipe.polyline
: Points encoded as a polyline. One oflatlons
orpolyline
must be provided.bathymetry
: iftrue
return distance below sea level for points on the ocean (i.e., elevation will be negative). Iffalse
return 0 for points on the ocean. Default:false
.interpolation
: which algorithm to use for interpolating between pixels in the underlying raster data.bilinear
is smoother if displaying multiple points, but is slower and may reduce the extremity of peaks and troughs. Options:nearest
,bilinear
. Default:bilinear
.
Response
A json object. Results are in the same order as the input points.
results[].elevation
: elevation in metres at the provided point.results[].lat
: parsed latitude.results[].lon
: parsed longitude.results[].data_source
: ID of the open data source was used to build this area of the GPXZ dataset. You can use this ID to lookup more details with the /v1/elevation/sources endpoint.results[].resolution
: approximate resolution in metres of the GPXZ dataset in this area.status
: will beOK
for successful request.
POST requests
When querying a large number of points in a single request, some software can't handle the length of the URL this
produces. To get around this limitation, you can also send POST requests to /v1/elevation/points
.
Request arguments should be provided as application/x-www-form-urlencoded
:
import requests
API_KEY = "ak_123456_abcdef"
data = {
'latlons': '40,91|-20,120',
'interpolation': 'nearest',
}
response = requests.post(
'https://api.gpxz.io/v1/elevation/points',
headers={'x-api-key': API_KEY},
data=data,
)
or as application/json
:
curl -X POST \
-H "Content-Type: application/json" \
-H "X-Api-Key: YOUR-API-KEY-HERE" \
-d '{"latlons": "40,91|-20,120", "interpolation": "nearest"}' \
https://api.gpxz.io/v1/elevation/points
/v1/elevation/sample
Query elevation at evenly spaced points sampled along a given path.
For example, if you gave irregularly-spaced GPS data and want to show an elevation profile, you would provide the GPS coordinates as the path, and get back elevation data you can plot directly.
The first and last points returned will be the first and last points of the provided path. Your path can be up to 5000 points long.
For more details about the sampling algorithm see Sampling points along a path.
HTTP request
GET https://api.gpxz.io/v1/elevation/sample?latlons=30.70,-82.22|30.70,-82.27&samples=4
Example response
{
"results": [
{
"elevation": 36.886948,
"lat": 30.7,
"lon": -82.22,
"data_source": "us_3dep_10m",
"resolution": 10
},
{
"elevation": 37.016758,
"lat": 30.700002138895783,
"lon": -82.23666666654412,
"data_source": "us_3dep_10m",
"resolution": 10
},
{
"elevation": 36.937859,
"lat": 30.700002138895783,
"lon": -82.25333333345586,
"data_source": "us_3dep_10m",
"resolution": 10
},
{
"elevation": 37.076237,
"lat": 30.7,
"lon": -82.27,
"data_source": "us_3dep_10m",
"resolution": 10
}
],
"status": "OK"
}
Request query parameters
latlons
:latitude,longitude
pairs separated by a pipe, representing the path to sample along.polyline
: Path points encoded as a polyline. One oflatlons
orpolyline
must be provided.samples
: Number of points to sample along the path. Must be at least 2. Required.bathymetry
: iftrue
return distance below sea level for points on the ocean (i.e., elevation will be negative). Iffalse
return 0 for points on the ocean. Default:false
.interpolation
: which algorithm to use for interpolating between pixels in the underlying raster data.bilinear
is smoother if displaying multiple points, but is slower and may reduce the extremity of peaks and troughs. Options:nearest
,bilinear
. Default:bilinear
.
Response
The response is the same as /v1/elevation/points.
POST requests
To avoid problems with URL length, you can send POST requests the same as /v1/elevation/points.