[gnome-maps/wip/mlundblad/get-extents-from-photon] photonParser: Parse bounding box when available
- From: Marcus Lundblad <mlundblad src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-maps/wip/mlundblad/get-extents-from-photon] photonParser: Parse bounding box when available
- Date: Mon, 5 Oct 2020 21:55:39 +0000 (UTC)
commit 2d55a940dd166c58b5712a3f42901791028f75a9
Author: Marcus Lundblad <ml update uu se>
Date: Mon Oct 5 23:52:44 2020 +0200
photonParser: Parse bounding box when available
Parse feature's bounding boxes from the "extents"
array when available in the result.
This allows MapWalker to get a better zoom-to-fit
for some features, compared to the fixed zoom levels
based on types.
src/photonParser.js | 19 +++++++++++++++++++
1 file changed, 19 insertions(+)
---
diff --git a/src/photonParser.js b/src/photonParser.js
index 3c3a78b6..d085636e 100644
--- a/src/photonParser.js
+++ b/src/photonParser.js
@@ -85,6 +85,9 @@ function parsePlace(latitude, longitude, properties) {
if (!countryCode && properties.country)
place.country = properties.country;
+ if (properties.extent)
+ place.bounding_box = _parseBoundingBox(properties.extent);
+
return new Place.Place({ place: place });
}
@@ -206,3 +209,19 @@ function _parsePlaceType(properties) {
return Geocode.PlaceType.MISCELLANEOUS;
}
}
+
+function _parseBoundingBox(extent) {
+ if (extent.length !== 4) {
+ Utils.debug('invalid extents in response: ' +
+ JSON.stringify(extent, null, 2));
+ return null;
+ }
+
+ /* it seems GraphHopper geocode swaps order of bottom and top compared
+ * to stock Photon, so just in case "clamp" both pairs
+ */
+ return new Geocode.BoundingBox({ left: Math.min(extent[0], extent[2]),
+ bottom: Math.min(extent[1], extent[3]),
+ right: Math.max(extent[0], extent[2]),
+ top: Math.max(extent[1], extent[3]) });
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]