function startMarker() {
$("add_marker").innerHTML='Click on the map to add a marker';
+
if (!markerLayer) {
- markerLayer = new OpenLayers.Layer.Vector("",{
- displayInLayerSwitcher: false,
- style: { externalGraphic: OpenLayers.Util.getImagesLocation()+"marker.png", graphicXOffset:-10.5, graphicYOffset:-25, graphicWidth: 21, graphicHeight: 25}
- });
- markerControl = new OpenLayers.Control.DrawFeature(markerLayer, OpenLayers.Handler.Point);
- map.addLayer(markerLayer);
- map.addControl(markerControl);
- markerLayer.events.on({"featureadded": endMarker});
+ markerLayer = new OpenLayers.Layer.Vector("",{
+ displayInLayerSwitcher: false,
+ style: {
+ externalGraphic: OpenLayers.Util.getImagesLocation() + "marker.png",
+ graphicXOffset: -10.5,
+ graphicYOffset: -25,
+ graphicWidth: 21,
+ graphicHeight: 25
+ }
+ });
+ map.addLayer(markerLayer);
+
+ markerControl = new OpenLayers.Control.DrawFeature(markerLayer, OpenLayers.Handler.Point);
+ map.addControl(markerControl);
+
+ markerLayer.events.on({ "featureadded": endMarker });
}
+
markerLayer.destroyFeatures();
markerControl.activate();
+
return false;
- }
+ }
$("add_marker").onclick = startMarker;
function endMarker(event) {
-
markerControl.deactivate();
- $("add_marker").innerHTML='Change marker position';
- $("marker_inputs").style.display="block";
+
+ $("add_marker").innerHTML = "Change marker position";
+ $("marker_inputs").style.display = "block";
var epsg4326 = new OpenLayers.Projection("EPSG:4326");
var epsg900913 = new OpenLayers.Projection("EPSG:900913");
- var geom = event.feature.geometry.clone().transform( epsg900913, epsg4326 );
+ var geom = event.feature.geometry.clone().transform(epsg900913, epsg4326);
+
$("marker_lon").value = geom.x.toFixed(5);
$("marker_lat").value = geom.y.toFixed(5);
+
htmlUrlChanged();
}
$("marker_lon").value = "";
$("marker_lat").value = "";
$("marker_inputs").style.display = "none";
- $("add_marker").innerHTML='Add a marker to the map';
+ $("add_marker").innerHTML = "Add a marker to the map";
+
if (markerLayer) {
- markerControl.destroy();
- markerLayer.destroy();
- markerLayer = null;
- markerControl = null;
+ markerControl.destroy();
+ markerLayer.destroy();
+ markerLayer = null;
+ markerControl = null;
}
}
function htmlUrlChanged() {
var bounds = new OpenLayers.Bounds($("minlon").value, $("minlat").value, $("maxlon").value, $("maxlat").value);
- var url = "http://#{SERVER_URL}/export/embed.html?bbox=" + bounds.toBBOX();
+ var layerName = map.baseLayer.name.toLowerCase();
+ var url = "http://#{SERVER_URL}/export/embed.html?bbox=" + bounds.toBBOX() + "&layer=" + layerName;
+
if ($("marker_lat").value && $("marker_lon").value) {
- url += "&marker=" + $("marker_lat").value + "," + $("marker_lon").value;
+ url += "&marker=" + $("marker_lat").value + "," + $("marker_lon").value;
}
- var layerName = map.baseLayer.name.toLowerCase();
- if (layerName != "mapnik") {
- url += "&layer="+layerName;
- }
var html = '<iframe width="425" height="350" frameborder="0" scrolling="no" marginheight="0" marginwidth="0" src="'+url+'" style="border: 1px solid black"></iframe>';
$("export_html_text").value = html;
var mapnik = new OpenLayers.Layer.OSM.Mapnik("Mapnik", {
displayOutsideMaxExtent: true,
wrapDateLine: true,
- attribution: attribution
+ attribution: attribution
});
map.addLayer(mapnik);
- } else {
+ } else {
var osmarender = new OpenLayers.Layer.OSM.Osmarender("Osmarender", {
displayOutsideMaxExtent: true,
wrapDateLine: true,
- attribution: attribution
+ attribution: attribution
});
- map.addLayer(osmarender);
- }
+ map.addLayer(osmarender);
+ }
+
if (args.marker) {
var markers = new OpenLayers.Layer.Markers();
map.addLayer(markers);
- markers.addMarker( new OpenLayers.Marker(new OpenLayers.LonLat(args.marker[1], args.marker[0]).transform(map.displayProjection, map.getProjectionObject())));
+ markers.addMarker(new OpenLayers.Marker(new OpenLayers.LonLat(args.marker[1], args.marker[0]).transform(map.displayProjection, map.getProjectionObject())));
map.marker = true;
- }
- if (args.bbox) {
+ }
+
+ if (args.bbox) {
var bounds = OpenLayers.Bounds.fromArray(args.bbox).transform(map.displayProjection, map.getProjectionObject());
map.zoomToExtent(bounds)
} else {
- map.zoomToMaxExtent();
+ map.zoomToMaxExtent();
}
+
var size = map.getSize();
if (size.h > 320) {
map.addControl(new OpenLayers.Control.PanZoomBar());