gpt4 book ai didi

mapbox - 如何使用mapbox在相同坐标上设置多个标记?

转载 作者:行者123 更新时间:2023-12-04 14:15:56 27 4
gpt4 key购买 nike

我使用 mapbox GL 来引用总部位于非洲的视频游戏公司。所有这些公司都放在 map 上:https://africangamingnetworks.com/

当我有多个具有相同坐标的标记(例如喀麦隆雅温得的两家公司)时,mapbox 仅显示第一个,因为它们具有相同的纬度和经度。

我该怎么做才能显示具有相同坐标的所有标记?

提前致谢。

<%@ include file="/init.jsp"%>
<div class="shadow row">
<div class=" col-12 rounded-sm " id='map'
style='height: 800px;'></div>

</div>


<script>
mapboxgl.accessToken = 'pk.eyJ1Ijoia29zdGVkIiMWQzbXA3M2ZxYmd5MnkifQ.faOl-gGzibR9yMpZ-i7FTQ';
var map = new mapboxgl.Map({
container : 'map',
style : 'mapbox://styles/mapbox/streets-v11',
zoom : 2
// starting zoom
});

// Add zoom and rotation controls to the map.
map.addControl(new mapboxgl.NavigationControl());

var studioListComplete = [];

<c:forEach var="studio" items="${studioList}">

studioListComplete
.push({
"type" : "Feature",
"properties" : {
"description" : "<strong>${studio.studioName} (${studio.country})</strong> <br/><br/>" +
"${studio.studioDescription}<br/><br/>"+
"<strong>City : </strong>${studio.city}<br/>"+
"<strong>Number of employees : </strong>${studio.numberOfEmployees}<br/>"+
"<strong>Phone : </strong>${studio.phoneNumber}<br/><br/>"+

"<a href=\"${studio.webSiteUrl}\" target=\"_blank\">Please visit our website</a>",
"icon": "rocket"
},
"geometry" : {
"type" : "Point",
"coordinates" : [ "${studio.longitude}",
"${studio.latitude}" ]
}
});
//var marker = new mapboxgl.Marker()
//.setLngLat(["${studio.longitude}", "${studio.latitude}"])
//.addTo(map);
</c:forEach>

console.log(studioListComplete);

map.on('load', function() {
// Add a layer showing the places.
map.addLayer({
"id" : "places",
"type" : "symbol",
"source" : {
"type" : "geojson",
"data" : {
"type" : "FeatureCollection",
"features" : studioListComplete
}
},
"layout" : {
"icon-image" : "{icon}-15",
'icon-size': 1,
"icon-allow-overlap" : true
}
});

// When a click event occurs on a feature in the places layer, open a popup at the
// location of the feature, with description HTML from its properties.
map.on('click', 'places', function(e) {
var coordinates = e.features[0].geometry.coordinates.slice();
var description = e.features[0].properties.description;

// Ensure that if the map is zoomed out such that multiple
// copies of the feature are visible, the popup appears
// over the copy being pointed to.
while (Math.abs(e.lngLat.lng - coordinates[0]) > 180) {
coordinates[0] += e.lngLat.lng > coordinates[0] ? 360 : -360;
}

new mapboxgl.Popup().setLngLat(coordinates).setHTML(description)
.addTo(map);
});

// Change the cursor to a pointer when the mouse is over the places layer.
map.on('mouseenter', 'places', function() {
map.getCanvas().style.cursor = 'pointer';
});

// Change it back to a pointer when it leaves.
map.on('mouseleave', 'places', function() {
map.getCanvas().style.cursor = '';
});
});
</script>

<style>
//Style is here

</style>

最佳答案

如果您希望为具有相同坐标的点显示两个离散标记,最好的做法是稍微修改其中一个点的纬度和经度,使其不直接位于另一个点的上方。

或者,如果无法修改坐标数据,您可以探索对数据进行聚类,以便在视觉上清楚地看到多个公司位于同一聚类中。 This example展示了如何使用默认圆形图层创建集群并为其设置样式,以及 this example展示了如何高度定制视觉集群。

关于mapbox - 如何使用mapbox在相同坐标上设置多个标记?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60332076/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com