[gnome-maps/wip/mlundblad/get-extents-from-photon] photonParser: Parse bounding box when available




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]