Map
The Map object represents the map on your page. It exposes methods
and properties that enable you to programmatically change the map,
and fires events as users interact with it.
You create a Map by specifying a container and other options.
Then UNL Map JS initializes the map on the page and returns your Map
object.
Extends Evented.
Parameters
options
(Object)| Name | Description | 
|---|---|
| options.env (SANDBOX | PROD)default:  Environment.PROD | The env of the api. The api key and vpm id credentials should be generated on the env passed as an option here. | 
| options.container (HTMLElement | string) | The HTML element in which UNL Map JS will render the map, or the element's string id. The specified element must have no children. | 
| options.minZoom numberdefault:  0 | The minimum zoom level of the map (0-24). | 
| options.maxZoom numberdefault:  22 | The maximum zoom level of the map (0-24). | 
| options.minPitch numberdefault:  0 | The minimum pitch of the map (0-85). Values greater than 60 degrees are experimental and may result in rendering issues. | 
| options.maxPitch numberdefault:  60 | The maximum pitch of the map (0-85). Values greater than 60 degrees are experimental and may result in rendering issues. | 
| options.hash (boolean | string)default:  false | If true, the map's position (zoom, center latitude, center longitude, bearing, and pitch) will be synced with the hash fragment of the page's URL.
For example,http://path/to/my/page.html#2.59/39.26/53.07/-24.1/60.
An additional string may optionally be provided to indicate a parameter-styled hash,
e.g. 
http://path/to/my/page.html#map=2.59/39.26/53.07/-24.1/60&foo=bar
, where foo
is a custom parameter and bar is an arbitrary hash distinct from the map hash. | 
| options.interactive booleandefault:  true | If false, no mouse, touch, or keyboard listeners will be attached to the map, so it will not respond to interaction. | 
| options.bearingSnap numberdefault:  7 | The threshold, measured in degrees, that determines when the map's
bearing will snap to north. For example, with a bearingSnapof 7, if the user rotates
the map within 7 degrees of north, the map will automatically snap to exact north. | 
| options.pitchWithRotate booleandefault:  true | If false, the map's pitch (tilt) control with "drag to rotate" interaction will be disabled. | 
| options.clickTolerance numberdefault:  3 | The max number of pixels a user can shift the mouse pointer during a click for it to be considered a valid click (as opposed to a mouse drag). | 
| options.failIfMajorPerformanceCaveat booleandefault:  false | If true, map creation will fail if the performance of UNL
Map JS would be dramatically worse than expected (i.e. a software renderer would be used). | 
| options.preserveDrawingBuffer booleandefault:  false | If true, the map's canvas can be exported to a PNG usingmap.getCanvas().toDataURL(). This isfalseby default as a performance optimization. | 
| options.antialias boolean? | If true, the gl context will be created with MSAA antialiasing, which can be useful for antialiasing custom layers. this isfalseby default as a performance optimization. | 
| options.refreshExpiredTiles booleandefault:  true | If false, the map won't attempt to re-request tiles once they expire per their HTTPcacheControl/expiresheaders. | 
| options.maxBounds LngLatBoundsLike? | If set, the map will be constrained to the given bounds. | 
| options.scrollZoom (boolean | Object)default:  true | If true, the "scroll to zoom" interaction is enabled. AnObjectvalue is passed as options to 
ScrollZoomHandler#enable
. | 
| options.boxZoom booleandefault:  true | If true, the "box zoom" interaction is enabled (see 
BoxZoomHandler
). | 
| options.dragRotate booleandefault:  true | If true, the "drag to rotate" interaction is enabled (see 
DragRotateHandler
). | 
| options.dragPan (boolean | Object)default:  true | If true, the "drag to pan" interaction is enabled. AnObjectvalue is passed as options to 
DragPanHandler#enable
. | 
| options.keyboard booleandefault:  true | If true, keyboard shortcuts are enabled (see 
KeyboardHandler
). | 
| options.doubleClickZoom booleandefault:  true | If true, the "double click to zoom" interaction is enabled (see 
DoubleClickZoomHandler
). | 
| options.touchZoomRotate (boolean | Object)default:  true | If true, the "pinch to rotate and zoom" interaction is enabled. AnObjectvalue is passed as options to 
TouchZoomRotateHandler#enable
. | 
| options.touchPitch (boolean | Object)default:  true | If true, the "drag to pitch" interaction is enabled. AnObjectvalue is passed as options to 
TouchPitchHandler#enable
. | 
| options.trackResize booleandefault:  true | If true, the map will automatically resize when the browser window resizes. | 
| options.center LngLatLikedefault:  [0,0] | The initial geographical centerpoint of the map. If centeris not specified in the constructor options, UNL Map JS will look for it in the map's style object. If it is not specified in the style, either, it will default to[0, 0]Note: UNL Map JS uses longitude, latitude coordinate order (as opposed to latitude, longitude) to match GeoJSON. | 
| options.zoom numberdefault:  0 | The initial zoom level of the map. If zoomis not specified in the constructor options, UNL Map JS will look for it in the map's style object. If it is not specified in the style, either, it will default to0. | 
| options.bearing numberdefault:  0 | The initial bearing (rotation) of the map, measured in degrees counter-clockwise from north. If bearingis not specified in the constructor options, UNL Map JS will look for it in the map's style object. If it is not specified in the style, either, it will default to0. | 
| options.pitch numberdefault:  0 | The initial pitch (tilt) of the map, measured in degrees away from the plane of the screen (0-85). If pitchis not specified in the constructor options, UNL Map JS will look for it in the map's style object. If it is not specified in the style, either, it will default to0. Values greater than 60 degrees are experimental and may result in rendering issues. | 
| options.bounds LngLatBoundsLike? | The initial bounds of the map. If boundsis specified, it overridescenterandzoomconstructor options. | 
| options.fitBoundsOptions Object? | A 
Map#fitBounds
 options object to use 
