заполнение-выдавливание не отображается правильно с mapbox-gl-js - PullRequest
0 голосов
/ 28 мая 2018

Вот так выглядит мой набор данных:

Набор данных Сиэтл Криминал

Что я хочу сделать, это изменить высоту выдавливания на основе столбца частоты.Я могу успешно отобразить их как точки, но я борюсь с этим всякий раз, когда использую заполнение-выдавливание.Можете ли вы помочь направить меня в правильном направлении?

    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'
    }
});

1 Ответ

0 голосов
/ 29 мая 2018

Поскольку mapbox-gl-js в настоящее время не имеет функциональных возможностей для выдавливания круга, необходимо заменить точки на многоугольник и интерполировать круг, например, функцией turf.circle:

  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/]

...