首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >填充挤压无法正确显示mapbox-gl-js

填充挤压无法正确显示mapbox-gl-js
EN

Stack Overflow用户
提问于 2018-05-28 16:47:23
回答 1查看 877关注 0票数 1

这就是我的数据集的样子:

西雅图犯罪数据集

我想要做的是根据频率列改变挤压高度。我可以成功地显示这些点,但每当我使用填充挤压时,我都在挣扎。你能帮我指出正确的方向吗?

代码语言:javascript
复制
    map.addLayer({
    'id': 'total',
    'type': 'circle',
    'source': {
        type: 'vector',
        url: 'mapbox://askakdagr8.9tklrr8g'
    },
    'source-layer': 'GroupedOutput-9i6ink',
    'paint': {
        // make circles larger as the user zooms from z12 to z22
        'circle-radius': {
            'base': 1.75,
            'stops': [
                [12, 2],
                [22, 180]
            ]
        },
        'circle-color': '#ff7770'
    }
});
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-29 06:28:19

由于mapbox-gl-js目前没有挤压圆的功能,所以需要用多边形替换点,然后用函数turf.circle插值圆。

代码语言:javascript
复制
  map.on('sourcedata', function(e) {
    if (e.sourceId !== 'total') return
    if (e.isSourceLoaded !== true) return

    var data = {
      "type": "FeatureCollection",
      "features": []
    }
    e.source.data.features.forEach(function(f) {
      var object = turf.centerOfMass(f)
      var center = object.geometry.coordinates
      var radius = 10;
      var options = {
        steps: 16,
        units: 'meters',
        properties: object.properties
      };
      data.features.push(turf.circle(center, radius, options))
    })
    map.getSource('extrusion').setData(data);
  })

[ http://jsfiddle.net/zjLek40n/ ]

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50570639

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档