如何使用openlayer 3的ServerVector响应创建多边形

时间:2014-07-30 10:03:25

标签: ajax json openlayers-3

此代码适用于加载地图,但我想从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
    })
});

0 个答案:

没有答案