Skip to content

Commit

Permalink
Merge pull request #10859 from SDaron/clipping-layer
Browse files Browse the repository at this point in the history
Add an example of clipping layer based on a vector source
  • Loading branch information
tschaub committed Apr 1, 2020
2 parents 5e8102b + 23c2e10 commit a073c5a
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 0 deletions.
3 changes: 3 additions & 0 deletions examples/layer-clipping-vector.css
@@ -0,0 +1,3 @@
#map {
background: transparent;
}
9 changes: 9 additions & 0 deletions examples/layer-clipping-vector.html
@@ -0,0 +1,9 @@
---
layout: example.html
title: Vector Clipping Layer
shortdesc: Vector Clipping Layer example
docs: >
Example of a clipping layer based on a vector source
tags: "clipping, openstreetmap, vector"
---
<div id="map" class="map"></div>
46 changes: 46 additions & 0 deletions examples/layer-clipping-vector.js
@@ -0,0 +1,46 @@
import Map from '../src/ol/Map.js';
import View from '../src/ol/View.js';
import {Tile as TileLayer, Vector as VectorLayer} from '../src/ol/layer.js';
import VectorSource from '../src/ol/source/Vector.js';
import GeoJSON from '../src/ol/format/GeoJSON.js';
import OSM from '../src/ol/source/OSM.js';
import {Fill, Style} from '../src/ol/style.js';
import {getVectorContext} from '../src/ol/render.js';
import {fromLonLat} from '../src/ol/proj.js';

const base = new TileLayer({
source: new OSM()
});

const clipLayer = new VectorLayer({
style: null,
source: new VectorSource({
url:
'./data/geojson/switzerland.geojson',
format: new GeoJSON()
})
});

const style = new Style({
fill: new Fill({
color: 'black'
})
});

base.on('postrender', function(e) {
e.context.globalCompositeOperation = 'destination-in';
const vectorContext = getVectorContext(e);
clipLayer.getSource().forEachFeature(function(feature) {
vectorContext.drawFeature(feature, style);
});
e.context.globalCompositeOperation = 'source-over';
});

const map = new Map({
layers: [base, clipLayer],
target: 'map',
view: new View({
center: fromLonLat([8.23, 46.86]),
zoom: 7
})
});

0 comments on commit a073c5a

Please sign in to comment.