是否可以利用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);
}
我觉得必须有更好的方法来做到这一点。
答案 0 :(得分:1)
目前,Mapbox GL不支持 - simplestyle-spec。目前GeoJSON支持仍然非常原始,因为焦点最初是在矢量切片上。 simplestyle-spec支持肯定在计划中。