嵌入式 GeoJSON 样式是否适用于 Mapbox GL?

Do embedded GeoJSON styles work with Mapbox GL?

是否可以利用 GeoJSON 数据源的内置 properties 属性自动设置 Mapbox GL 地图的样式,而无需预先指定样式?

我有一个用例,我在 GeoJSON LineString 中动态加载需要特定颜色的数据,并且它已经内置了样式数据:

{"properties": {"color": "#ffff33"...

现在,我有一个相当不雅的设置,其中解析出相关颜色,将其转换为样式,并在每次加载时将其添加到地图中:

    $scope.patternPropToStyle = function(props) {
      var id = 'pattern' + props.pid;
      var style = {
        "id": id,
        "type": "line",
        "source": id,
        "render": {
          "$type": "LineString",
          "line-join": "round",
          "line-cap": "round"
        },
        "paint": {
          "line-color": props.color,
          "line-width": 8
        }
      }
      $scope._mapStyle.layers.push(style);
      $scope._map.setStyle($scope._mapStyle);
    }

我觉得必须有更好的方法来做到这一点。

目前,不 - simplestyle-spec 在 Mapbox GL 中不受支持。目前 GeoJSON 支持仍然非常原始,因为最初的重点是矢量切片。 simplestyle-spec 支持肯定在计划中。