aboutsummaryrefslogtreecommitdiffstats
path: root/app/maps
diff options
context:
space:
mode:
authorMarc Florisson2012-05-04 14:07:12 +0200
committerMarc Florisson2012-05-04 14:07:12 +0200
commit09c55792e887dea709df29cae2e4fb8fbd86901c (patch)
tree5ef824a3144995bd1ab552eea4c852b23f99c35f /app/maps
parentac3a3153fa18da97cc120703f9a62061a211b581 (diff)
downloadchouette-core-09c55792e887dea709df29cae2e4fb8fbd86901c.tar.bz2
add map on route view
Diffstat (limited to 'app/maps')
-rw-r--r--app/maps/route_map.rb35
-rw-r--r--app/maps/style_map/route_style_map.rb44
2 files changed, 79 insertions, 0 deletions
diff --git a/app/maps/route_map.rb b/app/maps/route_map.rb
new file mode 100644
index 000000000..417b6037a
--- /dev/null
+++ b/app/maps/route_map.rb
@@ -0,0 +1,35 @@
+class RouteMap < ApplicationMap
+
+ attr_reader :referential, :route, :style
+
+ def initialize(referential, route, style = nil)
+ @referential = referential
+ @route = route
+ @style = style
+ end
+
+ def map
+ @map ||= MapLayers::Map.new(id, :projection => projection("EPSG:900913"), :controls => controls) do |map, page|
+ page << map.add_layer(MapLayers::OSM_MAPNIK)
+ page << map.add_layer(google_physical)
+ page << map.add_layer(google_streets)
+ page << map.add_layer(google_hybrid)
+ page << map.add_layer(google_satellite)
+
+ #page << map.add_layer(kml_layer(line, :styleMap => StyleMap::LineStyleMap.new( :style => line_style).style_map))
+ page << map.add_layer(kml_layer(polymorphic_path([referential, route.line, route], :format => :kml), :styleMap => StyleMap::RouteStyleMap.new.style_map))
+ page << map.zoom_to_extent(bounds) if bounds
+ end
+ end
+
+ def bounds
+ wgs84_bounds = ( route.geometry.empty?) ? Chouette::StopArea.bounds : route.geometry.envelope
+
+ @bounds ||= OpenLayers::Bounds.new(
+ wgs84_bounds.lower_corner.x, wgs84_bounds.lower_corner.y,
+ wgs84_bounds.upper_corner.x, wgs84_bounds.upper_corner.y).
+ transform(OpenLayers::Projection.new("EPSG:4326"), OpenLayers::Projection.new("EPSG:900913"))
+ end
+
+end
+
diff --git a/app/maps/style_map/route_style_map.rb b/app/maps/style_map/route_style_map.rb
new file mode 100644
index 000000000..136cecba5
--- /dev/null
+++ b/app/maps/style_map/route_style_map.rb
@@ -0,0 +1,44 @@
+class StyleMap::RouteStyleMap < StyleMap::GenericStyleMap
+ attr_accessor :style
+
+ def initialize(options = {})
+ @style = options[:style].present? ? default_style.merge(options[:style]) : default_style
+ end
+
+ def default_style
+ {
+ :label => "${label}",
+ :fontColor => "black",
+ :fontSize => "11px",
+ :fontWeight => "bold",
+ :labelAlign => "ct",
+ :labelXOffset => 0,
+ :labelYOffset => -15,
+ :strokeColor => "#000000",
+ :strokeOpacity => 1,
+ :strokeWidth => 3,
+ :strokeLineCap => "round",
+ :strokeDashstyle => "solid",
+ :externalGraphic => "/assets/map/${positionType}.png",
+ :graphicWidth => 12,
+ :graphicHeight => 12,
+ :graphicOpacity => 1,
+ :graphicXOffset => -6,
+ :graphicYOffset => -6,
+ :display => true
+ }
+ end
+
+ def context
+ context = {
+ :label => :" function(feature) {if(feature.layer.map.getZoom() > 13) { return feature.attributes.name;} else {return '';}} ",
+ :positionType => :" function(feature) { if (feature.attributes.departure != undefined) { return 'departure'; } else if (feature.attributes.arrival != undefined) { return 'arrival'; } else { return 'interstop'; }} "
+ }
+ end
+
+ def style_map
+ OpenLayers::StyleMap.new(:default => OpenLayers::Style.new(style, { :context => context}))
+ end
+
+end
+