概览
表示同一 GMSFeatureType
的所有地图项的集合的类,其样式可在客户端上替换。
每个 GMSFeatureType
都有一个对应的 GMSFeatureLayer
。
公共成员函数 | |
(instancetype) | - initWithFeatureType: |
创建用于测试的地图项图层实例。 | |
属性 | |
GMSFeatureType | featureType |
与此图层相关联的地图项类型。 | |
BOOL | 可用 |
确定数据驱动的 GMSFeatureLayer 是否可用。 | |
GMSFeatureStyle *_Nullable(^)(T) | 样式 |
要应用到此图层中所有地图项的样式块。 |
成员函数文档
-(实例类型)initWithFeatureType: | (GMSFeatureType) | featureType |
创建用于测试的地图项图层实例。
此方法应仅用于单元测试。在生产环境中,GMSFeatureLayer
实例只能通过 SDK 创建。
属性说明
- (GMSFeatureType) featureType [read, assign] |
与此图层相关联的地图项类型。
与图层相关联的所有地图项都是此类型。
- (BOOL) 可用 [read, assign] |
确定数据驱动的 GMSFeatureLayer
是否可用。
数据驱动型样式需要 Metal 框架、有效的地图 ID 以及应用地图项类型。如果为 NO
,GMSFeatureLayer
的样式将恢复为默认值,并且不会触发事件。
- (GMSFeatureStyle* _Nullable(^ style)(T)) [read, write, assign] |
要应用到此图层中所有地图项的样式块。
调用 setter 方法时,样式块会应用于视口中的所有可见地图项,对于后续进入视口的地图项,系统会多次运行该块。
将该函数应用于地图图块时,必须具有确定性并返回一致的结果。如果任何地图项的任何样式规范发生变化,则必须重新设置 style
。在不调用 style
setter 的情况下更改样式块的行为将导致出现未定义的行为,包括过时和/或破碎的地图渲染。请参阅下面的示例:
{.swift} var selectedPlaceIDs = Set<String>() var style = FeatureStyle(fill: .red, stroke: .clear, strokeWidth: 0) layer.style = { feature in selectedPlaceIDs.contains(feature.placeID) ? style : nil } selectedPlaceIDs.insert("foo") style = FeatureStyle(fill: .clear, stroke: .blue, strokeWidth: 1.5) layer.style = { feature in selectedPlaceIDs.contains(feature.placeID) ? style : nil }