微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Mapbox 中的聚类点

如何解决Mapbox 中的聚类点

我已经创建了人员分布图,包括它的照片作为图标。现在,我想尝试对它们进行聚类。但是,如果参考 MapBox Docs (https://docs.mapbox.com/mapbox-gl-js/example/cluster/),我对实现它们感到困惑,因为我循环显示该点的每张照片。有人对这个话题有想法吗?这是我的代码

$(document).ready(() => {
$.ajax({
    type: "GET",//YOUR TURN: Replace with csv export link
    url: `${google_sheet_name}/gviz/tq?tqx=out:csv&sheet=${sheet_name}`,dataType: "text",success: function (csvData) {
        makeGeoJSON(csvData);
    }
});

let makeGeoJSON = csvData => {
    csv2geojson.csv2geojson(csvData,{
        latfield: 'latitude',lonfield: 'longitude',delimiter: ','
    },(err,data) => {
        var geo = {
            'id': 'csvData','type': 'circle','source': {
                'type': 'geojson','data': data
            },}

        geo.source.data.features.forEach(marker => {
            var el = document.createElement('img');
            el.className = 'icon-image';
            el.src = marker.properties.image_path

            // make a marker for each feature and add it to the map
            new mapBoxgl.Marker(el)
                .setLngLat(marker.geometry.coordinates)
                .setPopup(new mapBoxgl.Popup({ offset: 25 }) // add popups
                .setHTML('<h3>' + marker.properties.name + '</h3><p>' + marker.properties.description + '</p>'))
                .addTo(map)
        })

        let UseBBox = () => {
            let bBox = turf.bBox(data);
            map.fitBounds(bBox,{
                padding: 50
            })
        }
        UseBBox()
    });
};

});

解决方法

该示例不为每个点渲染标记,而是使用 geojson 数据和图层。当您拥有更多点数时,这会提供更好的性能。 您的案例的基本流程类似于

  • 将数据添加到源以映射如示例中所述
  • 添加2层,一层用于渲染集群图标,另一层用于非集群点
  • 群集图标可以与示例中的相同
  • 非聚簇层可以使用 imagepath 来渲染用户图像

要动态加载和渲染图像,请使用 styleimagemissing 事件。请参阅 https://docs.mapbox.com/mapbox-gl-js/example/add-image-missing-generated/

中的示例

注意添加图片应该完成synchronosly

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?