Merge remote-tracking branch 'upstream/pull/2204'

This commit is contained in:
Tom Hughes 2019-06-10 21:29:38 +01:00
commit 6db326aa1f
3 changed files with 50 additions and 29 deletions

View file

@ -118,7 +118,7 @@ gem "canonical-rails"
gem "logstasher" gem "logstasher"
# Used to generate images for traces # Used to generate images for traces
gem "gd2-ffij" gem "gd2-ffij", ">= 0.4.0"
# Used for browser detection # Used for browser detection
gem "browser" gem "browser"

View file

@ -178,7 +178,7 @@ GEM
multipart-post (>= 1.2, < 3) multipart-post (>= 1.2, < 3)
ffi (1.11.1) ffi (1.11.1)
fspath (3.1.1) fspath (3.1.1)
gd2-ffij (0.3.0) gd2-ffij (0.4.0)
ffi (>= 1.0.0) ffi (>= 1.0.0)
geoip (1.6.4) geoip (1.6.4)
globalid (0.4.2) globalid (0.4.2)
@ -471,7 +471,7 @@ DEPENDENCIES
factory_bot_rails factory_bot_rails
fakefs fakefs
faraday faraday
gd2-ffij gd2-ffij (>= 0.4.0)
geoip geoip
htmlentities htmlentities
http_accept_language (~> 2.0.0) http_accept_language (~> 2.0.0)

View file

@ -47,47 +47,68 @@ module GPX
end end
end end
def picture(min_lat, min_lon, max_lat, max_lon, _num_points) def picture(min_lat, min_lon, max_lat, max_lon, num_points)
# frames = 10 nframes = 10
width = 250 width = 250
height = 250 height = 250
delay = 50
points_per_frame = num_points / nframes
proj = OSM::Mercator.new(min_lat, min_lon, max_lat, max_lon, width, height) proj = OSM::Mercator.new(min_lat, min_lon, max_lat, max_lon, width, height)
# TODO: create animated gif frames = []
# https://github.com/openstreetmap/openstreetmap-website/issues/281
image = GD2::Image::IndexedColor.new(width, height)
black = image.palette.allocate(GD2::Color[0, 0, 0]) (0...nframes).each do |n|
white = image.palette.allocate(GD2::Color[255, 255, 255]) frames[n] = GD2::Image::IndexedColor.new(width, height)
black = frames[n].palette.allocate(GD2::Color[0, 0, 0])
white = frames[n].palette.allocate(GD2::Color[255, 255, 255])
grey = frames[n].palette.allocate(GD2::Color[187, 187, 187])
image.draw do |pen| frames[n].draw do |pen|
pen.color = white pen.color = white
pen.rectangle(0, 0, width, height, true) pen.rectangle(0, 0, width, height, true)
end end
image.draw do |pen| frames[n].draw do |pen|
pen.color = black pen.color = black
pen.anti_aliasing = true pen.anti_aliasing = true
pen.dont_blend = false pen.dont_blend = false
oldpx = 0.0 oldpx = 0.0
oldpy = 0.0 oldpy = 0.0
first = true first = true
points do |p| points.each_with_index do |p, pt|
px = proj.x(p.longitude) px = proj.x(p.longitude)
py = proj.y(p.latitude) py = proj.y(p.latitude)
pen.line(px, py, oldpx, oldpy) unless first if (pt >= (points_per_frame * n)) && (pt <= (points_per_frame * (n + 1)))
pen.thickness = 3
pen.color = black
else
pen.thickness = 1
pen.color = grey
end
first = false pen.line(px, py, oldpx, oldpy) unless first
oldpy = py first = false
oldpx = px oldpy = py
oldpx = px
end
end end
end end
image.gif image = GD2::AnimatedGif.new
frames.each do |frame|
image.add(frame, :delay => delay)
end
image.end
output = StringIO.new
image.export(output)
output.read
end end
def icon(min_lat, min_lon, max_lat, max_lon) def icon(min_lat, min_lon, max_lat, max_lon)