Extensión de Mapea para el soporte de carga de ficheros locales .mbtiles.
Se implementa la clase M.layer.MBTiles para aquellos ficheros MBTiles que tengan su tile data en formato imagen (jpg, png, etc).
Por el contratio, la clase M.layer.MBTilesVector se usará cuando el tile data esté en formato .pbf (mapbox vector tile).
Node version >= 12.X.X
-
Instalar dependencias
npm install
-
Desplegar servidor de desarrollo
npm start
-
Se abrirá el navegador con la página de test.
En la carpeta properties se encuentran los diferentes ficheros para configurar el perfil deseado.
Para compilar con un perfil concreto
$ npm run build -- -P <perfil>
- M.config.MBTILES_SQL_WASM_URL: Este parámetro de configuración indica donde se encuentra el fichero sql-wasm.wasm necesario para la librería SQL.js que se usa como dependencia para la conexión con los ficheros mbtiles. Para entornos de producción este fichero debe estar disponible desde un servidor que provea del fichero sql-wasm.wasm
-
Constructor:
new M.layer.MBTiles(options) options: {object}
const options = { source, // El fichero que contiene la información de mbtiles (.mbtiles) // Tipo: | Response: https://developer.mozilla.org/es/docs/Web/API/Response | File: https://developer.mozilla.org/es/docs/Web/API/File | Uint8Array: https://developer.mozilla.org/es/docs/Web/JavaScript/Referencia/Objetos_globales/Uint8Array extent, // extensión de la capa. Opcional name, // Nombre interno de la capa. Opcional legend, // Leyenda para mostrar en TOC. Opcional transparent, // True para hacerla capa base. Opcional, visibility, // Visibilidad de la capa. Opcional opacity, // Opacidad de la capa. Numero entre [0-1] zoomLevels // Numero de niveles de zoom de la capa. 16 por defecto, tileLoadFunction, // Función de carga de los tiles. Recibe las coordenadas x,y,z // y devuelve una promesa con el dato con la imagen en base64 o la URL de dicha imagen para esas coordenadas. } }
-
Constructor:
new M.layer.MBTilesVector(options, inheritedOpts)
options: {object}
const options = { source, // El fichero que contiene la información de mbtiles (.mbtiles) // Tipo: | Response: https://developer.mozilla.org/es/docs/Web/API/Response | File: https://developer.mozilla.org/es/docs/Web/API/File | Uint8Array: https://developer.mozilla.org/es/docs/Web/JavaScript/Referencia/Objetos_globales/Uint8Array name, // Nombre interno de la capa. Opcional legend, // Leyenda para mostrar en TOC. Opcional, maxExtent, // Extensión máxima de la capa. Opcional visibility, // Visibilidad de la capa. Opcional opacity, // Opacidad de la capa. Numero entre [0-1] zoomLevels // Numero de niveles de zoom de la capa. 16 por defecto, tileLoadFunction, // Función de carga de los tiles. Recibe las coordenadas x,y,z // y devuelve una promesa con el dato .pbf para esas coordenadas. }
inheritedOpts: {object}
const inheritedOpts = { style, // Estilo de Mapea para la capa (M.style.Point|M.style.Line|M.style.Polygon). Opcional }
- M.Map.prototype.addMBTiles
- M.Map.prototype.addMBTilesVector
- M.Map.prototype.getMBTiles
- M.Map.prototype.getMBTilesVector
- M.Map.prototype.removeMBTiles
- M.Map.prototype.removeMBTilesVector
- M.layer.type.MBTiles
- M.layer.type.MBTilesVector
Mapea-MBTiles | Mapea |
---|---|
1.0.0 | =6.0.0 |
1.1.0 | >=6.1.0 |
1.2.0 | >=6.1.0 |
Pasamos a mostrar un ejemplo general de explotación de la extensión:
const mapjs = M.map({
container: 'map',
projection: 'EPSG:3857*m',
controls: ['layerswitcher'],
layers: ['OSM'],
});
fetch('./countries.mbtiles').then((response) => {
const mbtile = new M.layer.MBTilesVector({
name: 'mbtiles_vector',
legend: 'Cabrera',
source: response,
});
mapjs.addLayers(mbtile);
}).catch(e => {
throw e
});
fetch('./cabrera.mbtiles').then((response) => {
const mbtile = new M.layer.MBTiles({
name: 'mbtiles',
legend: 'Countries',
source: response,
});
mapjs.addLayers(mbtile);
});
// Ejemplo de uso de una funcion personalizada de carga
const mbtile = new MBTiles({
name: 'mbtiles',
legend: 'Capa personalizada',
tileLoadFunction: (z, x, y) => {
return new Promise((resolve) => {
if (z > 4) {
resolve('');
} else {
resolve('https://www.juntadeandalucia.es/themes/images/logo-junta-principal.png');
}
});
},
});