Add new marker type (ForbiddenArea) to leaflet.Draw Toolbar.
Prohibit the placement of its markers if they are too close to another layer.
Check out the demo !
It depends on Leaflet.GeometryUtil.
For creation and edition, it also depends on Leaflet.draw.
In order to use this plugin in your app you can either:
- install it via your favorite package manager:
npm i leaflet-forbiddenarea
bower install [email protected]:makinacorpus/Leaflet.ForbiddenArea.git
- download the repository and import the
leaflet.forbiddenarea.js
file in your app.
- Add
leaflet.forbiddenarea.js
andleaflet.geometryutil.js
andleaflet.draw.js
var editableMarkers = new L.FeatureGroup();
var osm = L.tileLayer('//{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
attribution: 'Map data © 2013 OpenStreetMap contributors',
});
var map = L.map('map')
.setView([48.49, 1.4], 16)
.addLayer(osm);
var marker = L.marker([48.488, 1.395]).addTo(map);
editableMarkers.addLayer(marker);
map.addLayer(editableMarkers);
var forbiddenIcon = L.icon({
iconUrl: './marker-forbidden.png',
iconSize: [28, 42],
iconAnchor: [14, 42],
className: 'marker-forbidden',
});
var options = {
position: 'topright',
draw: {
polyline: false,
polygon: false,
circle: false,
rectangle: false,
marker: true,
forbiddenAreaMarker: {
guideLayers: editableMarkers,
distanceForbiddenArea: 300,
msgForbidden: 'Other marker are too close !',
forbiddenIcon: forbiddenIcon,
icon : new L.Icon.Default()
},
},
edit: {
featureGroup: editableMarkers,
remove: false
}
};
var drawControl = new L.Control.Draw(options);
map.addControl(drawControl);
map.on('draw:created', function(e) {
var layer = e.layer;
map.addLayer(layer);
editableMarkers.addLayer(layer);
});
- can change marker title
- prohibit the placement of a marker if it is too close to another.ex
- Keep default icon marker for forbidden marker type, but can be cool if we can choose an other if we want (toolbar)
- Show forbidden zone around layer Authors
- Bastien Alvez