我希望能在Google地图上启用绘图功能,就像(这个例子)一样。 当用户完成绘图后,他将点击保存按钮将其绘图保存在数据库或KML文件中,任何格式都可以 :) .. 我不知道如何实现保存部分?有人能帮我吗?
我希望能在Google地图上启用绘图功能,就像(这个例子)一样。 当用户完成绘图后,他将点击保存按钮将其绘图保存在数据库或KML文件中,任何格式都可以 :) .. 我不知道如何实现保存部分?有人能帮我吗?
在这里,http://jsfiddle.net/X66L4/1/ 尝试画一些圆圈,点击保存,然后通过切换到手形光标编辑圆圈并再次保存来查看更改。
我展示了一个保存圆圈数据的例子,主要思路是为每种绘图类型(线条、多边形、标记、圆圈)保留一个全局数组,并使用绘图管理器上的监听器检测每种类型被绘制(完成)。
var circles = [];
google.maps.event.addDomListener(drawingManager, 'circlecomplete',
function(circle) {
circles.push(circle);
});
保存整个绘制对象的原因是为了继续跟踪更改。因此,您需要为每种类型的绘图使用一个数组和侦听器。<!DOCTYPE html>
<html>
<head>
<style type="text/css">
html, body, #map_canvas { margin: 0; padding: 0; height: 100% }
</style>
<script type="text/javascript" src="http://maps.googleapis.com/maps/api/js?sensor=false&libraries=drawing"></script>
<script type="text/javascript">
var myOptions = {
center: new google.maps.LatLng(-25,177.5),
zoom: 3,
mapTypeId: google.maps.MapTypeId.SATELLITE
};
var map;
function initialize() {
map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
var drawingManager = new google.maps.drawing.DrawingManager({
drawingMode: google.maps.drawing.OverlayType.CIRCLE,
drawingControl: true,
drawingControlOptions: {
position: google.maps.ControlPosition.TOP_CENTER,
drawingModes: [google.maps.drawing.OverlayType.CIRCLE]
},
circleOptions: {
editable: true
}
});
drawingManager.setMap(map);
var circles = [];
google.maps.event.addDomListener(drawingManager, 'circlecomplete', function(circle) {
circles.push(circle);
});
google.maps.event.addDomListener(savebutton, 'click', function() {
document.getElementById("savedata").value = "";
for (var i = 0; i < circles.length; i++) {
var circleCenter = circles[i].getCenter();
var circleRadius = circles[i].getRadius();
document.getElementById("savedata").value += "circle((";
document.getElementById("savedata").value +=
circleCenter.lat().toFixed(3) + "," + circleCenter.lng().toFixed(3);
document.getElementById("savedata").value += "), ";
document.getElementById("savedata").value += circleRadius.toFixed(3) + ")\n";
}
});
}
google.maps.event.addDomListener(window, 'load', initialize);
</script>
</head>
<body>
<button id="savebutton">SAVE</button>
<textarea id="savedata" rows="8" cols="40"></textarea>
<div id="map_canvas"></div>
</body>
</html>
map.data.setControls(['Polygon']);
map.data.setStyle({
editable: true,
draggable: true
});
function loadPolygons(map) {
var data = JSON.parse(localStorage.getItem('geoData'));
map.data.forEach(function (f) {
map.data.remove(f);
});
console.log(data);
map.data.addGeoJson(data)
}