only
 when fitting the initial boundsprovided above. | 
| options.renderWorldCopies booleandefault:  true | If true, multiple copies of the world will be rendered side by side beyond -180 and 180 degrees longitude. If set tofalse:
 container, there will be blank space beyond 180 and -180 degrees longitude. 
 map and the other on the left edge of the map) at every zoom level. | 
| options.maxTileCacheSize numberdefault:  null | The maximum number of tiles stored in the tile cache for a given source. If omitted, the cache will be dynamically sized based on the current viewport. | 
| options.localIdeographFontFamily stringdefault:  'sans-serif' | Defines a CSS
font-family for locally overriding generation of glyphs in the 'CJK Unified Ideographs', 'Hiragana', 'Katakana' and 'Hangul Syllables' ranges.
In these ranges, font settings from the map's style will be ignored, except for font-weight keywords (light/regular/medium/bold).
Set to false, to enable font settings from the map's style for these glyph ranges.
The purpose of this option is to avoid bandwidth-intensive glyph server requests. (See 
Use locally generated ideographs
.) | 
| options.transformRequest RequestTransformFunctiondefault:  null | A callback run before the Map makes a request for an external URL. The callback can be used to modify the url, set headers, or set the credentials property for cross-origin requests.
Expected to return an object with a urlproperty and optionallyheadersandcredentialsproperties. | 
| options.collectResourceTiming booleandefault:  false | If true, Resource Timing API information will be collected for requests made by GeoJSON and Vector Tile web workers (this information is normally inaccessible from the main Javascript thread). Information will be returned in aresourceTimingproperty of relevantdataevents. | 
| options.fadeDuration numberdefault:  300 | Controls the duration of the fade-in/fade-out animation for label collisions, in milliseconds. This setting affects all symbol layers. This setting does not affect the duration of runtime styling transitions or raster tile cross-fading. | 
| options.crossSourceCollisions booleandefault:  true | If true, symbols from multiple sources can collide with each other during collision detection. Iffalse, collision detection is run separately for the symbols in each source. | 
| options.locale Objectdefault:  null | A patch to apply to the default localization table for UI strings, e.g. control tooltips. The localeobject maps namespaced UI string IDs to translated strings in the target language; seesrc/ui/default_locale.jsfor an example with all supported string IDs. The object may specify all UI strings (thereby adding support for a new translation) or only a subset of strings (thereby patching the default translation table). | 
| options.pixelRatio number? | The pixel ratio. The canvas' widthattribute will becontainer.clientWidth * pixelRatioand itsheightattribute will becontainer.clientHeight * pixelRatio. Defaults todevicePixelRatioif not specified. | 
Example
var map = new UnlSdk.Map({container: 'map',apiKey: 'YOUR-UNL-API-KEY', vpmId: 'YOUR-UNL-VPM-ID', center: [-122.420679, 37.772537],zoom: 13,style: style_object,hash: true,transformRequest: (url, resourceType)=> {if(resourceType === 'Source' && url.startsWith('http://myHost')) {return {url: url.replace('http', 'https'),headers: { 'my-custom-header': true},credentials: 'include'  // Include cookies for cross-origin requests}}}});