我们正在开发一个iOS应用,并且在设置MGLFillStyleLayer(MapBox iOS SDK)的填充颜色时遇到问题。
我们有一个很大的.geojson文件,该文件已解析并添加到标准MapBox地图中。 geojson中的每个要素都有一个“颜色”属性,用于设置要素的背景色。颜色将保存为十六进制代码。
是否可以通过使用MapBox表达式或诸如“ forEach Feature-> set fill-color”之类的东西分别为每个特征设置颜色?
我们试图通过使用MapBox提供的样式(https://docs.mapbox.com/ios/api/maps/4.1.1/for-style-authors.html)来更改颜色,但无法弄清楚如何将要素属性加载到快速函数中以生成颜色。 在Mapbox(https://docs.mapbox.com/ios/maps/examples/heatmap-example/)的heatmap示例中,我们看到可以通过NSNumber-Value设置填充颜色
let colorDictionary: [NSNumber: UIColor] = [
0.0: .clear,
0.01: .white,
0.15: UIColor(red: 0.19, green: 0.30, blue: 0.80, alpha: 1.0),
0.5: UIColor(red: 0.73, green: 0.23, blue: 0.25, alpha: 1.0),
1: .yellow
]
也许我们需要定义一些固定值,例如1 =#db7851,2 = ....等等?
要添加geojson数据,我们使用以下代码
let data = try Data(contentsOf: url)
guard let shapeCollectionFeature = try MGLShape(data: data, encoding: String.Encoding.utf8.rawValue) as? MGLShapeCollectionFeature else {
fatalError("Could not cast to specified MGLShapeCollectionFeature")
}
// Create source and add it to the map style.
let source = MGLShapeSource(identifier: "flurstuecke_shape", shape: shapeCollectionFeature, options: nil)
style.addSource(source)
let fillLayer = MGLFillStyleLayer(identifier: "flurstuecke", source: source)
style.addLayer(fillLayer)
出于测试目的,我们添加了一个touch事件,用于更改所选功能的颜色(仅用于测试MapBox表达式)。
let spot = sender.location(in: mapView)
let features = mapView.visibleFeatures(at: spot, styleLayerIdentifiers: Set(["flurstuecke"]))
if let feature = features.first, let fbid = feature.attribute(forKey: "FBID") as? String {
guard let layer = mapView.style?.layer(withIdentifier: "flurstuecke") as? MGLFillStyleLayer
else {
fatalError("Could not cast to specified MGLFillStyleLayer")
}
layer.fillColor = NSExpression(format: "TERNARY(FBID = %@, %@, %@)", fbid, UIColor.green, UIColor.blue)
}
我们希望有人可以给我们一个提示或一些文档,以帮助我们为每个功能着色。谢谢:)
答案 0 :(得分:0)
使用
layer.lineColor = NSExpression(forKeyPath:“ color”)
geojson颜色属性值的示例: “ color”的值可以是:[“ RGB”,255,0,0],“ red”,“#000000”