我的应用程序中有一个谷歌地图组件,允许用户绘制多边形、线条和标记。现在我想实现一个按钮,允许用户导出他/她在地图中绘制的东西的 kml 文件。
任何关于这样做的最佳方法的建议。
非常感谢您的评论和贡献
我的应用程序中有一个谷歌地图组件,允许用户绘制多边形、线条和标记。现在我想实现一个按钮,允许用户导出他/她在地图中绘制的东西的 kml 文件。
任何关于这样做的最佳方法的建议。
非常感谢您的评论和贡献
我将我的想法总结为在用户绘制时存储坐标,然后当单击“输出 KML”按钮时,格式化保存的坐标数据并将其放置在要复制的文本区域中(除非有办法提示下载? )。
下面是当用户完成一个绘图元素时我如何保存数据:
(我不知道检测编辑的好方法。)
首先,为每种绘图类型(线、多边形、标记)添加事件侦听器,以便在完成时触发。每种类型都需要一个单独的事件侦听器。这是折线的一个,每个侦听器都会返回刚刚完成的绘图元素的类型。
google.maps.event.addDomListener(drawingManager, 'polylinecomplete', function(line) {
path = line.getPath();
document.getElementById("action").value += "#polyline\n";
for(var i = 0; i < path.length; i++) {
document.getElementById("action").value += path.getAt(i) + "\n";
}
});
我将坐标直接放入共享的文本区域,但它们应该放入数组变量的数组中,其中一个变量用于多边形,一个用于折线,一个用于标记。
从这些内部变量中读取时,将 Google Maps LatLngs 转换为 KML 格式 long,lat,altitude。您将不得不对每个元素的名称和描述进行创意。
最后,当请求 KML 时,循环遍历标记、线和多边形变量以生成 KML 格式的元素,例如Point-coordinates, LineString, and Polygon-outerBoundaryIs