- def get_picture(min_lat, min_lon, max_lat, max_lon, num_points)
- #puts "getting picfor bbox #{min_lat},#{min_lon} - #{max_lat},#{max_lon}"
- frames = 10
- width = 250
- height = 250
- rat= Math.cos( ((max_lat + min_lat)/2.0) / 180.0 * 3.141592)
- proj = OSM::Mercator.new((min_lat + max_lat) / 2, (max_lon + min_lon) / 2, (max_lat - min_lat) / width / rat, width, height)
-
- linegc = Magick::Draw.new
- linegc.stroke_linejoin('miter')
- linegc.stroke_width(1)
- linegc.stroke('#BBBBBB')
- linegc.fill('#BBBBBB')
-
- highlightgc = Magick::Draw.new
- highlightgc.stroke_linejoin('miter')
- highlightgc.stroke_width(3)
- highlightgc.stroke('#000000')
- highlightgc.fill('#000000')
-
- images = []
-
- frames.times do
- image = Magick::Image.new(width, height) do |image|
- image.background_color = 'white'
- image.format = 'GIF'
- end
-
- images << image
- end
-
- oldpx = 0.0
- oldpy = 0.0
-
- first = true
-
- m = 0
- mm = 0
- points do |p|
- px = proj.x(p['longitude'])
- py = proj.y(p['latitude'])
-
- if m > 0
- frames.times do |n|
- if n == mm
- gc = highlightgc.dup
- else
- gc = linegc.dup
- end
-
- gc.line(px, py, oldpx, oldpy)
-
- gc.draw(images[n])
- end
- end
-
- m += 1
- if m > num_points.to_f / frames.to_f * (mm+1)
- mm += 1
- end
-
- oldpy = py
- oldpx = px
- end
-
- il = Magick::ImageList.new
-
- images.each do |f|
- il << f
- end
-
- il.delay = 50
- il.format = 'GIF'