com.google.maps.ElevationApi Maven / Gradle / Ivy
/*
* Copyright 2014 Google Inc. All rights reserved.
*
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this
* file except in compliance with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
* ANY KIND, either express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package com.google.maps;
import static com.google.maps.internal.StringJoin.join;
import com.google.maps.errors.ApiException;
import com.google.maps.internal.ApiConfig;
import com.google.maps.internal.ApiResponse;
import com.google.maps.internal.PolylineEncoding;
import com.google.maps.model.ElevationResult;
import com.google.maps.model.EncodedPolyline;
import com.google.maps.model.LatLng;
/**
* The Google Elevation API provides a simple interface to query locations on the earth for
* elevation data. Additionally, you may request sampled elevation data along paths, allowing you to
* calculate elevation changes along routes.
*
* See the Google Maps
* Elevation API documentation.
*/
public class ElevationApi {
private static final ApiConfig API_CONFIG = new ApiConfig("/maps/api/elevation/json");
private ElevationApi() {}
/**
* Gets a list of elevations for a list of points.
*
* @param context The {@link GeoApiContext} to make requests through.
* @param points The points to retrieve elevations for.
* @return The elevations as a {@link PendingResult}.
*/
public static PendingResult getByPoints(
GeoApiContext context, LatLng... points) {
return context.get(API_CONFIG, MultiResponse.class, "locations", shortestParam(points));
}
/**
* See
* documentation.
*
* @param context The {@link GeoApiContext} to make requests through.
* @param samples The number of samples to retrieve heights along {@code path}.
* @param path The path to sample.
* @return The elevations as a {@link PendingResult}.
*/
public static PendingResult getByPath(
GeoApiContext context, int samples, LatLng... path) {
return context.get(
API_CONFIG,
MultiResponse.class,
"samples",
String.valueOf(samples),
"path",
shortestParam(path));
}
/**
* See
* documentation.
*
* @param context The {@link GeoApiContext} to make requests through.
* @param samples The number of samples to retrieve heights along {@code encodedPolyline}.
* @param encodedPolyline The path to sample as an encoded polyline.
* @return The elevations as a {@link PendingResult}.
*/
public static PendingResult getByPath(
GeoApiContext context, int samples, EncodedPolyline encodedPolyline) {
return context.get(
API_CONFIG,
MultiResponse.class,
"samples",
String.valueOf(samples),
"path",
"enc:" + encodedPolyline.getEncodedPath());
}
/**
* Chooses the shortest param (only a guess, since the length is different after URL encoding).
*/
private static String shortestParam(LatLng[] points) {
String joined = join('|', points);
String encoded = "enc:" + PolylineEncoding.encode(points);
return joined.length() < encoded.length() ? joined : encoded;
}
/**
* Retrieves the elevation of a single location.
*
* @param context The {@link GeoApiContext} to make requests through.
* @param location The location to retrieve the elevation for.
* @return The elevation as a {@link PendingResult}.
*/
public static PendingResult getByPoint(GeoApiContext context, LatLng location) {
return context.get(API_CONFIG, SingularResponse.class, "locations", location.toString());
}
private static class SingularResponse implements ApiResponse {
public String status;
public String errorMessage;
public ElevationResult[] results;
@Override
public boolean successful() {
return "OK".equals(status);
}
@Override
public ElevationResult getResult() {
return results[0];
}
@Override
public ApiException getError() {
if (successful()) {
return null;
}
return ApiException.from(status, errorMessage);
}
}
/**
* Retrieves the elevations of an encoded polyline path.
*
* @param context The {@link GeoApiContext} to make requests through.
* @param encodedPolyline The encoded polyline to retrieve elevations for.
* @return The elevations as a {@link PendingResult}.
*/
public static PendingResult getByPoints(
GeoApiContext context, EncodedPolyline encodedPolyline) {
return context.get(
API_CONFIG, MultiResponse.class, "locations", "enc:" + encodedPolyline.getEncodedPath());
}
private static class MultiResponse implements ApiResponse {
public String status;
public String errorMessage;
public ElevationResult[] results;
@Override
public boolean successful() {
return "OK".equals(status);
}
@Override
public ElevationResult[] getResult() {
return results;
}
@Override
public ApiException getError() {
if (successful()) {
return null;
}
return ApiException.from(status, errorMessage);
}
}
}