1

此代码可以正常加载地图,但我想从 json 创建多边形并通过 ajax 请求(在 json 数组中)获取数据。

我是 openlayer 3 的新手。我不知道如何从 ajax 请求获得的 json 数据创建多边形。

如果您知道任何其他方式,请建议我(但只能使用 openlayers 3)。

var vectorSource = new ol.source.ServerVector({
    format: new ol.format.GeoJSON(),
    loader: function(extent, resolution, projection) {
       var url = 'http://demo.opengeo.org/geoserver/wfs?service=WFS&' +
       'version=1.1.0&request=GetFeature&typename=osm:water_areas&' +
       'outputFormat=text/javascript&format_options=callback:loadFeatures' +
       '&srsname=EPSG:3857&bbox=' + extent.join(',') + ',EPSG:3857';
        $.ajax({
            url: url,
            dataType: 'jsonp'
        });
    },
    strategy: ol.loadingstrategy.createTile(new ol.tilegrid.XYZ({
     maxZoom: 19
    })),
 projection: 'EPSG:3857'
 });

 var loadFeatures = function(response) {
    vectorSource.addFeatures(vectorSource.readFeatures(response));
 };

 var vector = new ol.layer.Vector({
     source: vectorSource,
     style: new ol.style.Style({
        stroke: new ol.style.Stroke({
           color: 'rgba(0, 0, 255, 1.0)',
           width: 2
        })
     })
});

var raster = new ol.layer.Tile({
    source: new ol.source.BingMaps({
        imagerySet: 'Aerial',
        key: 'Ak-dzM4wZjSqTlzveKz5u0d4IQ4bRzVI309GxmkgSVr1ewS6iPSrOvOKhA-CJlm3'
    })
});

var map = new ol.Map({
    layers: [raster, vector],
    target: document.getElementById('map'),
    view: new ol.View({
        center: [-8908887.277395891, 5381918.072437216],
        maxZoom: 19,
        zoom: 12
    })
});
4

0 回答 0