]> git.openstreetmap.org Git - rails.git/commitdiff
Return the centre of the image if the bbox has no extent
authorAndy Allan <git@gravitystorm.co.uk>
Wed, 23 Dec 2020 15:01:01 +0000 (15:01 +0000)
committerAndy Allan <git@gravitystorm.co.uk>
Wed, 23 Dec 2020 15:01:01 +0000 (15:01 +0000)
Fixes #3007. If all the provided points in the gpx file have the same
lat/lon, then an image where they are all at the centre seems plausible.

lib/osm.rb
test/lib/osm_test.rb [new file with mode: 0644]

index a6d74067772c0d415aa98508002d5efc28c3c87d..daa15fe8bffcaf8004411411dd7d6057a0478225 100644 (file)
@@ -378,12 +378,17 @@ module OSM
     end
 
     # and these two will give you the right points on your image. all the constants can be reduced to speed things up. FIXME
+    # If the bbox has no extent, return the centre of the image to avoid dividing by zero.
 
     def y(lat)
+      return @height / 2 if (@by - @ty).zero?
+
       @height - ((ysheet(lat) - @ty) / (@by - @ty) * @height)
     end
 
     def x(lon)
+      return @width / 2 if (@bx - @tx).zero?
+
       ((xsheet(lon) - @tx) / (@bx - @tx) * @width)
     end
   end
diff --git a/test/lib/osm_test.rb b/test/lib/osm_test.rb
new file mode 100644 (file)
index 0000000..032ece5
--- /dev/null
@@ -0,0 +1,15 @@
+require "test_helper"
+
+class OsmTest < ActiveSupport::TestCase
+  def test_mercator
+    proj = OSM::Mercator.new(0, 0, 1, 1, 100, 200)
+    assert_in_delta(50, proj.x(0.5), 0.01)
+    assert_in_delta(100, proj.y(0.5), 0.01)
+  end
+
+  def test_mercator_collapsed_bbox
+    proj = OSM::Mercator.new(0, 0, 0, 0, 100, 200)
+    assert_in_delta(50, proj.x(0), 0.01)
+    assert_in_delta(100, proj.y(0), 0.01)
+  end
+end