发布于 2017-06-26 17:11:27
你看到这个API方法了吗?https://www.mapbox.com/mapbox-gl-js/api/#map#setstyle
这样,您就可以为地图设置一个新的样式,例如,单击一个图标或按一个按钮或任何你想要的东西。
将此作为参考,以供借鉴:
mapboxgl.accessToken = 'pk.eyJ1IjoiZmFyYWRheTIiLCJhIjoiTUVHbDl5OCJ9.buFaqIdaIM3iXr1BOYKpsQ';
let map = new mapboxgl.Map({
container: 'map',
style: 'mapbox://styles/mapbox/streets-v9',
center: [-1.77, 52.73],
zoom: 3,
});
let icon = document.getElementById('icon');
icon.addEventListener('click', function(e) {
map.setStyle('mapbox://styles/mapbox/light-v9');
}, false)#icon {
position: absolute;
top: 15px;
left: 15px;
color: black;
}
#map {
height: 500px;
}<link href="https://api.tiles.mapbox.com/mapbox-gl-js/v0.38.0/mapbox-gl.css" rel="stylesheet"/>
<script src="https://api.tiles.mapbox.com/mapbox-gl-js/v0.38.0/mapbox-gl.js"></script>
<div id="map"></div>
<button id="icon">
Switch layers
</button>
发布于 2017-06-27 01:48:09
您想要的是一个切换层的“控件”。Mapbox不包含这样的东西,也没有一个被列为插件 (尚未)。
您应该使用Mapbox的iControl类来创建控件,然后按照Mapbox的说明添加样式和行为:
function LayerSwitchControl() { }
LayerSwitchControl.prototype.onAdd = function(map) {
this._map = map;
this._container = document.createElement('div');
this._container.className = 'mapboxgl-ctrl';
// change this next line to include a layer-switching icon
this._container.textContent = 'Hello, world';
return this._container;
};
LayerSwitchControl.prototype.onRemove = function () {
this._container.parentNode.removeChild(this._container);
this._map = undefined;
};然后,您需要向以下内容添加代码:
click事件。发布于 2022-04-15 17:52:32
这是我的工作密码,

这是变焦电平控制

https://stackoverflow.com/questions/44754214
复制相似问题