OpenLayers.Layer.Markers问题 - 只有最后添加的标记才会显示在地图上

时间:2013-06-08 15:00:53

标签: openlayers marker markers

function init_map() {
    var map, layer;
    map = new OpenLayers.Map('map');
    layer = new OpenLayers.Layer.WMS( "OpenLayers WMS",
        "http://vmap0.tiles.osgeo.org/wms/vmap0", {layers: 'basic'} );
    map.addLayer(layer);
    map.setCenter(new OpenLayers.LonLat(43.5, 40), 10);
    var size = new OpenLayers.Size(21,25);
    var offset = new OpenLayers.Pixel(-(size.w/2), -size.h);
    var icon = new OpenLayers.Icon('http://www.openlayers.org/dev/img/marker.png',size,offset);
    var markers = new OpenLayers.Layer.Markers("Objects");
    map.addControl(new OpenLayers.Control.LayerSwitcher());
    map.addLayer(markers);
    $.ajax({
        type: "GET",
        url: "/rest/displaymap/getMarkers/",
        dataType: "json",
        error: function() {
            console.log('failed to retrieve data');
        },
        success: function(d) {
            console.log(d);
            var i;
            for(i=0; i<d.length; i++) {
                var mrk = new OpenLayers.Marker(new OpenLayers.LonLat(d[i]['objectLon'],d[i]['objectLat']), icon);
                markers.addMarker(mrk);
            }    
        }
    });
}

^我的Init()函数。我有一个带标记和瓷砖图层的简单图层。返回的json是正确的。但只显示一个标记而不是全部。不知道问题出在哪里。求救!

1 个答案:

答案 0 :(得分:0)

在这种情况下你应该使用icon.clone()。在Marker documentation中写道:

  

请注意,如果您将图标传递给Marker构造函数,它将使用该图标并使用它。这意味着你不应该在标记之间共享图标 - 你只使用它们一次,但你应该使用相同的图标克隆()任何其他标记。