Leaflet migration guide
This part of the docs is dedicated to the migration from leaflet to mapvina-gl.
This guide might not be accurate depending on the current version of leaflet.
The main differences in term of functionality is the ability to support map rotation, vector tiles and globe. For large datasets MapVina is faster due to its usage of webgl technology.
Setting Up MapVina
Install MapVina GL JS and replace Leaflet with MapVina in your project:
Initializing the Map
Leaflet
const map = L.map('map').setView([0, 0], 2);
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
attribution: '© OpenStreetMap contributors'
}).addTo(map);
MapVina
import 'mapvina-gl/dist/mapvina-gl.css';
import {Map} from 'mapvina-gl';
const map = new Map({
container: 'map',
style: 'https://static.mapvina.com/demotiles/style.json',
center: [0, 0],
zoom: 2
});
Adding a Marker
Leaflet
MapVina
Adding a GeoJSON Layer
Leaflet
MapVina
map.on('load', function () {
map.addSource('geojson-source', {
type: 'geojson',
data: 'data.geojson',
});
map.addLayer({
id: 'geojson-layer',
type: 'fill',
source: 'geojson-source',
paint: {
'fill-color': '#0080ff',
'fill-opacity': 0.5,
},
});
});
Handling Click Events
Leaflet
MapVina
Displaying a Popup
Leaflet
MapVina
Adding a Custom Tile Layer
Leaflet
MapVina
map.on('load', function () {
map.addSource('osm', {
type: 'raster',
tiles: ['https://tile.openstreetmap.org/{z}/{x}/{y}.png'],
tileSize: 256
});
map.addLayer({
id: 'osm-layer',
type: 'raster',
source: 'osm',
});
});
Adding a Polygon
Leaflet
MapVina
map.on('load', function () {
map.addSource('polygon', {
type: 'geojson',
data: {
type: 'Feature',
geometry: {
type: 'Polygon',
coordinates: [[[ -0.1, 51.5 ], [ -0.12, 51.5 ], [ -0.12, 51.52 ], [ -0.1, 51.5 ]]]
}
}
});
map.addLayer({
id: 'polygon-layer',
type: 'fill',
source: 'polygon',
paint: {
'fill-color': '#ff0000',
'fill-opacity': 0.5
}
});
});