UNPKG

openlayers

Version:

Build tools and sources for developing OpenLayers based mapping applications

52 lines (42 loc) 1.42 kB
// NOCOMPILE // this example uses JSTS for which we don't have an externs file. goog.require('ol.Map'); goog.require('ol.View'); goog.require('ol.format.GeoJSON'); goog.require('ol.layer.Tile'); goog.require('ol.layer.Vector'); goog.require('ol.proj'); goog.require('ol.source.OSM'); goog.require('ol.source.Vector'); var source = new ol.source.Vector(); fetch('data/geojson/roads-seoul.geojson').then(function(response) { return response.json(); }).then(function(json) { var format = new ol.format.GeoJSON(); var features = format.readFeatures(json, {featureProjection: 'EPSG:3857'}); var parser = new jsts.io.OL3Parser(); for (var i = 0; i < features.length; i++) { var feature = features[i]; // convert the OpenLayers geometry to a JSTS geometry var jstsGeom = parser.read(feature.getGeometry()); // create a buffer of 40 meters around each line var buffered = jstsGeom.buffer(40); // convert back from JSTS and replace the geometry on the feature feature.setGeometry(parser.write(buffered)); } source.addFeatures(features); }); var vectorLayer = new ol.layer.Vector({ source: source }); var rasterLayer = new ol.layer.Tile({ source: new ol.source.OSM() }); var map = new ol.Map({ layers: [rasterLayer, vectorLayer], target: document.getElementById('map'), view: new ol.View({ center: ol.proj.fromLonLat([126.979293, 37.528787]), zoom: 15 }) });