Per arcgis javascript SDK versione 3.x è possibile utilizzare la classe esri / basemaps per dichiarare e registrare mappe di base personalizzate e utilizzare con la mappa: https://developers.arcgis.com/javascript/3/jsapi/esri.basemaps-amd.html
Dichiara e registra una mappa di base personalizzata:
Basemaps.mybasemap = {
title: 'My custom basemap',
thumbnailUrl: 'https://js.arcgis.com/3.22/esri/images/basemap/satellite.jpg',
//itemId: 'ulas',
baseMapLayers: [
{ url: "https://services.arcgisonline.com/ArcGIS/rest/services/Specialty/DeLorme_World_Base_Map/MapServer" }
]
};
Utilizza una mappa di base personalizzata nel costruttore della mappa:
var map = new Map("mapDiv", {
basemap: "mybasemap",
center: [-122.69, 45.52],
zoom: 3
});
Oppure puoi applicare la tua mappa di base personalizzata alla mappa esistente:
map.setBasemap("mybasemap");
Esempio di codice completo: https://codepen.io/digz6666/pen/wPwPbW
Per arcgis javascript SDK versione 4.x è possibile utilizzare esri / Basemap.
Dichiarare il livello della mappa di base e la mappa di base:
var baseLayer = new MapImageLayer({
url: "https://services.arcgisonline.com/ArcGIS/rest/services/Specialty/DeLorme_World_Base_Map/MapServer"
});
var myBasemap = this.esri.basemap({
baseLayers: [baseLayer],
title: 'My custom basemap',
id: 'my_custom_basemap'
});
Applica la mappa di base all'oggetto mappa esistente:
map.basemap = myBasemap;