use of com.here.android.mpa.pde.PlatformDataResult in project here-android-sdk-examples by heremaps.
the class MapFragmentView method roadSlopes.
/**
* Method contains logic for extracting data about slopes and showing it on a route
*/
private void roadSlopes() {
final java.util.Map<String, Integer> slopesMap = new HashMap<>();
final java.util.Map<String, List<GeoCoordinate>> geometryMap = new HashMap<>();
/*
* Create a route plan for route calculation
*/
RoutePlan rp = new RoutePlan();
rp.addWaypoint(new RouteWaypoint(new GeoCoordinate(37.79513, -122.47603)));
rp.addWaypoint(new RouteWaypoint(new GeoCoordinate(37.78166, -122.44450)));
CoreRouter router = new CoreRouter();
/*
* For getting list of Link IDs routing should be forced to work online
*/
router.setConnectivity(CoreRouter.Connectivity.ONLINE);
router.calculateRoute(rp, new CoreRouter.Listener() {
@Override
public void onCalculateRouteFinished(List<RouteResult> list, RoutingError routingError) {
if (routingError == RoutingError.NONE) {
Route route = list.get(0).getRoute();
/*
* Show route on the map and zoom to the route
*/
GeoBoundingBox bbox = route.getBoundingBox();
map.addMapObject(new MapRoute(route));
map.zoomTo(bbox, Map.Animation.NONE, 0);
/*
* Get list of Link IDs for the route
*/
final List<Long> ids = route.getPermanentLinkIds();
for (Long id : ids) {
pvids.add(id);
}
Set<String> layers = new HashSet<>(Arrays.asList(ADAS_LAYER, ROAD_GEOM_LAYER));
PlatformDataRequest request = PlatformDataRequest.createBoundingBoxRequest(layers, bbox);
request.execute(new PlatformDataRequest.Listener<PlatformDataResult>() {
@Override
public void onCompleted(PlatformDataResult data, PlatformDataRequest.Error error) {
if (error == null) {
/*
* Process route geometry from PDE
*/
PlatformDataItemCollection roadDataCollection = data.get(ROAD_GEOM_LAYER);
for (PlatformDataItem item : roadDataCollection) {
geometryMap.put(item.getLinkId(), item.getCoordinates());
}
/*
* Process ADAS data from PDE
*/
PlatformDataItemCollection adasDataCollection = data.get(ADAS_LAYER);
for (PlatformDataItem item : adasDataCollection) {
List<String> values = new ArrayList<>();
/*
* Split slopes data
*/
StringTokenizer tokenizer = new StringTokenizer(item.get("SLOPES"));
while (tokenizer.hasMoreTokens()) {
String token = tokenizer.nextToken(",");
/*
* Filter out invalid data
*/
if (!token.equals("NULL") && !token.equals("1000000000")) {
values.add(token);
}
}
/*
* Mark slopes data if it contains either high or low value
*/
int max = 0;
int min = 0;
for (String str : values) {
int temp = Integer.valueOf(str);
if (temp > max)
max = temp;
if (temp < min)
min = temp;
}
if ((min * -1) > max && min <= -5_000)
slopesMap.put(item.getLinkId(), LOW_COLOR);
else if ((min * -1) < max && max >= 5_000)
slopesMap.put(item.getLinkId(), HIGH_COLOR);
}
/*
* Process list of geometry
* find route segment with high or low slopes value
* and add this geometry to the list
*/
List<MapObject> polylines = new ArrayList<>();
for (java.util.Map.Entry<String, List<GeoCoordinate>> entry : geometryMap.entrySet()) {
if (pvids.contains(Long.parseLong(entry.getKey()))) {
GeoPolyline polyline = new GeoPolyline();
polyline.add(entry.getValue());
MapPolyline line = new MapPolyline(polyline);
if (slopesMap.containsKey(entry.getKey())) {
line.setLineColor(slopesMap.get(entry.getKey()));
line.setLineWidth(15);
polylines.add(line);
}
}
}
/*
* Show a list of slopes geometry on the map
*/
map.addMapObjects(polylines);
} else {
/*
* Process PDE request error
*/
Log.i(TAG, "PDE error: " + error.getFaultCode());
Log.i(TAG, "PDE error: " + error.getMessage());
Log.i(TAG, "PDE error: " + error.getResponseCode());
Log.i(TAG, "PDE error: " + error.getType().toString());
}
}
});
} else {
Log.e(TAG, "Routing error: " + routingError);
}
}
@Override
public void onProgress(int i) {
Log.i(TAG, String.format("Route calculation progress: %d%%", i));
}
});
}
use of com.here.android.mpa.pde.PlatformDataResult in project here-android-sdk-examples by heremaps.
the class MapFragmentView method showCapitals.
/**
* Method contains logic for extracting data about capitals and placing it on a map
*/
private void showCapitals() {
/*
* Create an image for marker
*/
final int[] colorArray = new int[25 * 25];
for (int i = 0; i < colorArray.length; i++) {
colorArray[i] = Color.GREEN;
}
Bitmap bitmap = Bitmap.createBitmap(colorArray, 25, 25, Bitmap.Config.ARGB_8888);
final Image image = new Image();
image.setBitmap(bitmap);
/*
* Create list of PDE layers to extract
*/
Set<String> layers = new HashSet<>(Arrays.asList(CITY_POI_LAYER));
GeoBoundingBox bbox = map.getBoundingBox();
/*
* Check that bounding box is valid
*/
if (bbox == null || bbox.isEmpty()) {
Log.e(TAG, "PDE bbox is null or empty!");
Toast.makeText(this.activity.getApplicationContext(), "Current zoom level is too low. Please zoom closer.", Toast.LENGTH_LONG).show();
} else {
/*
* Create and send PDE request
*/
final PlatformDataRequest request = PlatformDataRequest.createBoundingBoxRequest(layers, bbox);
request.execute(new PlatformDataRequest.Listener<PlatformDataResult>() {
@Override
public void onCompleted(PlatformDataResult platformDataResult, PlatformDataRequest.Error error) {
if (error == null) {
/*
* Process PDE request response
*/
PlatformDataItemCollection result = platformDataResult.get(CITY_POI_LAYER);
List<MapObject> markers = new ArrayList<>();
for (java.util.Map<String, String> entry : result.extract()) {
double lat = Double.parseDouble(entry.get("LAT")) / 100_000;
double lon = Double.parseDouble(entry.get("LON")) / 100_000;
MapMarker marker = new MapMarker();
marker.setCoordinate(new GeoCoordinate(lat, lon));
marker.setIcon(image);
markers.add(marker);
}
/*
* Add list of map markers on map
*/
map.addMapObjects(markers);
/*
* Set the zoom level.
*/
map.setZoomLevel(3.95);
} else {
/*
* Process PDE request error
*/
Log.i(TAG, "PDE error: " + error.getFaultCode());
Log.i(TAG, "PDE error: " + error.getMessage());
Log.i(TAG, "PDE error: " + error.getResponseCode());
Log.i(TAG, "PDE error: " + error.getType().toString());
}
}
});
}
}
Aggregations