控件

定位

GeolocateControl在新页面打开 提供一个按钮,该按钮使用浏览器的 Geolocation API在新页面打开 在地图上定位用户。

map.addControl(new mapboxgl.GeolocateControl())

全屏

FullscreenControl在新页面打开 可以切换地图的全屏模式。

map.addControl(new mapboxgl.FullscreenControl())

导航

NavigationControl在新页面打开 包含缩放和指南针。

map.addControl(new mapboxgl.NavigationControl({ visualizePitch: true }))

比例尺

ScaleControl在新页面打开 显示地图上的距离与地面上相应距离的比率。

map.addControl(new mapboxgl.ScaleControl())

自定义

Mapbox GL JS 提供了 IControl 接口。自定义控件必须实现 onAddonRemove 方法,并且有一个 HTML 元素,通常为 div 元素。如果要使用 Mapbox GL JS 默认控件样式,需要给元素添加 mapboxgl-ctrl 样式。

官方示例

// es6 类
class HelloWorldControl {
  onAdd(map) {
    this._map = map
    this._container = document.createElement('div')
    this._container.className = 'mapboxgl-ctrl'
    this._container.textContent = 'Hello, world'
    return this._container
  }

  onRemove() {
    this._container.parentNode.removeChild(this._container)
    this._map = undefined
  }
}

// es5 原型类
function HelloWorldControl() {}

HelloWorldControl.prototype.onAdd = function (map) {
  this._map = map
  this._container = document.createElement('div')
  this._container.className = 'mapboxgl-ctrl'
  this._container.textContent = 'Hello, world'
  return this._container
}

HelloWorldControl.prototype.onRemove = function () {
  this._container.parentNode.removeChild(this._container)
  this._map = undefined
}

城市选择器

一个快速定位城市的控件。GitHub 地址:城市选择器在新页面打开