maplibre-gl 2.0.4 → 2.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (319) hide show
  1. package/build/{banner.js → banner.ts} +1 -1
  2. package/build/generate-query-test-fixtures.ts +123 -0
  3. package/build/generate-shaders.ts +35 -0
  4. package/build/generate-struct-arrays.ts +7 -7
  5. package/build/generate-style-code.ts +8 -8
  6. package/build/generate-style-spec.ts +5 -4
  7. package/build/generate-typings.ts +16 -0
  8. package/build/readme.md +8 -18
  9. package/build/release-notes.js +9 -13
  10. package/build/{rollup_plugin_minify_style_spec.js → rollup_plugin_minify_style_spec.ts} +4 -3
  11. package/build/{rollup_plugins.js → rollup_plugins.ts} +12 -26
  12. package/dist/maplibre-gl-dev.js +54885 -0
  13. package/dist/maplibre-gl.css +1 -1
  14. package/dist/maplibre-gl.d.ts +1583 -1023
  15. package/dist/maplibre-gl.js +3 -3
  16. package/dist/maplibre-gl.js.map +1 -1
  17. package/package.json +99 -141
  18. package/src/css/maplibre-gl.css +36 -36
  19. package/src/data/{array_types.ts → array_types.g.ts} +0 -0
  20. package/src/data/bucket/circle_bucket.ts +1 -1
  21. package/src/data/bucket/fill_bucket.test.ts +1 -1
  22. package/src/data/bucket/fill_bucket.ts +4 -4
  23. package/src/data/bucket/fill_extrusion_bucket.ts +1 -1
  24. package/src/data/bucket/line_bucket.test.ts +1 -1
  25. package/src/data/bucket/line_bucket.ts +6 -6
  26. package/src/data/bucket/symbol_bucket.test.ts +16 -16
  27. package/src/data/bucket/symbol_bucket.ts +56 -56
  28. package/src/data/bucket.ts +43 -43
  29. package/src/data/dem_data.ts +12 -12
  30. package/src/data/evaluation_feature.ts +10 -10
  31. package/src/data/feature_index.ts +37 -37
  32. package/src/data/feature_position_map.ts +5 -5
  33. package/src/data/index_array_type.ts +1 -1
  34. package/src/data/load_geometry.test.ts +1 -1
  35. package/src/data/program_configuration.ts +47 -47
  36. package/src/data/segment.ts +14 -14
  37. package/src/geo/edge_insets.ts +2 -2
  38. package/src/geo/lng_lat.ts +4 -4
  39. package/src/geo/lng_lat_bounds.ts +35 -35
  40. package/src/geo/mercator_coordinate.ts +5 -5
  41. package/src/geo/transform.test.ts +1 -1
  42. package/src/geo/transform.ts +14 -14
  43. package/src/gl/context.ts +3 -3
  44. package/src/gl/types.ts +19 -19
  45. package/src/gl/value.ts +6 -6
  46. package/src/gl/vertex_buffer.test.ts +1 -1
  47. package/src/index.ts +24 -9
  48. package/src/render/draw_circle.ts +8 -8
  49. package/src/render/draw_collision_debug.ts +5 -5
  50. package/src/render/draw_debug.ts +1 -1
  51. package/src/render/draw_line.ts +4 -4
  52. package/src/render/draw_symbol.ts +21 -21
  53. package/src/render/glyph_atlas.ts +12 -12
  54. package/src/render/glyph_manager.test.ts +10 -21
  55. package/src/render/glyph_manager.ts +34 -33
  56. package/src/render/image_manager.ts +4 -4
  57. package/src/render/painter.ts +16 -14
  58. package/src/render/program/background_program.ts +29 -29
  59. package/src/render/program/circle_program.ts +11 -11
  60. package/src/render/program/clipping_mask_program.ts +1 -1
  61. package/src/render/program/collision_program.ts +9 -9
  62. package/src/render/program/debug_program.ts +4 -4
  63. package/src/render/program/fill_extrusion_program.ts +31 -31
  64. package/src/render/program/fill_program.ts +29 -29
  65. package/src/render/program/heatmap_program.ts +12 -12
  66. package/src/render/program/hillshade_program.ts +12 -12
  67. package/src/render/program/line_program.ts +41 -41
  68. package/src/render/program/pattern.ts +28 -28
  69. package/src/render/program/raster_program.ts +21 -21
  70. package/src/render/program/symbol_program.ts +97 -97
  71. package/src/render/program.ts +25 -25
  72. package/src/render/texture.ts +9 -9
  73. package/src/render/uniform_binding.ts +1 -1
  74. package/src/render/vertex_array_object.ts +13 -13
  75. package/src/shaders/_prelude.fragment.glsl.g.ts +2 -0
  76. package/src/shaders/_prelude.vertex.glsl.g.ts +2 -0
  77. package/src/shaders/background.fragment.glsl.g.ts +2 -0
  78. package/src/shaders/background.vertex.glsl.g.ts +2 -0
  79. package/src/shaders/background_pattern.fragment.glsl.g.ts +2 -0
  80. package/src/shaders/background_pattern.vertex.glsl.g.ts +2 -0
  81. package/src/shaders/circle.fragment.glsl.g.ts +2 -0
  82. package/src/shaders/circle.vertex.glsl.g.ts +2 -0
  83. package/src/shaders/clipping_mask.fragment.glsl.g.ts +2 -0
  84. package/src/shaders/clipping_mask.vertex.glsl.g.ts +2 -0
  85. package/src/shaders/collision_box.fragment.glsl.g.ts +2 -0
  86. package/src/shaders/collision_box.vertex.glsl.g.ts +2 -0
  87. package/src/shaders/collision_circle.fragment.glsl.g.ts +2 -0
  88. package/src/shaders/collision_circle.vertex.glsl.g.ts +2 -0
  89. package/src/shaders/debug.fragment.glsl.g.ts +2 -0
  90. package/src/shaders/debug.vertex.glsl.g.ts +2 -0
  91. package/src/shaders/fill.fragment.glsl.g.ts +2 -0
  92. package/src/shaders/fill.vertex.glsl.g.ts +2 -0
  93. package/src/shaders/fill_extrusion.fragment.glsl.g.ts +2 -0
  94. package/src/shaders/fill_extrusion.vertex.glsl.g.ts +2 -0
  95. package/src/shaders/fill_extrusion_pattern.fragment.glsl.g.ts +2 -0
  96. package/src/shaders/fill_extrusion_pattern.vertex.glsl.g.ts +2 -0
  97. package/src/shaders/fill_outline.fragment.glsl.g.ts +2 -0
  98. package/src/shaders/fill_outline.vertex.glsl.g.ts +2 -0
  99. package/src/shaders/fill_outline_pattern.fragment.glsl.g.ts +2 -0
  100. package/src/shaders/fill_outline_pattern.vertex.glsl.g.ts +2 -0
  101. package/src/shaders/fill_pattern.fragment.glsl.g.ts +2 -0
  102. package/src/shaders/fill_pattern.vertex.glsl.g.ts +2 -0
  103. package/src/shaders/heatmap.fragment.glsl.g.ts +2 -0
  104. package/src/shaders/heatmap.vertex.glsl.g.ts +2 -0
  105. package/src/shaders/heatmap_texture.fragment.glsl.g.ts +2 -0
  106. package/src/shaders/heatmap_texture.vertex.glsl.g.ts +2 -0
  107. package/src/shaders/hillshade.fragment.glsl.g.ts +2 -0
  108. package/src/shaders/hillshade.vertex.glsl.g.ts +2 -0
  109. package/src/shaders/hillshade_prepare.fragment.glsl.g.ts +2 -0
  110. package/src/shaders/hillshade_prepare.vertex.glsl.g.ts +2 -0
  111. package/src/shaders/line.fragment.glsl.g.ts +2 -0
  112. package/src/shaders/line.vertex.glsl.g.ts +2 -0
  113. package/src/shaders/line_gradient.fragment.glsl.g.ts +2 -0
  114. package/src/shaders/line_gradient.vertex.glsl.g.ts +2 -0
  115. package/src/shaders/line_pattern.fragment.glsl.g.ts +2 -0
  116. package/src/shaders/line_pattern.vertex.glsl.g.ts +2 -0
  117. package/src/shaders/line_sdf.fragment.glsl.g.ts +2 -0
  118. package/src/shaders/line_sdf.vertex.glsl.g.ts +2 -0
  119. package/src/shaders/raster.fragment.glsl.g.ts +2 -0
  120. package/src/shaders/raster.vertex.glsl.g.ts +2 -0
  121. package/src/shaders/shaders.ts +52 -55
  122. package/src/shaders/symbol_icon.fragment.glsl.g.ts +2 -0
  123. package/src/shaders/symbol_icon.vertex.glsl.g.ts +2 -0
  124. package/src/shaders/symbol_sdf.fragment.glsl.g.ts +2 -0
  125. package/src/shaders/symbol_sdf.vertex.glsl.g.ts +2 -0
  126. package/src/shaders/symbol_text_and_icon.fragment.glsl.g.ts +2 -0
  127. package/src/shaders/symbol_text_and_icon.vertex.glsl.g.ts +2 -0
  128. package/src/source/canvas_source.test.ts +11 -12
  129. package/src/source/canvas_source.ts +4 -4
  130. package/src/source/geojson_source.test.ts +2 -1
  131. package/src/source/geojson_source.ts +1 -1
  132. package/src/source/geojson_worker_source.ts +23 -23
  133. package/src/source/geojson_wrapper.ts +8 -8
  134. package/src/source/image_source.test.ts +153 -0
  135. package/src/source/image_source.ts +6 -6
  136. package/src/source/pixels_to_tile_units.ts +6 -6
  137. package/src/source/query_features.ts +20 -20
  138. package/src/source/raster_dem_tile_source.test.ts +4 -3
  139. package/src/source/raster_dem_tile_source.ts +1 -1
  140. package/src/source/raster_tile_source.test.ts +4 -3
  141. package/src/source/raster_tile_source.ts +1 -1
  142. package/src/source/rtl_text_plugin.ts +10 -10
  143. package/src/source/source.ts +29 -29
  144. package/src/source/source_cache.test.ts +33 -1
  145. package/src/source/source_cache.ts +7 -5
  146. package/src/source/source_state.ts +1 -1
  147. package/src/source/tile.test.ts +3 -3
  148. package/src/source/tile.ts +15 -15
  149. package/src/source/tile_cache.test.ts +6 -4
  150. package/src/source/tile_cache.ts +6 -6
  151. package/src/source/tile_id.test.ts +10 -13
  152. package/src/source/tile_id.ts +2 -2
  153. package/src/source/vector_tile_source.test.ts +17 -5
  154. package/src/source/vector_tile_source.ts +4 -5
  155. package/src/source/vector_tile_worker_source.test.ts +4 -4
  156. package/src/source/vector_tile_worker_source.ts +5 -5
  157. package/src/source/worker.test.ts +1 -1
  158. package/src/source/worker.ts +22 -22
  159. package/src/source/worker_source.ts +56 -56
  160. package/src/source/worker_tile.ts +4 -4
  161. package/src/style/evaluation_parameters.ts +3 -3
  162. package/src/style/format_section_override.test.ts +1 -1
  163. package/src/style/light.ts +10 -10
  164. package/src/style/load_glyph_range.test.ts +3 -5
  165. package/src/style/load_glyph_range.ts +6 -6
  166. package/src/style/load_sprite.ts +5 -4
  167. package/src/style/pauseable_placement.ts +1 -1
  168. package/src/style/properties.ts +70 -70
  169. package/src/style/query_utils.ts +7 -7
  170. package/src/style/style.test.ts +26 -15
  171. package/src/style/style.ts +30 -30
  172. package/src/style/style_glyph.ts +8 -8
  173. package/src/style/style_image.ts +58 -58
  174. package/src/style/style_layer/background_style_layer.ts +2 -2
  175. package/src/style/style_layer/{background_style_layer_properties.ts → background_style_layer_properties.g.ts} +0 -0
  176. package/src/style/style_layer/circle_style_layer.ts +10 -10
  177. package/src/style/style_layer/{circle_style_layer_properties.ts → circle_style_layer_properties.g.ts} +0 -0
  178. package/src/style/style_layer/custom_style_layer.ts +19 -19
  179. package/src/style/style_layer/fill_extrusion_style_layer.ts +11 -11
  180. package/src/style/style_layer/{fill_extrusion_style_layer_properties.ts → fill_extrusion_style_layer_properties.g.ts} +0 -0
  181. package/src/style/style_layer/fill_style_layer.ts +9 -9
  182. package/src/style/style_layer/{fill_style_layer_properties.ts → fill_style_layer_properties.g.ts} +0 -0
  183. package/src/style/style_layer/heatmap_style_layer.ts +2 -2
  184. package/src/style/style_layer/{heatmap_style_layer_properties.ts → heatmap_style_layer_properties.g.ts} +0 -0
  185. package/src/style/style_layer/hillshade_style_layer.ts +2 -2
  186. package/src/style/style_layer/{hillshade_style_layer_properties.ts → hillshade_style_layer_properties.g.ts} +0 -0
  187. package/src/style/style_layer/line_style_layer.ts +9 -9
  188. package/src/style/style_layer/{line_style_layer_properties.ts → line_style_layer_properties.g.ts} +0 -0
  189. package/src/style/style_layer/raster_style_layer.ts +2 -2
  190. package/src/style/style_layer/{raster_style_layer_properties.ts → raster_style_layer_properties.g.ts} +0 -0
  191. package/src/style/style_layer/symbol_style_layer.ts +26 -7
  192. package/src/style/style_layer/{symbol_style_layer_properties.ts → symbol_style_layer_properties.g.ts} +6 -0
  193. package/src/style/style_layer.ts +10 -10
  194. package/src/style/style_layer_index.ts +3 -3
  195. package/src/style/validate_style.ts +15 -15
  196. package/src/style-spec/CHANGELOG.md +6 -0
  197. package/src/style-spec/error/validation_error.ts +1 -1
  198. package/src/style-spec/expression/compound_expression.ts +3 -3
  199. package/src/style-spec/expression/definitions/format.ts +11 -11
  200. package/src/style-spec/expression/definitions/interpolate.ts +5 -5
  201. package/src/style-spec/expression/definitions/match.ts +2 -2
  202. package/src/style-spec/expression/definitions/number_format.ts +11 -11
  203. package/src/style-spec/expression/expression.ts +8 -8
  204. package/src/style-spec/expression/index.ts +97 -97
  205. package/src/style-spec/expression/parsing_context.ts +11 -11
  206. package/src/style-spec/expression/types/collator.ts +9 -9
  207. package/src/style-spec/expression/types/resolved_image.ts +2 -2
  208. package/src/style-spec/expression/types.ts +14 -14
  209. package/src/style-spec/expression/values.ts +1 -1
  210. package/src/style-spec/feature_filter/index.ts +66 -66
  211. package/src/style-spec/function/convert.ts +3 -3
  212. package/src/style-spec/package.json +1 -1
  213. package/src/style-spec/reference/v8.json +68 -2
  214. package/src/style-spec/style-spec.ts +44 -44
  215. package/src/style-spec/types.ts +2 -0
  216. package/src/style-spec/util/color_spaces.ts +8 -8
  217. package/src/style-spec/util/result.ts +4 -4
  218. package/src/style-spec/validate/validate_filter.ts +58 -58
  219. package/src/style-spec/validate/validate_source.ts +63 -63
  220. package/src/style-spec/visit.ts +11 -11
  221. package/src/symbol/collision_feature.test.ts +1 -1
  222. package/src/symbol/collision_feature.ts +10 -10
  223. package/src/symbol/collision_index.ts +43 -43
  224. package/src/symbol/cross_tile_symbol_index.ts +17 -17
  225. package/src/symbol/get_anchors.ts +16 -16
  226. package/src/symbol/grid_index.test.ts +42 -19
  227. package/src/symbol/grid_index.ts +69 -40
  228. package/src/symbol/placement.ts +124 -95
  229. package/src/symbol/projection.ts +30 -30
  230. package/src/symbol/quads.ts +30 -30
  231. package/src/symbol/shaping.ts +160 -160
  232. package/src/symbol/symbol_layout.ts +119 -119
  233. package/src/symbol/symbol_size.ts +29 -29
  234. package/src/symbol/symbol_style_layer.test.ts +49 -2
  235. package/src/types/cancelable.ts +1 -1
  236. package/src/types/tilejson.ts +13 -13
  237. package/src/ui/anchor.ts +1 -1
  238. package/src/ui/camera.test.ts +9 -9
  239. package/src/ui/camera.ts +26 -18
  240. package/src/ui/control/attribution_control.test.ts +51 -16
  241. package/src/ui/control/attribution_control.ts +35 -16
  242. package/src/ui/control/control.ts +40 -40
  243. package/src/ui/control/fullscreen_control.ts +1 -1
  244. package/src/ui/control/geolocate_control.test.ts +1 -1
  245. package/src/ui/control/geolocate_control.ts +102 -102
  246. package/src/ui/control/logo_control.test.ts +5 -4
  247. package/src/ui/control/navigation_control.ts +3 -3
  248. package/src/ui/control/scale_control.test.ts +2 -2
  249. package/src/ui/control/scale_control.ts +5 -5
  250. package/src/ui/events.ts +289 -200
  251. package/src/ui/handler/box_zoom.test.ts +1 -1
  252. package/src/ui/handler/box_zoom.ts +1 -1
  253. package/src/ui/handler/dblclick_zoom.test.ts +1 -1
  254. package/src/ui/handler/drag_pan.test.ts +1 -1
  255. package/src/ui/handler/drag_rotate.test.ts +1 -1
  256. package/src/ui/handler/keyboard.test.ts +1 -1
  257. package/src/ui/handler/keyboard.ts +51 -51
  258. package/src/ui/handler/map_event.test.ts +1 -1
  259. package/src/ui/handler/map_event.ts +1 -1
  260. package/src/ui/handler/mouse.ts +1 -1
  261. package/src/ui/handler/mouse_rotate.test.ts +1 -1
  262. package/src/ui/handler/scroll_zoom.test.ts +3 -2
  263. package/src/ui/handler/scroll_zoom.ts +9 -9
  264. package/src/ui/handler/shim/drag_pan.ts +4 -4
  265. package/src/ui/handler/shim/drag_rotate.ts +1 -1
  266. package/src/ui/handler/shim/touch_zoom_rotate.ts +1 -1
  267. package/src/ui/handler/tap_recognizer.ts +4 -4
  268. package/src/ui/handler/touch_pan.ts +2 -2
  269. package/src/ui/handler/touch_zoom_rotate.test.ts +1 -1
  270. package/src/ui/handler/touch_zoom_rotate.ts +1 -1
  271. package/src/ui/handler_inertia.ts +6 -6
  272. package/src/ui/handler_manager.ts +44 -44
  273. package/src/ui/map/isMoving.test.ts +1 -1
  274. package/src/ui/map/isRotating.test.ts +1 -1
  275. package/src/ui/map/isZooming.test.ts +1 -1
  276. package/src/ui/map.test.ts +87 -14
  277. package/src/ui/map.ts +138 -108
  278. package/src/ui/map_events.test.ts +1 -1
  279. package/src/ui/marker.test.ts +12 -12
  280. package/src/ui/marker.ts +37 -37
  281. package/src/ui/popup.test.ts +7 -7
  282. package/src/ui/popup.ts +9 -9
  283. package/src/util/actor.test.ts +41 -10
  284. package/src/util/actor.ts +8 -8
  285. package/src/util/ajax.test.ts +214 -0
  286. package/src/util/ajax.ts +51 -30
  287. package/src/util/browser.ts +1 -1
  288. package/src/util/classify_rings.test.ts +1 -1
  289. package/src/util/color_ramp.ts +5 -5
  290. package/src/util/config.ts +2 -2
  291. package/src/util/dispatcher.ts +1 -1
  292. package/src/util/dom.ts +2 -2
  293. package/src/util/evented.ts +1 -1
  294. package/src/util/find_pole_of_inaccessibility.ts +3 -3
  295. package/src/util/image.ts +5 -5
  296. package/src/util/performance.ts +7 -7
  297. package/src/util/request_manager.ts +4 -4
  298. package/src/util/resolve_tokens.ts +4 -4
  299. package/src/util/struct_array.test.ts +1 -1
  300. package/src/util/struct_array.ts +15 -15
  301. package/src/util/task_queue.ts +3 -3
  302. package/src/util/test/util.ts +14 -0
  303. package/src/util/tile_request_cache.ts +3 -3
  304. package/src/util/transferable_grid_index.ts +4 -4
  305. package/src/util/util.ts +8 -8
  306. package/src/util/web_worker.ts +4 -68
  307. package/src/util/web_worker_transfer.test.ts +3 -0
  308. package/src/util/web_worker_transfer.ts +21 -17
  309. package/src/util/worker_pool.ts +1 -1
  310. package/build/.eslintrc +0 -21
  311. package/build/glsl_to_js.js +0 -12
  312. package/build/post-ts-build.js +0 -43
  313. package/build/release-notes.md.ejs +0 -8
  314. package/build/test/build-tape.js +0 -17
  315. package/build/web_worker_replacement.js +0 -5
  316. package/dist/package.json +0 -1
  317. package/src/style-spec/validate_spec.test.ts +0 -29
  318. package/src/symbol/shaping.test.ts +0 -392
  319. package/src/types/glsl.d.ts +0 -4
