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