javascript - 单击时提取 drawingManager 多边形路径 Google map

标签 javascript jquery google-maps google-maps-api-3 polygon

我有一个启用了绘图管理器的 Google map ,用户可以在其中绘制多边形并将其保存到我的数据库中。我为 overlaycomplete 事件向 drawingManager 对象添加了一个事件监听器。当事件被触发时,多边形的坐标被写入一个隐藏字段。这很好用 - 唯一的问题是,如果在该点之后拖动/更改单个顶点,则不会触发事件。当用户点击提交并将它们写入隐藏字段时,我需要在(任何)更改时更新字段或遍历多边形顶点。我不太明白如何让它工作,但你可以在这里看到我目前所拥有的:http://jsfiddle.net/5Y4WT/21/

HTML:

<div id="map_canvas" style="width:500px; height:450px;"></div>
<form method="post" accept-charset="utf-8" id="map_form">
  <input type="text" name="vertices" value="" id="vertices"  />
  <input type="button" name="save" value="Save!" id="save"  />
</form>

JavaScript:

var map; // Global declaration of the map
var iw = new google.maps.InfoWindow(); // Global declaration of the infowindow
var lat_longs = new Array();
var markers = new Array();
var drawingManager;
function initialize() {
    var myLatlng = new google.maps.LatLng(40.9403762, -74.1318096);
    var myOptions = {
        zoom: 13,
        center: myLatlng,
        mapTypeId: google.maps.MapTypeId.ROADMAP}
    map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
    drawingManager = new google.maps.drawing.DrawingManager({
    drawingMode: google.maps.drawing.OverlayType.POLYGON,
    drawingControl: true,
    drawingControlOptions: {
                position: google.maps.ControlPosition.TOP_CENTER,
                drawingModes: [google.maps.drawing.OverlayType.POLYGON]
                },
                        polygonOptions: {
                            editable: true
                        }
            });
            drawingManager.setMap(map);

            google.maps.event.addListener(drawingManager, "overlaycomplete", function(event) {
                var newShape = event.overlay;
                newShape.type = event.type;
            });

            google.maps.event.addListener(drawingManager, 'overlaycomplete', function(event) {
                $('#vertices').val(event.overlay.getPath().getArray());
            });
        }
 initialize();

$(function(){
    $('#save').click(function(){
        //iterate polygon vertices?
    });
});

最佳答案

想通了!!

我添加了函数 overlayClickListener:

function overlayClickListener(overlay) {
    google.maps.event.addListener(overlay, "mouseup", function(event){
        $('#vertices').val(overlay.getPath().getArray());
    });
}

并将其附加到 overlaycomplete 上的叠加层:

google.maps.event.addListener(drawingManager, "overlaycomplete", function(event){
                overlayClickListener(event.overlay);
                $('#vertices').val(event.overlay.getPath().getArray());
            });

有关实际解决方案,请参见此处:http://jsfiddle.net/rvsMH/1/

关于javascript - 单击时提取 drawingManager 多边形路径 Google map ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15454919/

相关文章:

javascript - 通过 JavaScript 访问表单值

javascript - 解析云查询错误

javascript - 如何在 node.js 中导入 font-awesome 以在 react.js 中使用?

javascript - 根据 .jqGrid 中第一个复选框的选择读取第二个复选框的值

ios - 如何将自定义标记从服务器添加到谷歌地图? swift

javascript - 我得到了一个带有来自服务器的数据的div,使用ajax,div将被替换为我使用jquery和ajax提交到php路由的表单

javascript - 如何将jquery日期选择器更改为美国日期选择器

ajax - 通过jquery调用删除rest api

javascript - 在多边形中添加一些区域 [JavaScript::Google Map API v3]

javascript - 谷歌地图 div 区域中仅显示带有缩放控制的白色