如何使用 mapbox 在同一坐标上设置多个标记?
How to set multiple markers on same coordinates with mapbox?
我使用 mapbox GL 来参考非洲的视频游戏公司。所有这些公司都放在地图上: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 shows how to create and style clusters using a default circle layer, and this example 展示了如何高度自定义视觉集群。
我使用 mapbox GL 来参考非洲的视频游戏公司。所有这些公司都放在地图上: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 shows how to create and style clusters using a default circle layer, and this example 展示了如何高度自定义视觉集群。