]> git.openstreetmap.org Git - rails.git/commitdiff
Updated min bounds algorithm
authorJ Guthrie <jamie.guthrie@gmail.com>
Wed, 3 Oct 2018 21:07:20 +0000 (22:07 +0100)
committerJ Guthrie <jamie.guthrie@gmail.com>
Wed, 3 Oct 2018 21:07:20 +0000 (22:07 +0100)
app/assets/javascripts/index/history.js

index 71a94aef0d1ca014d446fa59c8a4ebeaa74c4038..30d33c6578b2ee240c6c6ac1ae05b00f6db226ba 100644 (file)
@@ -97,17 +97,26 @@ OSM.History = function(map) {
     $("[data-changeset]").each(function () {
       var changeset = $(this).data('changeset');
       if (changeset.bbox) {
     $("[data-changeset]").each(function () {
       var changeset = $(this).data('changeset');
       if (changeset.bbox) {
-        var latModifier = 0;
-        var lonModifier = 0;
+        var latWidth = changeset.bbox.maxlat - changeset.bbox.minlat;
+        var lonWidth = changeset.bbox.maxlon - changeset.bbox.minlon;
+        var minLatWidth = 0.0004;
+        var minLonWidth = 0.0008;
 
 
-        if (changeset.bbox.minlat === changeset.bbox.maxlat || changeset.bbox.minlon === changeset.bbox.maxlon) {
-          latModifier = 0.0001;
-          lonModifier = 0.0002;
+        var bounds = [[changeset.bbox.minlat, changeset.bbox.minlon],
+          [changeset.bbox.maxlat, changeset.bbox.maxlon]];
+
+        if (latWidth < minLatWidth) {
+          bounds[0][0] -= ((minLatWidth - latWidth) / 2);
+          bounds[1][0] += ((minLatWidth - latWidth) / 2);
+        }
+
+        if (lonWidth < minLonWidth) {
+          bounds[0][1] -= ((minLonWidth - lonWidth) / 2);
+          bounds[1][1] += ((minLonWidth - lonWidth) / 2);
         }
 
         changeset.bounds = L.latLngBounds(
         }
 
         changeset.bounds = L.latLngBounds(
-          [changeset.bbox.minlat - latModifier, changeset.bbox.minlon - lonModifier],
-          [changeset.bbox.maxlat + latModifier, changeset.bbox.maxlon + lonModifier]);
+          bounds);
         changesets.push(changeset);
       }
     });
         changesets.push(changeset);
       }
     });