@@ -3,18 +3,18 @@ import {RGBAImage} from '../util/image';
3
3
  import type Map from '../ui/map';
4
4
 
5
5
  export type StyleImageData = {
6
- data: RGBAImage;
7
- version: number;
8
- hasRenderCallback?: boolean;
9
- userImage?: StyleImageInterface;
6
+ data: RGBAImage;
7
+ version: number;
8
+ hasRenderCallback?: boolean;
9
+ userImage?: StyleImageInterface;
10
10
  };
11
11
 
12
12
  export type StyleImageMetadata = {
13
- pixelRatio: number;
14
- sdf: boolean;
15
- stretchX?: Array<[number, number]>;
16
- stretchY?: Array<[number, number]>;
17
- content?: [number, number, number, number];
13
+ pixelRatio: number;
14
+ sdf: boolean;
15
+ stretchX?: Array<[number, number]>;
16
+ stretchY?: Array<[number, number]>;
17
+ content?: [number, number, number, number];
18
18
  };
19
19
 
20
20
  export type StyleImage = StyleImageData & StyleImageMetadata;
@@ -73,55 +73,55 @@ export type StyleImage = StyleImageData & StyleImageMetadata;
73
73
  */
74
74
 
75
75
  export interface StyleImageInterface {
76
- /**
77
- * @property {number} width
78
- */
79
- width: number;
80
- /**
81
- * @property {number} height
82
- */
83
- height: number;
84
- /**
85
- * @property {Uint8Array | Uint8ClampedArray} data
86
- */
87
- data: Uint8Array | Uint8ClampedArray;
88
- /**
89
- * This method is called once before every frame where the icon will be used.
90
- * The method can optionally update the image's `data` member with a new image.
91
- *
92
- * If the method updates the image it must return `true` to commit the change.
93
- * If the method returns `false` or nothing the image is assumed to not have changed.
94
- *
95
- * If updates are infrequent it maybe easier to use {@link Map#updateImage} to update
96
- * the image instead of implementing this method.
97
- *
98
- * @function
99
- * @memberof StyleImageInterface
100
- * @instance
101
- * @name render
102
- * @return {boolean} `true` if this method updated the image. `false` if the image was not changed.
103
- */
104
- render?: () => boolean;
105
- /**
106
- * Optional method called when the layer has been added to the Map with {@link Map#addImage}.
107
- *
108
- * @function
109
- * @memberof StyleImageInterface
110
- * @instance
111
- * @name onAdd
112
- * @param {Map} map The Map this custom layer was just added to.
113
- */
114
- onAdd?: (map: Map, id: string) => void;
115
- /**
116
- * Optional method called when the icon is removed from the map with {@link Map#removeImage}.
117
- * This gives the image a chance to clean up resources and event listeners.
118
- *
119
- * @function
120
- * @memberof StyleImageInterface
121
- * @instance
122
- * @name onRemove
123
- */
124
- onRemove?: () => void;
76
+ /**
77
+ * @property {number} width
78
+ */
79
+ width: number;
80
+ /**
81
+ * @property {number} height
82
+ */
83
+ height: number;
84
+ /**
85
+ * @property {Uint8Array | Uint8ClampedArray} data
86
+ */
87
+ data: Uint8Array | Uint8ClampedArray;
88
+ /**
89
+ * This method is called once before every frame where the icon will be used.
90
+ * The method can optionally update the image's `data` member with a new image.
91
+ *
92
+ * If the method updates the image it must return `true` to commit the change.
93
+ * If the method returns `false` or nothing the image is assumed to not have changed.
94
+ *
95
+ * If updates are infrequent it maybe easier to use {@link Map#updateImage} to update
96
+ * the image instead of implementing this method.
97
+ *
98
+ * @function
99
+ * @memberof StyleImageInterface
100
+ * @instance
101
+ * @name render
102
+ * @return {boolean} `true` if this method updated the image. `false` if the image was not changed.
103
+ */
104
+ render?: () => boolean;
105
+ /**
106
+ * Optional method called when the layer has been added to the Map with {@link Map#addImage}.
107
+ *
108
+ * @function
109
+ * @memberof StyleImageInterface
110
+ * @instance
111
+ * @name onAdd
112
+ * @param {Map} map The Map this custom layer was just added to.
113
+ */
114
+ onAdd?: (map: Map, id: string) => void;
115
+ /**
116
+ * Optional method called when the icon is removed from the map with {@link Map#removeImage}.
117
+ * This gives the image a chance to clean up resources and event listeners.
118
+ *
119
+ * @function
120
+ * @memberof StyleImageInterface
121
+ * @instance
122
+ * @name onRemove
123
+ */
124
+ onRemove?: () => void;
125
125
  }
