Para arcgis javascript SDK versión 3.x puede usar la clase esri / basemaps para declarar y registrar mapas base personalizados y usar con su mapa: https://developers.arcgis.com/javascript/3/jsapi/esri.basemaps-amd.html
Declarar y registrar un mapa base personalizado:
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" }
]
};
Utilice un mapa base personalizado en el constructor de mapas:
var map = new Map("mapDiv", {
basemap: "mybasemap",
center: [-122.69, 45.52],
zoom: 3
});
O puede aplicar su mapa base personalizado al mapa existente:
map.setBasemap("mybasemap");
Ejemplo de código completo: https://codepen.io/digz6666/pen/wPwPbW
Para arcgis javascript SDK versión 4.x puede usar esri / Basemap.
Declare la capa del mapa base y el mapa 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'
});
Aplicar mapa base al objeto de mapa existente:
map.basemap = myBasemap;