Mapbox Controls
Usage
Install
npm install mapbox-gl-controls
Include styles
<link href="mapbox-gl-controls/theme.css" rel="stylesheet">
Ruler Control
import RulerControl from 'mapbox-gl-controls/lib/ruler';
map.addControl(new RulerControl(), 'top-right');
map.on('ruler.on', () => console.log('ruler: on'));
map.on('ruler.off', () => console.log('ruler: off'));
map.addControl(new RulerControl({
units: 'miles',
labelFormat: n => `${n.toFixed(2)} ml`,
}), 'top-right');
Styles Control
import StylesControl from 'mapbox-gl-controls/lib/styles';
map.addControl(new StylesControl(), 'top-left');
map.addControl(new StylesControl({
styles: [
{
label: 'Streets',
styleName: 'Mapbox Streets',
styleUrl: 'mapbox://styles/mapbox/streets-v9',
}, {
label: 'Satellite',
styleName: 'Satellite',
styleUrl: 'mapbox://styles/mapbox/satellite-v9',
},
],
onChange: (style) => console.log(style),
}), 'top-left');
Compass Control
import CompassControl from 'mapbox-gl-controls/lib/compass';
map.addControl(new CompassControl(), 'top-right');
Zoom Control
import ZoomControl from 'mapbox-gl-controls/lib/zoom';
map.addControl(new ZoomControl(), 'top-right');
Language Control
import LanguageControl from 'mapbox-gl-controls/lib/language';
map.addControl(new LanguageControl());
const languageControl = new LanguageControl({
language: 'ru',
});
map.addControl(languageControl);
languageControl.setLanguage('mul');
Inspect Control
import InspectControl from 'mapbox-gl-controls/lib/inspect';
map.addControl(new InspectControl(), 'bottom-right');
Tooltip Control
import TooltipControl from 'mapbox-gl-controls/lib/tooltip';
map.addControl(new TooltipControl({ layer: '$fill' }));
API
Compass
Parameters
options
Object (optional, default {}
)
options.instant
Boolean Show compass if bearing is 0 (optional, default true
)
Language
Language can be set dynamically with .setLanguage(lang)
method.
Parameters
options
Object (optional, default {}
)
options.supportedLanguages
Array? (Supported languages)[https://docs.mapbox.com/help/troubleshooting/change-language/]options.language
String? One of the supported languages to applyoptions.excludedLayerIds
Array Array of layer id to exclude from localization (optional, default []
)options.getLanguageField
Function? Accepts language and returns language field
By default fields are name_LANGUAGE
and name
for multi language (mul)
Pitch
Parameters
options
Object (optional, default {}
)
options.zoom
Number? Zoom to while pitch
Ruler
Fires map ruler.on
and ruler.off
events at the beginning and at the end of measuring.
Parameters
options
Object (optional, default {}
)
options.units
String Any units @turf/distance supports (optional, default 'kilometers'
)options.labelFormat
Function? Accepts number and returns label.
Can be used to convert value to any measuring unitsoptions.font
Array Array of fonts. (optional, default ['Roboto Medium']
)
Styles
Parameters
options
Object (optional, default {}
)
options.styles
Array? Array of style objects:
options.onChange
Function? Triggered on style change. Accepts style
object
Tooltip
Shows tooltip on hover
Parameters
options
Object (optional, default {}
)
options.layer
String Layer id to show the tooltip on hover.
If not specified, tooltip will be shown for whole map containeroptions.getContent
Function? Triggered each time mouse moved over layer
option.
Accepts event
object