126
126
 
127
127
  export function renderStyleImage(image: StyleImage) {
@@ -1,9 +1,9 @@
1
1
  import StyleLayer from '../style_layer';
2
2
 
3
- import properties, {BackgroundPaintPropsPossiblyEvaluated} from './background_style_layer_properties';
3
+ import properties, {BackgroundPaintPropsPossiblyEvaluated} from './background_style_layer_properties.g';
4
4
  import {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';
5
5
 
6
- import type {BackgroundPaintProps} from './background_style_layer_properties';
6
+ import type {BackgroundPaintProps} from './background_style_layer_properties.g';
7
7
  import type {LayerSpecification} from '../../style-spec/types';
8
8
 
9
9
  class BackgroundStyleLayer extends StyleLayer {
@@ -3,14 +3,14 @@ import StyleLayer from '../style_layer';
3
3
  import CircleBucket from '../../data/bucket/circle_bucket';
4
4
  import {polygonIntersectsBufferedPoint} from '../../util/intersection_tests';
5
5
  import {getMaximumPaintValue, translateDistance, translate} from '../query_utils';
6
- import properties, {CircleLayoutPropsPossiblyEvaluated, CirclePaintPropsPossiblyEvaluated} from './circle_style_layer_properties';
6
+ import properties, {CircleLayoutPropsPossiblyEvaluated, CirclePaintPropsPossiblyEvaluated} from './circle_style_layer_properties.g';
7
7
  import {Transitionable, Transitioning, Layout, PossiblyEvaluated} from '../properties';
8
8
  import {mat4, vec4} from 'gl-matrix';
9
9
  import Point from '@mapbox/point-geometry';
10
10
  import type {FeatureState} from '../../style-spec/expression';
11
11
  import type Transform from '../../geo/transform';
12
12
  import type {Bucket, BucketParameters} from '../../data/bucket';
13
- import type {CircleLayoutProps, CirclePaintProps} from './circle_style_layer_properties';
13
+ import type {CircleLayoutProps, CirclePaintProps} from './circle_style_layer_properties.g';
14
14
  import type {LayerSpecification} from '../../style-spec/types';
15
15
  import type {VectorTileFeature} from '@mapbox/vector-tile';
16
16
 
@@ -38,14 +38,14 @@ class CircleStyleLayer extends StyleLayer {
38
38
  }
39
39
 
40
40
  queryIntersectsFeature(
41
- queryGeometry: Array<Point>,
42
- feature: VectorTileFeature,
43
- featureState: FeatureState,
44
- geometry: Array<Array<Point>>,
45
- zoom: number,
46
- transform: Transform,
47
- pixelsToTileUnits: number,
48
- pixelPosMatrix: mat4
41
+ queryGeometry: Array<Point>,
42
+ feature: VectorTileFeature,
43
+ featureState: FeatureState,
44
+ geometry: Array<Array<Point>>,
45
+ zoom: number,
46
+ transform: Transform,
47
+ pixelsToTileUnits: number,
48
+ pixelPosMatrix: mat4
49
49
  ): boolean {
50
50
  const translatedPolygon = translate(queryGeometry,
51
51
  this.paint.get('circle-translate'),
@@ -75,15 +75,15 @@ export interface CustomLayerInterface {
75
75
  /**
76
76
  * @property {string} id A unique layer id.
77
77
  */
78
- id: string;
78
+ id: string;
79
79
  /**
80
80
  * @property {string} type The layer's type. Must be `"custom"`.
81
81
  */
82
- type: 'custom';
82
+ type: 'custom';
83
83
  /**
84
84
  * @property {string} renderingMode Either `"2d"` or `"3d"`. Defaults to `"2d"`.
85
85
  */
86
- renderingMode: '2d' | '3d';
86
+ renderingMode: '2d' | '3d';
87
87
  /**
88
88
  * Called during a render frame allowing the layer to draw into the GL context.
89
89
  *
@@ -112,7 +112,7 @@ export interface CustomLayerInterface {
112
112
  * lengths in mercator units would be rendered as a cube. {@link MercatorCoordinate}.fromLngLat
113
113
  * can be used to project a `LngLat` to a mercator coordinate.
114
114
  */
115
- render: CustomRenderMethod;
115
+ render: CustomRenderMethod;
116
116
  /**
117
117
  * Optional method called during a render frame to allow a layer to prepare resources or render into a texture.
118
118
  *
@@ -130,7 +130,7 @@ export interface CustomLayerInterface {
130
130
  * lengths in mercator units would be rendered as a cube. {@link MercatorCoordinate}.fromLngLat
131
131
  * can be used to project a `LngLat` to a mercator coordinate.
132
132
  */
133
- prerender: CustomRenderMethod;
133
+ prerender: CustomRenderMethod;
134
134
  /**
135
135
  * Optional method called when the layer has been added to the Map with {@link Map#addLayer}. This
136
136
  * gives the layer a chance to initialize gl resources and register event listeners.
@@ -142,19 +142,19 @@ export interface CustomLayerInterface {
142
142
  * @param {Map} map The Map this custom layer was just added to.
143
143
  * @param {WebGLRenderingContext} gl The gl context for the map.
144
144
  */
145
- onAdd(map: Map, gl: WebGLRenderingContext): void;
145
+ onAdd(map: Map, gl: WebGLRenderingContext): void;
146
146
  /**
147
- * Optional method called when the layer has been removed from the Map with {@link Map#removeLayer}. This
148
- * gives the layer a chance to clean up gl resources and event listeners.
149
- *
150
- * @function
151
- * @memberof CustomLayerInterface
152
- * @instance
153
- * @name onRemove
154
- * @param {Map} map The Map this custom layer was just added to.
155
- * @param {WebGLRenderingContext} gl The gl context for the map.
156
- */
157
- onRemove(map: Map, gl: WebGLRenderingContext): void;
147
+ * Optional method called when the layer has been removed from the Map with {@link Map#removeLayer}. This
148
+ * gives the layer a chance to clean up gl resources and event listeners.
149
+ *
150
+ * @function
151
+ * @memberof CustomLayerInterface
152
+ * @instance
153
+ * @name onRemove
154
+ * @param {Map} map The Map this custom layer was just added to.
155
+ * @param {WebGLRenderingContext} gl The gl context for the map.
156
+ */
157
+ onRemove(map: Map, gl: WebGLRenderingContext): void;
158
158
  }
159
159
 
160
160
  export function validateCustomStyleLayer(layerObject: CustomLayerInterface) {
@@ -213,13 +213,13 @@ class CustomStyleLayer extends StyleLayer {
213
213
  if (this.implementation.onAdd) {
214
214
  this.implementation.onAdd(map, map.painter.context.gl);
215
215
  }
216
- }
216
+ };
217
217
 
218
218
  onRemove = (map: Map) => {
219
219
  if (this.implementation.onRemove) {
220
220
  this.implementation.onRemove(map, map.painter.context.gl);
221
221
  }
222
- }
222
+ };
223
223
  }
224
224
 
225
225
  export default CustomStyleLayer;
@@ -3,19 +3,19 @@ import StyleLayer from '../style_layer';
3
3
  import FillExtrusionBucket from '../../data/bucket/fill_extrusion_bucket';
4
4
  import {polygonIntersectsPolygon, polygonIntersectsMultiPolygon} from '../../util/intersection_tests';
5
5
  import {translateDistance, translate} from '../query_utils';
6
- import properties, {FillExtrusionPaintPropsPossiblyEvaluated} from './fill_extrusion_style_layer_properties';
6
+ import properties, {FillExtrusionPaintPropsPossiblyEvaluated} from './fill_extrusion_style_layer_properties.g';
7
7
  import {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';
8
8
  import {mat4, vec4} from 'gl-matrix';
9
9
  import Point from '@mapbox/point-geometry';
10
10
  import type {FeatureState} from '../../style-spec/expression';
11
11
  import type {BucketParameters} from '../../data/bucket';
12
- import type {FillExtrusionPaintProps} from './fill_extrusion_style_layer_properties';
12
+ import type {FillExtrusionPaintProps} from './fill_extrusion_style_layer_properties.g';
13
13
  import type Transform from '../../geo/transform';
14
14
  import type {LayerSpecification} from '../../style-spec/types';
15
15
  import type {VectorTileFeature} from '@mapbox/vector-tile';
16
16
 
17
17
  export class Point3D extends Point {
18
- z: number
18
+ z: number;
19
19
  }
20
20
 
21
21
  class FillExtrusionStyleLayer extends StyleLayer {
@@ -40,14 +40,14 @@ class FillExtrusionStyleLayer extends StyleLayer {
40
40
  }
41
41
 
42
42
  queryIntersectsFeature(
43
- queryGeometry: Array<Point>,
44
- feature: VectorTileFeature,
45
- featureState: FeatureState,
46
- geometry: Array<Array<Point>>,
47
- zoom: number,
48
- transform: Transform,
49
- pixelsToTileUnits: number,
50
- pixelPosMatrix: mat4
43
+ queryGeometry: Array<Point>,
44
+ feature: VectorTileFeature,
45
+ featureState: FeatureState,
46
+ geometry: Array<Array<Point>>,
47
+ zoom: number,
48
+ transform: Transform,
49
+ pixelsToTileUnits: number,
50
+ pixelPosMatrix: mat4
51
51
  ): boolean | number {
52
52
 
53
53
  const translatedPolygon = translate(queryGeometry,
@@ -3,13 +3,13 @@ import StyleLayer from '../style_layer';
3
3
  import FillBucket from '../../data/bucket/fill_bucket';
4
4
  import {polygonIntersectsMultiPolygon} from '../../util/intersection_tests';
5
5
  import {translateDistance, translate} from '../query_utils';
6
- import properties, {FillLayoutPropsPossiblyEvaluated, FillPaintPropsPossiblyEvaluated} from './fill_style_layer_properties';
6
+ import properties, {FillLayoutPropsPossiblyEvaluated, FillPaintPropsPossiblyEvaluated} from './fill_style_layer_properties.g';
7
7
  import {Transitionable, Transitioning, Layout, PossiblyEvaluated} from '../properties';
8
8
 
9
9
  import type {FeatureState} from '../../style-spec/expression';
10
10
  import type {BucketParameters} from '../../data/bucket';
11
11
  import type Point from '@mapbox/point-geometry';
12
- import type {FillLayoutProps, FillPaintProps} from './fill_style_layer_properties';
12
+ import type {FillLayoutProps, FillPaintProps} from './fill_style_layer_properties.g';
13
13
  import type EvaluationParameters from '../evaluation_parameters';
14
14
  import type Transform from '../../geo/transform';
15
15
  import type {LayerSpecification} from '../../style-spec/types';
@@ -45,13 +45,13 @@ class FillStyleLayer extends StyleLayer {
45
45
  }
46
46
 
47
47
  queryIntersectsFeature(
48
- queryGeometry: Array<Point>,
49
- feature: VectorTileFeature,
50
- featureState: FeatureState,
51
- geometry: Array<Array<Point>>,
52
- zoom: number,
53
- transform: Transform,
54
- pixelsToTileUnits: number
48
+ queryGeometry: Array<Point>,
49
+ feature: VectorTileFeature,
50
+ featureState: FeatureState,
51
+ geometry: Array<Array<Point>>,
52
+ zoom: number,
53
+ transform: Transform,
54
+ pixelsToTileUnits: number
55
55
  ): boolean {
56
56
  const translatedPolygon = translate(queryGeometry,
57
57
  this.paint.get('fill-translate'),
@@ -2,13 +2,13 @@ import StyleLayer from '../style_layer';
2
2
 
3
3
  import HeatmapBucket from '../../data/bucket/heatmap_bucket';
4
4
  import {RGBAImage} from '../../util/image';
5
- import properties, {HeatmapPaintPropsPossiblyEvaluated} from './heatmap_style_layer_properties';
5
+ import properties, {HeatmapPaintPropsPossiblyEvaluated} from './heatmap_style_layer_properties.g';
6
6
  import {renderColorRamp} from '../../util/color_ramp';
7
7
  import {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';
8
8
 
9
9
  import type Texture from '../../render/texture';
10
10
  import type Framebuffer from '../../gl/framebuffer';
11
- import type {HeatmapPaintProps} from './heatmap_style_layer_properties';
11
+ import type {HeatmapPaintProps} from './heatmap_style_layer_properties.g';
12
12
  import type {LayerSpecification} from '../../style-spec/types';
13
13
 
14
14
  class HeatmapStyleLayer extends StyleLayer {
@@ -1,9 +1,9 @@
1
1
  import StyleLayer from '../style_layer';
2
2
 
3
- import properties, {HillshadePaintPropsPossiblyEvaluated} from './hillshade_style_layer_properties';
3
+ import properties, {HillshadePaintPropsPossiblyEvaluated} from './hillshade_style_layer_properties.g';
4
4
  import {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';
5
5
 
6
- import type {HillshadePaintProps} from './hillshade_style_layer_properties';
6
+ import type {HillshadePaintProps} from './hillshade_style_layer_properties.g';
7
7
  import type {LayerSpecification} from '../../style-spec/types';
8
8
 
9
9
  class HillshadeStyleLayer extends StyleLayer {
@@ -4,7 +4,7 @@ import StyleLayer from '../style_layer';
4
4
  import LineBucket from '../../data/bucket/line_bucket';
5
5
  import {polygonIntersectsBufferedMultiLine} from '../../util/intersection_tests';
6
6
  import {getMaximumPaintValue, translateDistance, translate} from '../query_utils';
7
- import properties, {LineLayoutPropsPossiblyEvaluated, LinePaintPropsPossiblyEvaluated} from './line_style_layer_properties';
7
+ import properties, {LineLayoutPropsPossiblyEvaluated, LinePaintPropsPossiblyEvaluated} from './line_style_layer_properties.g';
8
8
  import {extend} from '../../util/util';
9
9
  import EvaluationParameters from '../evaluation_parameters';
10
10
  import {Transitionable, Transitioning, Layout, PossiblyEvaluated, DataDrivenProperty} from '../properties';
@@ -12,7 +12,7 @@ import {Transitionable, Transitioning, Layout, PossiblyEvaluated, DataDrivenProp
12
12
  import Step from '../../style-spec/expression/definitions/step';
13
13
  import type {FeatureState, ZoomConstantExpression} from '../../style-spec/expression';
14
14
  import type {Bucket, BucketParameters} from '../../data/bucket';
15
- import type {LineLayoutProps, LinePaintProps} from './line_style_layer_properties';
15
+ import type {LineLayoutProps, LinePaintProps} from './line_style_layer_properties.g';
16
16
  import type Transform from '../../geo/transform';
17
17
  import type {LayerSpecification} from '../../style-spec/types';
18
18
  import type {VectorTileFeature} from '@mapbox/vector-tile';
@@ -88,13 +88,13 @@ class LineStyleLayer extends StyleLayer {
88
88
  }
89
89
 
90
90
  queryIntersectsFeature(
91
- queryGeometry: Array<Point>,
92
- feature: VectorTileFeature,
93
- featureState: FeatureState,
94
- geometry: Array<Array<Point>>,
95
- zoom: number,
96
- transform: Transform,
97
- pixelsToTileUnits: number
91
+ queryGeometry: Array<Point>,
92
+ feature: VectorTileFeature,
93
+ featureState: FeatureState,
94
+ geometry: Array<Array<Point>>,
95
+ zoom: number,
96
+ transform: Transform,
97
+ pixelsToTileUnits: number
98
98
  ): boolean {
99
99
  const translatedPolygon = translate(queryGeometry,
100
100
  this.paint.get('line-translate'),
@@ -1,9 +1,9 @@
1
1
  import StyleLayer from '../style_layer';
2
2
 
3
- import properties, {RasterPaintPropsPossiblyEvaluated} from './raster_style_layer_properties';
3
+ import properties, {RasterPaintPropsPossiblyEvaluated} from './raster_style_layer_properties.g';
4
4
  import {Transitionable, Transitioning, PossiblyEvaluated} from '../properties';
5
5
 
6
- import type {RasterPaintProps} from './raster_style_layer_properties';
6
+ import type {RasterPaintProps} from './raster_style_layer_properties.g';
7
7
  import type {LayerSpecification} from '../../style-spec/types';
8
8
 
9
9
  class RasterStyleLayer extends StyleLayer {
@@ -3,7 +3,7 @@ import StyleLayer from '../style_layer';
3
3
  import assert from 'assert';
4
4
  import SymbolBucket from '../../data/bucket/symbol_bucket';
5
5
  import resolveTokens from '../../util/resolve_tokens';
6
- import properties, {SymbolLayoutPropsPossiblyEvaluated, SymbolPaintPropsPossiblyEvaluated} from './symbol_style_layer_properties';
6
+ import properties, {SymbolLayoutPropsPossiblyEvaluated, SymbolPaintPropsPossiblyEvaluated} from './symbol_style_layer_properties.g';
7
7
 
8
8
  import {
9
9
  Transitionable,
@@ -22,7 +22,7 @@ import {
22
22
  } from '../../style-spec/expression';
23
23
 
24
24
  import type {BucketParameters} from '../../data/bucket';
25
- import type {SymbolLayoutProps, SymbolPaintProps} from './symbol_style_layer_properties';
25
+ import type {SymbolLayoutProps, SymbolPaintProps} from './symbol_style_layer_properties.g';
26
26
  import type EvaluationParameters from '../evaluation_parameters';
27
27
  import type {LayerSpecification} from '../../style-spec/types';
28
28
  import type {Feature, SourceExpression, CompositeExpression} from '../../style-spec/expression';
@@ -127,13 +127,13 @@ class SymbolStyleLayer extends StyleLayer {
127
127
  expression = (new ZoomConstantExpression('source', styleExpression) as SourceExpression);
128
128
  } else {
129
129
  expression = (new ZoomDependentExpression('composite',
130
- styleExpression,
131
- overriden.value.zoomStops,
132
- (overriden.value as any)._interpolationType) as CompositeExpression);
130
+ styleExpression,
131
+ overriden.value.zoomStops,
132
+ (overriden.value as any)._interpolationType) as CompositeExpression);
133
133
  }
134
134
  this.paint._values[overridable] = new PossiblyEvaluatedPropertyValue(overriden.property,
135
- expression,
136
- overriden.parameters);
135
+ expression,
136
+ overriden.parameters);
137
137
  }
138
138
  }
139
139
 
@@ -185,4 +185,23 @@ class SymbolStyleLayer extends StyleLayer {
185
185
  }
186
186
  }
187
187
 
188
+ export type OverlapMode = 'never' | 'always' | 'cooperative';
189
+
190
+ export function getOverlapMode(layout: PossiblyEvaluated<SymbolLayoutProps, SymbolLayoutPropsPossiblyEvaluated>, overlapProp: 'icon-overlap', allowOverlapProp: 'icon-allow-overlap'): OverlapMode;
191
+ export function getOverlapMode(layout: PossiblyEvaluated<SymbolLayoutProps, SymbolLayoutPropsPossiblyEvaluated>, overlapProp: 'text-overlap', allowOverlapProp: 'text-allow-overlap'): OverlapMode;
192
+ export function getOverlapMode(layout: PossiblyEvaluated<SymbolLayoutProps, SymbolLayoutPropsPossiblyEvaluated>, overlapProp: 'icon-overlap' | 'text-overlap', allowOverlapProp: 'icon-allow-overlap' | 'text-allow-overlap'): OverlapMode {
193
+ let result: OverlapMode = 'never';
194
+ const overlap = layout.get(overlapProp);
195
+
196
+ if (overlap) {
197
+ // if -overlap is set, use it
198
+ result = overlap;
199
+ } else if (layout.get(allowOverlapProp)) {
200
+ // fall back to -allow-overlap, with false='never', true='always'
201
+ result = 'always';
202
+ }
203
+
204
+ return result;
205
+ }
206
+
188
207
  export default SymbolStyleLayer;
@@ -32,6 +32,7 @@ export type SymbolLayoutProps = {
32
32
  "symbol-sort-key": DataDrivenProperty<number>,
33
33
  "symbol-z-order": DataConstantProperty<"auto" | "viewport-y" | "source">,
34
34
  "icon-allow-overlap": DataConstantProperty<boolean>,
35
+ "icon-overlap": DataConstantProperty<"never" | "always" | "cooperative">,
35
36
  "icon-ignore-placement": DataConstantProperty<boolean>,
36
37
  "icon-optional": DataConstantProperty<boolean>,
37
38
  "icon-rotation-alignment": DataConstantProperty<"map" | "viewport" | "auto">,
@@ -65,6 +66,7 @@ export type SymbolLayoutProps = {
65
66
  "text-transform": DataDrivenProperty<"none" | "uppercase" | "lowercase">,
66
67
  "text-offset": DataDrivenProperty<[number, number]>,
67
68
  "text-allow-overlap": DataConstantProperty<boolean>,
69
+ "text-overlap": DataConstantProperty<"never" | "always" | "cooperative">,
68
70
  "text-ignore-placement": DataConstantProperty<boolean>,
69
71
  "text-optional": DataConstantProperty<boolean>,
70
72
  };
@@ -76,6 +78,7 @@ export type SymbolLayoutPropsPossiblyEvaluated = {
76
78
  "symbol-sort-key": PossiblyEvaluatedPropertyValue<number>,
77
79
  "symbol-z-order": "auto" | "viewport-y" | "source",
78
80
  "icon-allow-overlap": boolean,
81
+ "icon-overlap": "never" | "always" | "cooperative",
79
82
  "icon-ignore-placement": boolean,
80
83
  "icon-optional": boolean,
81
84
  "icon-rotation-alignment": "map" | "viewport" | "auto",
@@ -109,6 +112,7 @@ export type SymbolLayoutPropsPossiblyEvaluated = {
109
112
  "text-transform": PossiblyEvaluatedPropertyValue<"none" | "uppercase" | "lowercase">,
110
113
  "text-offset": PossiblyEvaluatedPropertyValue<[number, number]>,
111
114
  "text-allow-overlap": boolean,
115
+ "text-overlap": "never" | "always" | "cooperative",
112
116
  "text-ignore-placement": boolean,
113
117
  "text-optional": boolean,
114
118
  };
@@ -120,6 +124,7 @@ const layout: Properties<SymbolLayoutProps> = new Properties({
120
124
  "symbol-sort-key": new DataDrivenProperty(styleSpec["layout_symbol"]["symbol-sort-key"] as any as StylePropertySpecification),
121
125
  "symbol-z-order": new DataConstantProperty(styleSpec["layout_symbol"]["symbol-z-order"] as any as StylePropertySpecification),
122
126
  "icon-allow-overlap": new DataConstantProperty(styleSpec["layout_symbol"]["icon-allow-overlap"] as any as StylePropertySpecification),
127
+ "icon-overlap": new DataConstantProperty(styleSpec["layout_symbol"]["icon-overlap"] as any as StylePropertySpecification),
123
128
  "icon-ignore-placement": new DataConstantProperty(styleSpec["layout_symbol"]["icon-ignore-placement"] as any as StylePropertySpecification),
124
129
  "icon-optional": new DataConstantProperty(styleSpec["layout_symbol"]["icon-optional"] as any as StylePropertySpecification),
125
130
  "icon-rotation-alignment": new DataConstantProperty(styleSpec["layout_symbol"]["icon-rotation-alignment"] as any as StylePropertySpecification),
@@ -153,6 +158,7 @@ const layout: Properties<SymbolLayoutProps> = new Properties({
153
158
  "text-transform": new DataDrivenProperty(styleSpec["layout_symbol"]["text-transform"] as any as StylePropertySpecification),
154
159
  "text-offset": new DataDrivenProperty(styleSpec["layout_symbol"]["text-offset"] as any as StylePropertySpecification),
155
160
  "text-allow-overlap": new DataConstantProperty(styleSpec["layout_symbol"]["text-allow-overlap"] as any as StylePropertySpecification),
161
+ "text-overlap": new DataConstantProperty(styleSpec["layout_symbol"]["text-overlap"] as any as StylePropertySpecification),
156
162
  "text-ignore-placement": new DataConstantProperty(styleSpec["layout_symbol"]["text-ignore-placement"] as any as StylePropertySpecification),
157
163
  "text-optional": new DataConstantProperty(styleSpec["layout_symbol"]["text-optional"] as any as StylePropertySpecification),
158
164
  });
@@ -58,19 +58,19 @@ abstract class StyleLayer extends Evented {
58
58
 
59
59
  queryRadius?(bucket: Bucket): number;
60
60
  queryIntersectsFeature?(
61
- queryGeometry: Array<Point>,
62
- feature: VectorTileFeature,
63
- featureState: FeatureState,
64
- geometry: Array<Array<Point>>,
65
- zoom: number,
66
- transform: Transform,
67
- pixelsToTileUnits: number,
68
- pixelPosMatrix: mat4
61
+ queryGeometry: Array<Point>,
62
+ feature: VectorTileFeature,
63
+ featureState: FeatureState,
64
+ geometry: Array<Array<Point>>,
65
+ zoom: number,
66
+ transform: Transform,
67
+ pixelsToTileUnits: number,
68
+ pixelPosMatrix: mat4
69
69
  ): boolean | number;
70
70
 
71
71
  constructor(layer: LayerSpecification | CustomLayerInterface, properties: Readonly<{
72
- layout?: Properties<any>;
73
- paint?: Properties<any>;
72
+ layout?: Properties<any>;
73
+ paint?: Properties<any>;
74
74
  }>) {
75
75
  super();
76
76
 
@@ -12,9 +12,9 @@ export type Family<Layer extends TypedStyleLayer> = Array<Layer>;
12
12
 
13
13
  class StyleLayerIndex {
14
14
  familiesBySource: {
15
- [source: string]: {
16
- [sourceLayer: string]: Array<Family<any>>;
17
- };
15
+ [source: string]: {
16
+ [sourceLayer: string]: Array<Family<any>>;
17
+ };
18
18
  };
19
19
  keyCache: {[source: string]: string};
20
20