@mapgis/mapbox-gl 16.0.1 → 16.2.0

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 (434) hide show
  1. package/dist/mapbox-gl.js +3 -3
  2. package/dist/mapbox-gl.js.map +1 -1
  3. package/package.json +1 -1
  4. package/.flowconfig +0 -61
  5. package/LICENSE.txt +0 -84
  6. package/README.md +0 -34
  7. package/build/banner.js +0 -4
  8. package/build/check-bundle-size.js +0 -140
  9. package/build/generate-access-token-script.js +0 -11
  10. package/build/generate-flow-typed-style-spec.js +0 -188
  11. package/build/generate-release-list.js +0 -21
  12. package/build/generate-struct-arrays.js +0 -237
  13. package/build/generate-style-code.js +0 -159
  14. package/build/mapbox-gl.js.flow +0 -3
  15. package/build/print-release-url.js +0 -6
  16. package/build/rollup_plugin_minify_style_spec.js +0 -20
  17. package/build/rollup_plugins.js +0 -80
  18. package/build/run-node +0 -3
  19. package/build/run-tap +0 -8
  20. package/build/test/build-tape.js +0 -19
  21. package/flow-typed/gl.js +0 -5
  22. package/flow-typed/jsdom.js +0 -18
  23. package/flow-typed/mapbox-gl-supported.js +0 -9
  24. package/flow-typed/mapbox-unitbezier.js +0 -14
  25. package/flow-typed/offscreen-canvas.js +0 -9
  26. package/flow-typed/pbf.js +0 -25
  27. package/flow-typed/point-geometry.js +0 -44
  28. package/flow-typed/potpack.js +0 -12
  29. package/flow-typed/sinon.js +0 -28
  30. package/flow-typed/vector-tile.js +0 -41
  31. package/src/css/mapbox-gl.css +0 -798
  32. package/src/css/svg/mapboxgl-ctrl-attrib.svg +0 -3
  33. package/src/css/svg/mapboxgl-ctrl-compass.svg +0 -4
  34. package/src/css/svg/mapboxgl-ctrl-fullscreen.svg +0 -3
  35. package/src/css/svg/mapboxgl-ctrl-geolocate.svg +0 -5
  36. package/src/css/svg/mapboxgl-ctrl-logo.svg +0 -20
  37. package/src/css/svg/mapboxgl-ctrl-shrink.svg +0 -3
  38. package/src/css/svg/mapboxgl-ctrl-zoom-in.svg +0 -3
  39. package/src/css/svg/mapboxgl-ctrl-zoom-out.svg +0 -3
  40. package/src/data/array_types.js +0 -1095
  41. package/src/data/bucket/circle_attributes.js +0 -9
  42. package/src/data/bucket/circle_bucket.js +0 -204
  43. package/src/data/bucket/fill_attributes.js +0 -9
  44. package/src/data/bucket/fill_bucket.js +0 -233
  45. package/src/data/bucket/fill_extrusion_attributes.js +0 -10
  46. package/src/data/bucket/fill_extrusion_bucket.js +0 -289
  47. package/src/data/bucket/heatmap_bucket.js +0 -17
  48. package/src/data/bucket/line_attributes.js +0 -10
  49. package/src/data/bucket/line_bucket.js +0 -556
  50. package/src/data/bucket/pattern_attributes.js +0 -10
  51. package/src/data/bucket/pattern_bucket_features.js +0 -60
  52. package/src/data/bucket/symbol_attributes.js +0 -117
  53. package/src/data/bucket/symbol_bucket.js +0 -972
  54. package/src/data/bucket.js +0 -123
  55. package/src/data/dem_data.js +0 -125
  56. package/src/data/extent.js +0 -18
  57. package/src/data/feature_index.js +0 -321
  58. package/src/data/feature_position_map.js +0 -125
  59. package/src/data/index_array_type.js +0 -16
  60. package/src/data/load_geometry.js +0 -48
  61. package/src/data/pos_attributes.js +0 -6
  62. package/src/data/program_configuration.js +0 -687
  63. package/src/data/raster_bounds_attributes.js +0 -7
  64. package/src/data/segment.js +0 -76
  65. package/src/geo/edge_insets.js +0 -102
  66. package/src/geo/lng_lat.js +0 -165
  67. package/src/geo/lng_lat_bounds.js +0 -267
  68. package/src/geo/mercator_coordinate.js +0 -153
  69. package/src/geo/transform.js +0 -864
  70. package/src/gl/color_mode.js +0 -34
  71. package/src/gl/context.js +0 -298
  72. package/src/gl/cull_face_mode.js +0 -26
  73. package/src/gl/depth_mode.js +0 -29
  74. package/src/gl/framebuffer.js +0 -44
  75. package/src/gl/index_buffer.js +0 -55
  76. package/src/gl/stencil_mode.js +0 -30
  77. package/src/gl/types.js +0 -84
  78. package/src/gl/value.js +0 -520
  79. package/src/gl/vertex_buffer.js +0 -119
  80. package/src/index.js +0 -201
  81. package/src/render/draw_background.js +0 -57
  82. package/src/render/draw_circle.js +0 -113
  83. package/src/render/draw_collision_debug.js +0 -49
  84. package/src/render/draw_custom.js +0 -49
  85. package/src/render/draw_debug.js +0 -127
  86. package/src/render/draw_fill.js +0 -126
  87. package/src/render/draw_fill_extrusion.js +0 -96
  88. package/src/render/draw_heatmap.js +0 -140
  89. package/src/render/draw_hillshade.js +0 -108
  90. package/src/render/draw_line.js +0 -98
  91. package/src/render/draw_raster.js +0 -125
  92. package/src/render/draw_symbol.js +0 -394
  93. package/src/render/glyph_atlas.js +0 -71
  94. package/src/render/glyph_manager.js +0 -182
  95. package/src/render/image_atlas.js +0 -149
  96. package/src/render/image_manager.js +0 -306
  97. package/src/render/line_atlas.js +0 -210
  98. package/src/render/painter.js +0 -653
  99. package/src/render/program/background_program.js +0 -103
  100. package/src/render/program/circle_program.js +0 -69
  101. package/src/render/program/clipping_mask_program.js +0 -20
  102. package/src/render/program/collision_program.js +0 -49
  103. package/src/render/program/debug_program.js +0 -35
  104. package/src/render/program/fill_extrusion_program.js +0 -122
  105. package/src/render/program/fill_program.js +0 -126
  106. package/src/render/program/heatmap_program.js +0 -83
  107. package/src/render/program/hillshade_program.js +0 -122
  108. package/src/render/program/line_program.js +0 -207
  109. package/src/render/program/pattern.js +0 -102
  110. package/src/render/program/program_uniforms.js +0 -42
  111. package/src/render/program/raster_program.js +0 -92
  112. package/src/render/program/symbol_program.js +0 -224
  113. package/src/render/program.js +0 -168
  114. package/src/render/texture.js +0 -122
  115. package/src/render/uniform_binding.js +0 -147
  116. package/src/render/vertex_array_object.js +0 -163
  117. package/src/shaders/README.md +0 -42
  118. package/src/shaders/_prelude.fragment.glsl +0 -17
  119. package/src/shaders/_prelude.vertex.glsl +0 -73
  120. package/src/shaders/background.fragment.glsl +0 -10
  121. package/src/shaders/background.vertex.glsl +0 -7
  122. package/src/shaders/background_pattern.fragment.glsl +0 -28
  123. package/src/shaders/background_pattern.vertex.glsl +0 -20
  124. package/src/shaders/circle.fragment.glsl +0 -39
  125. package/src/shaders/circle.vertex.glsl +0 -64
  126. package/src/shaders/clipping_mask.fragment.glsl +0 -3
  127. package/src/shaders/clipping_mask.vertex.glsl +0 -7
  128. package/src/shaders/collision_box.fragment.glsl +0 -21
  129. package/src/shaders/collision_box.vertex.glsl +0 -27
  130. package/src/shaders/collision_circle.fragment.glsl +0 -34
  131. package/src/shaders/collision_circle.vertex.glsl +0 -36
  132. package/src/shaders/debug.fragment.glsl +0 -9
  133. package/src/shaders/debug.vertex.glsl +0 -12
  134. package/src/shaders/encode_attribute.js +0 -17
  135. package/src/shaders/fill.fragment.glsl +0 -13
  136. package/src/shaders/fill.vertex.glsl +0 -13
  137. package/src/shaders/fill_extrusion.fragment.glsl +0 -9
  138. package/src/shaders/fill_extrusion.vertex.glsl +0 -66
  139. package/src/shaders/fill_extrusion_pattern.fragment.glsl +0 -45
  140. package/src/shaders/fill_extrusion_pattern.vertex.glsl +0 -79
  141. package/src/shaders/fill_outline.fragment.glsl +0 -17
  142. package/src/shaders/fill_outline.vertex.glsl +0 -17
  143. package/src/shaders/fill_outline_pattern.fragment.glsl +0 -43
  144. package/src/shaders/fill_outline_pattern.vertex.glsl +0 -44
  145. package/src/shaders/fill_pattern.fragment.glsl +0 -36
  146. package/src/shaders/fill_pattern.vertex.glsl +0 -39
  147. package/src/shaders/heatmap.fragment.glsl +0 -22
  148. package/src/shaders/heatmap.vertex.glsl +0 -54
  149. package/src/shaders/heatmap_texture.fragment.glsl +0 -14
  150. package/src/shaders/heatmap_texture.vertex.glsl +0 -11
  151. package/src/shaders/hillshade.fragment.glsl +0 -52
  152. package/src/shaders/hillshade.vertex.glsl +0 -11
  153. package/src/shaders/hillshade_prepare.fragment.glsl +0 -74
  154. package/src/shaders/hillshade_prepare.vertex.glsl +0 -15
  155. package/src/shaders/index.js +0 -20
  156. package/src/shaders/line.fragment.glsl +0 -30
  157. package/src/shaders/line.vertex.glsl +0 -85
  158. package/src/shaders/line_gradient.fragment.glsl +0 -34
  159. package/src/shaders/line_gradient.vertex.glsl +0 -87
  160. package/src/shaders/line_pattern.fragment.glsl +0 -74
  161. package/src/shaders/line_pattern.vertex.glsl +0 -99
  162. package/src/shaders/line_sdf.fragment.glsl +0 -45
  163. package/src/shaders/line_sdf.vertex.glsl +0 -98
  164. package/src/shaders/raster.fragment.glsl +0 -52
  165. package/src/shaders/raster.vertex.glsl +0 -21
  166. package/src/shaders/shaders.js +0 -180
  167. package/src/shaders/symbol_icon.fragment.glsl +0 -17
  168. package/src/shaders/symbol_icon.vertex.glsl +0 -94
  169. package/src/shaders/symbol_sdf.fragment.glsl +0 -52
  170. package/src/shaders/symbol_sdf.vertex.glsl +0 -115
  171. package/src/shaders/symbol_text_and_icon.fragment.glsl +0 -68
  172. package/src/shaders/symbol_text_and_icon.vertex.glsl +0 -116
  173. package/src/source/canvas_source.js +0 -238
  174. package/src/source/geojson_helper.js +0 -92
  175. package/src/source/geojson_source.js +0 -374
  176. package/src/source/geojson_worker_source.js +0 -357
  177. package/src/source/geojson_wrapper.js +0 -94
  178. package/src/source/image_source.js +0 -307
  179. package/src/source/load_tilejson.js +0 -39
  180. package/src/source/mbtiles_source.js +0 -115
  181. package/src/source/offline_database.js +0 -61
  182. package/src/source/offline_database_root.js +0 -62
  183. package/src/source/pixels_to_tile_units.js +0 -21
  184. package/src/source/query_features.js +0 -208
  185. package/src/source/raster_dem_tile_source.js +0 -138
  186. package/src/source/raster_dem_tile_worker_source.js +0 -62
  187. package/src/source/raster_tile_offline_source.js +0 -136
  188. package/src/source/raster_tile_source.js +0 -177
  189. package/src/source/rtl_text_plugin.js +0 -138
  190. package/src/source/source.js +0 -137
  191. package/src/source/source_cache.js +0 -957
  192. package/src/source/source_state.js +0 -159
  193. package/src/source/tile.js +0 -465
  194. package/src/source/tile_bounds.js +0 -38
  195. package/src/source/tile_cache.js +0 -212
  196. package/src/source/tile_id.js +0 -402
  197. package/src/source/vector_tile_source.js +0 -192
  198. package/src/source/vector_tile_worker_source.js +0 -216
  199. package/src/source/video_source.js +0 -203
  200. package/src/source/worker.js +0 -237
  201. package/src/source/worker_source.js +0 -106
  202. package/src/source/worker_tile.js +0 -224
  203. package/src/style/create_style_layer.js +0 -36
  204. package/src/style/evaluation_parameters.js +0 -62
  205. package/src/style/light.js +0 -130
  206. package/src/style/load_glyph_range.js +0 -38
  207. package/src/style/load_sprite.js +0 -67
  208. package/src/style/parse_glyph_pbf.js +0 -44
  209. package/src/style/pauseable_placement.js +0 -132
  210. package/src/style/properties.js +0 -753
  211. package/src/style/query_utils.js +0 -43
  212. package/src/style/style.js +0 -1361
  213. package/src/style/style_glyph.js +0 -17
  214. package/src/style/style_image.js +0 -137
  215. package/src/style/style_layer/background_style_layer.js +0 -21
  216. package/src/style/style_layer/background_style_layer_properties.js +0 -40
  217. package/src/style/style_layer/circle_style_layer.js +0 -98
  218. package/src/style/style_layer/circle_style_layer_properties.js +0 -63
  219. package/src/style/style_layer/custom_style_layer.js +0 -223
  220. package/src/style/style_layer/fill_extrusion_style_layer.js +0 -224
  221. package/src/style/style_layer/fill_extrusion_style_layer_properties.js +0 -50
  222. package/src/style/style_layer/fill_style_layer.js +0 -67
  223. package/src/style/style_layer/fill_style_layer_properties.js +0 -55
  224. package/src/style/style_layer/heatmap_style_layer.js +0 -69
  225. package/src/style/style_layer/heatmap_style_layer_properties.js +0 -44
  226. package/src/style/style_layer/hillshade_style_layer.js +0 -25
  227. package/src/style/style_layer/hillshade_style_layer_properties.js +0 -46
  228. package/src/style/style_layer/layer_properties.js.ejs +0 -69
  229. package/src/style/style_layer/line_style_layer.js +0 -151
  230. package/src/style/style_layer/line_style_layer_properties.js +0 -71
  231. package/src/style/style_layer/raster_style_layer.js +0 -21
  232. package/src/style/style_layer/raster_style_layer_properties.js +0 -50
  233. package/src/style/style_layer/symbol_style_layer.js +0 -190
  234. package/src/style/style_layer/symbol_style_layer_properties.js +0 -153
  235. package/src/style/style_layer/typed_style_layer.js +0 -17
  236. package/src/style/style_layer.js +0 -281
  237. package/src/style/style_layer_index.js +0 -80
  238. package/src/style/validate_style.js +0 -42
  239. package/src/style/zoom_history.js +0 -44
  240. package/src/style-spec/.eslintrc +0 -5
  241. package/src/style-spec/CHANGELOG.md +0 -438
  242. package/src/style-spec/README.md +0 -59
  243. package/src/style-spec/bin/gl-style-composite +0 -9
  244. package/src/style-spec/bin/gl-style-format +0 -22
  245. package/src/style-spec/bin/gl-style-migrate +0 -9
  246. package/src/style-spec/bin/gl-style-validate +0 -50
  247. package/src/style-spec/composite.js +0 -50
  248. package/src/style-spec/declass.js +0 -42
  249. package/src/style-spec/deref.js +0 -52
  250. package/src/style-spec/diff.js +0 -393
  251. package/src/style-spec/dist/.gitkeep +0 -0
  252. package/src/style-spec/empty.js +0 -29
  253. package/src/style-spec/error/parsing_error.js +0 -16
  254. package/src/style-spec/error/validation_error.js +0 -18
  255. package/src/style-spec/expression/compound_expression.js +0 -162
  256. package/src/style-spec/expression/definitions/assertion.js +0 -130
  257. package/src/style-spec/expression/definitions/at.js +0 -70
  258. package/src/style-spec/expression/definitions/case.js +0 -85
  259. package/src/style-spec/expression/definitions/coalesce.js +0 -93
  260. package/src/style-spec/expression/definitions/coercion.js +0 -133
  261. package/src/style-spec/expression/definitions/collator.js +0 -78
  262. package/src/style-spec/expression/definitions/comparison.js +0 -184
  263. package/src/style-spec/expression/definitions/format.js +0 -144
  264. package/src/style-spec/expression/definitions/format_section_override.js +0 -54
  265. package/src/style-spec/expression/definitions/image.js +0 -52
  266. package/src/style-spec/expression/definitions/in.js +0 -92
  267. package/src/style-spec/expression/definitions/index.js +0 -561
  268. package/src/style-spec/expression/definitions/interpolate.js +0 -267
  269. package/src/style-spec/expression/definitions/length.js +0 -61
  270. package/src/style-spec/expression/definitions/let.js +0 -72
  271. package/src/style-spec/expression/definitions/literal.js +0 -77
  272. package/src/style-spec/expression/definitions/match.js +0 -158
  273. package/src/style-spec/expression/definitions/number_format.js +0 -142
  274. package/src/style-spec/expression/definitions/step.js +0 -120
  275. package/src/style-spec/expression/definitions/var.js +0 -46
  276. package/src/style-spec/expression/definitions/within.js +0 -333
  277. package/src/style-spec/expression/evaluation_context.js +0 -59
  278. package/src/style-spec/expression/expression.js +0 -27
  279. package/src/style-spec/expression/index.js +0 -392
  280. package/src/style-spec/expression/is_constant.js +0 -59
  281. package/src/style-spec/expression/parsing_context.js +0 -233
  282. package/src/style-spec/expression/parsing_error.js +0 -13
  283. package/src/style-spec/expression/runtime_error.js +0 -17
  284. package/src/style-spec/expression/scope.js +0 -36
  285. package/src/style-spec/expression/stops.js +0 -39
  286. package/src/style-spec/expression/types/collator.js +0 -61
  287. package/src/style-spec/expression/types/formatted.js +0 -73
  288. package/src/style-spec/expression/types/resolved_image.js +0 -29
  289. package/src/style-spec/expression/types.js +0 -106
  290. package/src/style-spec/expression/values.js +0 -123
  291. package/src/style-spec/feature_filter/README.md +0 -55
  292. package/src/style-spec/feature_filter/convert.js +0 -208
  293. package/src/style-spec/feature_filter/index.js +0 -165
  294. package/src/style-spec/format.js +0 -51
  295. package/src/style-spec/function/convert.js +0 -254
  296. package/src/style-spec/function/index.js +0 -262
  297. package/src/style-spec/group_by_layout.js +0 -75
  298. package/src/style-spec/migrate/expressions.js +0 -39
  299. package/src/style-spec/migrate/v8.js +0 -203
  300. package/src/style-spec/migrate/v9.js +0 -26
  301. package/src/style-spec/migrate.js +0 -36
  302. package/src/style-spec/package.json +0 -41
  303. package/src/style-spec/read_style.js +0 -14
  304. package/src/style-spec/reference/latest.js +0 -3
  305. package/src/style-spec/reference/v8.json +0 -5808
  306. package/src/style-spec/rollup.config.js +0 -45
  307. package/src/style-spec/style-spec.js +0 -122
  308. package/src/style-spec/types.js +0 -438
  309. package/src/style-spec/util/color.js +0 -95
  310. package/src/style-spec/util/color_spaces.js +0 -139
  311. package/src/style-spec/util/deep_equal.js +0 -28
  312. package/src/style-spec/util/extend.js +0 -10
  313. package/src/style-spec/util/get_type.js +0 -17
  314. package/src/style-spec/util/interpolate.js +0 -22
  315. package/src/style-spec/util/properties.js +0 -15
  316. package/src/style-spec/util/ref_properties.js +0 -2
  317. package/src/style-spec/util/result.js +0 -19
  318. package/src/style-spec/util/unbundle_jsonlint.js +0 -24
  319. package/src/style-spec/validate/latest.js +0 -11
  320. package/src/style-spec/validate/validate.js +0 -75
  321. package/src/style-spec/validate/validate_array.js +0 -52
  322. package/src/style-spec/validate/validate_boolean.js +0 -15
  323. package/src/style-spec/validate/validate_color.js +0 -20
  324. package/src/style-spec/validate/validate_constants.js +0 -13
  325. package/src/style-spec/validate/validate_enum.js +0 -21
  326. package/src/style-spec/validate/validate_expression.js +0 -43
  327. package/src/style-spec/validate/validate_filter.js +0 -111
  328. package/src/style-spec/validate/validate_formatted.js +0 -11
  329. package/src/style-spec/validate/validate_function.js +0 -207
  330. package/src/style-spec/validate/validate_glyphs_url.js +0 -21
  331. package/src/style-spec/validate/validate_image.js +0 -11
  332. package/src/style-spec/validate/validate_layer.js +0 -134
  333. package/src/style-spec/validate/validate_layout_property.js +0 -6
  334. package/src/style-spec/validate/validate_light.js +0 -47
  335. package/src/style-spec/validate/validate_number.js +0 -29
  336. package/src/style-spec/validate/validate_object.js +0 -61
  337. package/src/style-spec/validate/validate_paint_property.js +0 -6
  338. package/src/style-spec/validate/validate_property.js +0 -64
  339. package/src/style-spec/validate/validate_source.js +0 -111
  340. package/src/style-spec/validate/validate_string.js +0 -15
  341. package/src/style-spec/validate_mapbox_api_supported.js +0 -171
  342. package/src/style-spec/validate_style.js +0 -39
  343. package/src/style-spec/validate_style.min.js +0 -78
  344. package/src/style-spec/visit.js +0 -77
  345. package/src/symbol/anchor.js +0 -26
  346. package/src/symbol/check_max_angle.js +0 -81
  347. package/src/symbol/clip_line.js +0 -71
  348. package/src/symbol/collision_feature.js +0 -217
  349. package/src/symbol/collision_index.js +0 -372
  350. package/src/symbol/cross_tile_symbol_index.js +0 -301
  351. package/src/symbol/get_anchors.js +0 -167
  352. package/src/symbol/grid_index.js +0 -335
  353. package/src/symbol/mergelines.js +0 -82
  354. package/src/symbol/one_em.js +0 -4
  355. package/src/symbol/opacity_state.js +0 -27
  356. package/src/symbol/placement.js +0 -1062
  357. package/src/symbol/projection.js +0 -450
  358. package/src/symbol/quads.js +0 -334
  359. package/src/symbol/shaping.js +0 -816
  360. package/src/symbol/symbol_layout.js +0 -772
  361. package/src/symbol/symbol_size.js +0 -113
  362. package/src/symbol/transform_text.js +0 -29
  363. package/src/types/callback.js +0 -17
  364. package/src/types/cancelable.js +0 -3
  365. package/src/types/tilejson.js +0 -17
  366. package/src/types/transferable.js +0 -3
  367. package/src/types/window.js +0 -172
  368. package/src/ui/anchor.js +0 -32
  369. package/src/ui/bind_handlers.js +0 -202
  370. package/src/ui/camera.js +0 -1152
  371. package/src/ui/control/attribution_control.js +0 -189
  372. package/src/ui/control/fps_control.js +0 -185
  373. package/src/ui/control/fullscreen_control.js +0 -147
  374. package/src/ui/control/geolocate_control.js +0 -594
  375. package/src/ui/control/logo_control.js +0 -92
  376. package/src/ui/control/navigation_control.js +0 -148
  377. package/src/ui/control/scale_control.js +0 -142
  378. package/src/ui/crs.js +0 -64
  379. package/src/ui/default_locale.js +0 -20
  380. package/src/ui/events.js +0 -806
  381. package/src/ui/handler/box_zoom.js +0 -175
  382. package/src/ui/handler/dblclick_zoom.js +0 -139
  383. package/src/ui/handler/drag_pan.js +0 -416
  384. package/src/ui/handler/drag_rotate.js +0 -378
  385. package/src/ui/handler/keyboard.js +0 -161
  386. package/src/ui/handler/scroll_zoom.js +0 -333
  387. package/src/ui/handler/touch_zoom_rotate.js +0 -293
  388. package/src/ui/hash.js +0 -147
  389. package/src/ui/map.js +0 -2883
  390. package/src/ui/marker.js +0 -607
  391. package/src/ui/offline_map.js +0 -91
  392. package/src/ui/popup.js +0 -530
  393. package/src/util/actor.js +0 -212
  394. package/src/util/ajax.js +0 -371
  395. package/src/util/browser/web_worker.js +0 -10
  396. package/src/util/browser/window.js +0 -5
  397. package/src/util/browser.js +0 -70
  398. package/src/util/classify_rings.js +0 -52
  399. package/src/util/color_ramp.js +0 -28
  400. package/src/util/config.js +0 -30
  401. package/src/util/debug.js +0 -12
  402. package/src/util/dictionary_coder.js +0 -30
  403. package/src/util/dispatcher.js +0 -70
  404. package/src/util/dom.js +0 -144
  405. package/src/util/evented.js +0 -174
  406. package/src/util/find_pole_of_inaccessibility.js +0 -129
  407. package/src/util/global_worker_pool.js +0 -17
  408. package/src/util/image.js +0 -142
  409. package/src/util/intersection_tests.js +0 -208
  410. package/src/util/is_char_in_unicode_block.js +0 -311
  411. package/src/util/mapbox.js +0 -486
  412. package/src/util/offscreen_canvas_supported.js +0 -14
  413. package/src/util/performance.js +0 -112
  414. package/src/util/primitives.js +0 -145
  415. package/src/util/resolve_tokens.js +0 -16
  416. package/src/util/script_detection.js +0 -328
  417. package/src/util/sku_token.js +0 -42
  418. package/src/util/smart_wrap.js +0 -55
  419. package/src/util/struct_array.js +0 -243
  420. package/src/util/struct_array.js.ejs +0 -112
  421. package/src/util/struct_array_layout.js.ejs +0 -98
  422. package/src/util/task_queue.js +0 -68
  423. package/src/util/throttle.js +0 -28
  424. package/src/util/throttled_invoker.js +0 -46
  425. package/src/util/tile_cover.js +0 -101
  426. package/src/util/tile_request_cache.js +0 -172
  427. package/src/util/util.js +0 -504
  428. package/src/util/vectortile_to_geojson.js +0 -54
  429. package/src/util/verticalize_punctuation.js +0 -114
  430. package/src/util/web_worker.js +0 -91
  431. package/src/util/web_worker_transfer.js +0 -266
  432. package/src/util/webp_supported.js +0 -69
  433. package/src/util/window.js +0 -102
  434. package/src/util/worker_pool.js +0 -47
@@ -1,772 +0,0 @@
1
- // @flow
2
-
3
- import Anchor from './anchor';
4
-
5
- import {getAnchors, getCenterAnchor} from './get_anchors';
6
- import clipLine from './clip_line';
7
- import {shapeText, shapeIcon, WritingMode, fitIconToText} from './shaping';
8
- import {getGlyphQuads, getIconQuads} from './quads';
9
- import CollisionFeature from './collision_feature';
10
- import {warnOnce} from '../util/util';
11
- import {
12
- allowsVerticalWritingMode,
13
- allowsLetterSpacing
14
- } from '../util/script_detection';
15
- import findPoleOfInaccessibility from '../util/find_pole_of_inaccessibility';
16
- import classifyRings from '../util/classify_rings';
17
- import EXTENT from '../data/extent';
18
- import SymbolBucket from '../data/bucket/symbol_bucket';
19
- import EvaluationParameters from '../style/evaluation_parameters';
20
- import {SIZE_PACK_FACTOR} from './symbol_size';
21
- import ONE_EM from './one_em';
22
- import type {CanonicalTileID} from '../source/tile_id';
23
- import type {Shaping, PositionedIcon, TextJustify} from './shaping';
24
- import type {CollisionBoxArray} from '../data/array_types';
25
- import type {SymbolFeature} from '../data/bucket/symbol_bucket';
26
- import type {StyleImage} from '../style/style_image';
27
- import type {StyleGlyph} from '../style/style_glyph';
28
- import type SymbolStyleLayer from '../style/style_layer/symbol_style_layer';
29
- import type {ImagePosition} from '../render/image_atlas';
30
- import type {GlyphPosition} from '../render/glyph_atlas';
31
- import type {PossiblyEvaluatedPropertyValue} from '../style/properties';
32
-
33
- import Point from '@mapbox/point-geometry';
34
- import murmur3 from 'murmurhash-js';
35
-
36
- // The symbol layout process needs `text-size` evaluated at up to five different zoom levels, and
37
- // `icon-size` at up to three:
38
- //
39
- // 1. `text-size` at the zoom level of the bucket. Used to calculate a per-feature size for source `text-size`
40
- // expressions, and to calculate the box dimensions for icon-text-fit.
41
- // 2. `icon-size` at the zoom level of the bucket. Used to calculate a per-feature size for source `icon-size`
42
- // expressions.
43
- // 3. `text-size` and `icon-size` at the zoom level of the bucket, plus one. Used to calculate collision boxes.
44
- // 4. `text-size` at zoom level 18. Used for something line-symbol-placement-related.
45
- // 5. For composite `*-size` expressions: two zoom levels of curve stops that "cover" the zoom level of the
46
- // bucket. These go into a vertex buffer and are used by the shader to interpolate the size at render time.
47
- //
48
- // (1) and (2) are stored in `bucket.layers[0].layout`. The remainder are below.
49
- //
50
- type Sizes = {
51
- layoutTextSize: PossiblyEvaluatedPropertyValue<number>, // (3)
52
- layoutIconSize: PossiblyEvaluatedPropertyValue<number>, // (3)
53
- textMaxSize: PossiblyEvaluatedPropertyValue<number>, // (4)
54
- compositeTextSizes: [PossiblyEvaluatedPropertyValue<number>, PossiblyEvaluatedPropertyValue<number>], // (5)
55
- compositeIconSizes: [PossiblyEvaluatedPropertyValue<number>, PossiblyEvaluatedPropertyValue<number>], // (5)
56
- };
57
-
58
- export type TextAnchor = 'center' | 'left' | 'right' | 'top' | 'bottom' | 'top-left' | 'top-right' | 'bottom-left' | 'bottom-right';
59
-
60
- // The radial offset is to the edge of the text box
61
- // In the horizontal direction, the edge of the text box is where glyphs start
62
- // But in the vertical direction, the glyphs appear to "start" at the baseline
63
- // We don't actually load baseline data, but we assume an offset of ONE_EM - 17
64
- // (see "yOffset" in shaping.js)
65
- const baselineOffset = 7;
66
- const INVALID_TEXT_OFFSET = Number.POSITIVE_INFINITY;
67
-
68
- export function evaluateVariableOffset(anchor: TextAnchor, offset: [number, number]) {
69
-
70
- function fromRadialOffset(anchor: TextAnchor, radialOffset: number) {
71
- let x = 0, y = 0;
72
- if (radialOffset < 0) radialOffset = 0; // Ignore negative offset.
73
- // solve for r where r^2 + r^2 = radialOffset^2
74
- const hypotenuse = radialOffset / Math.sqrt(2);
75
- switch (anchor) {
76
- case 'top-right':
77
- case 'top-left':
78
- y = hypotenuse - baselineOffset;
79
- break;
80
- case 'bottom-right':
81
- case 'bottom-left':
82
- y = -hypotenuse + baselineOffset;
83
- break;
84
- case 'bottom':
85
- y = -radialOffset + baselineOffset;
86
- break;
87
- case 'top':
88
- y = radialOffset - baselineOffset;
89
- break;
90
- }
91
-
92
- switch (anchor) {
93
- case 'top-right':
94
- case 'bottom-right':
95
- x = -hypotenuse;
96
- break;
97
- case 'top-left':
98
- case 'bottom-left':
99
- x = hypotenuse;
100
- break;
101
- case 'left':
102
- x = radialOffset;
103
- break;
104
- case 'right':
105
- x = -radialOffset;
106
- break;
107
- }
108
-
109
- return [x, y];
110
- }
111
-
112
- function fromTextOffset(anchor: TextAnchor, offsetX: number, offsetY: number) {
113
- let x = 0, y = 0;
114
- // Use absolute offset values.
115
- offsetX = Math.abs(offsetX);
116
- offsetY = Math.abs(offsetY);
117
-
118
- switch (anchor) {
119
- case 'top-right':
120
- case 'top-left':
121
- case 'top':
122
- y = offsetY - baselineOffset;
123
- break;
124
- case 'bottom-right':
125
- case 'bottom-left':
126
- case 'bottom':
127
- y = -offsetY + baselineOffset;
128
- break;
129
- }
130
-
131
- switch (anchor) {
132
- case 'top-right':
133
- case 'bottom-right':
134
- case 'right':
135
- x = -offsetX;
136
- break;
137
- case 'top-left':
138
- case 'bottom-left':
139
- case 'left':
140
- x = offsetX;
141
- break;
142
- }
143
-
144
- return [x, y];
145
- }
146
-
147
- return (offset[1] !== INVALID_TEXT_OFFSET) ? fromTextOffset(anchor, offset[0], offset[1]) : fromRadialOffset(anchor, offset[0]);
148
- }
149
-
150
- export function performSymbolLayout(bucket: SymbolBucket,
151
- glyphMap: {[_: string]: {[number]: ?StyleGlyph}},
152
- glyphPositions: {[_: string]: {[number]: GlyphPosition}},
153
- imageMap: {[_: string]: StyleImage},
154
- imagePositions: {[_: string]: ImagePosition},
155
- showCollisionBoxes: boolean,
156
- canonical: CanonicalTileID) {
157
- bucket.createArrays();
158
-
159
- const tileSize = 512 * bucket.overscaling;
160
- bucket.tilePixelRatio = EXTENT / tileSize;
161
- bucket.compareText = {};
162
- bucket.iconsNeedLinear = false;
163
-
164
- const layout = bucket.layers[0].layout;
165
- const unevaluatedLayoutValues = bucket.layers[0]._unevaluatedLayout._values;
166
-
167
- const sizes = {};
168
-
169
- if (bucket.textSizeData.kind === 'composite') {
170
- const {minZoom, maxZoom} = bucket.textSizeData;
171
- sizes.compositeTextSizes = [
172
- unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(minZoom), canonical),
173
- unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(maxZoom), canonical)
174
- ];
175
- }
176
-
177
- if (bucket.iconSizeData.kind === 'composite') {
178
- const {minZoom, maxZoom} = bucket.iconSizeData;
179
- sizes.compositeIconSizes = [
180
- unevaluatedLayoutValues['icon-size'].possiblyEvaluate(new EvaluationParameters(minZoom), canonical),
181
- unevaluatedLayoutValues['icon-size'].possiblyEvaluate(new EvaluationParameters(maxZoom), canonical)
182
- ];
183
- }
184
-
185
- sizes.layoutTextSize = unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(bucket.zoom + 1), canonical);
186
- sizes.layoutIconSize = unevaluatedLayoutValues['icon-size'].possiblyEvaluate(new EvaluationParameters(bucket.zoom + 1), canonical);
187
- sizes.textMaxSize = unevaluatedLayoutValues['text-size'].possiblyEvaluate(new EvaluationParameters(18));
188
-
189
- const lineHeight = layout.get('text-line-height') * ONE_EM;
190
- const textAlongLine = layout.get('text-rotation-alignment') === 'map' && layout.get('symbol-placement') !== 'point';
191
- const keepUpright = layout.get('text-keep-upright');
192
- const textSize = layout.get('text-size');
193
-
194
- for (const feature of bucket.features) {
195
- const fontstack = layout.get('text-font').evaluate(feature, {}, canonical).join(',');
196
- const layoutTextSizeThisZoom = textSize.evaluate(feature, {}, canonical);
197
- const layoutTextSize = sizes.layoutTextSize.evaluate(feature, {}, canonical);
198
- const layoutIconSize = sizes.layoutIconSize.evaluate(feature, {}, canonical);
199
-
200
- const shapedTextOrientations = {
201
- horizontal: {},
202
- vertical: undefined
203
- };
204
- const text = feature.text;
205
- let textOffset: [number, number] = [0, 0];
206
- if (text) {
207
- const unformattedText = text.toString();
208
- const spacing = layout.get('text-letter-spacing').evaluate(feature, {}, canonical) * ONE_EM;
209
- const spacingIfAllowed = allowsLetterSpacing(unformattedText) ? spacing : 0;
210
-
211
- const textAnchor = layout.get('text-anchor').evaluate(feature, {}, canonical);
212
- const variableTextAnchor = layout.get('text-variable-anchor');
213
-
214
- if (!variableTextAnchor) {
215
- const radialOffset = layout.get('text-radial-offset').evaluate(feature, {}, canonical);
216
- // Layers with variable anchors use the `text-radial-offset` property and the [x, y] offset vector
217
- // is calculated at placement time instead of layout time
218
- if (radialOffset) {
219
- // The style spec says don't use `text-offset` and `text-radial-offset` together
220
- // but doesn't actually specify what happens if you use both. We go with the radial offset.
221
- textOffset = evaluateVariableOffset(textAnchor, [radialOffset * ONE_EM, INVALID_TEXT_OFFSET]);
222
- } else {
223
- textOffset = (layout.get('text-offset').evaluate(feature, {}, canonical).map(t => t * ONE_EM): any);
224
- }
225
- }
226
-
227
- let textJustify = textAlongLine ?
228
- "center" :
229
- layout.get('text-justify').evaluate(feature, {}, canonical);
230
-
231
- const symbolPlacement = layout.get('symbol-placement');
232
- const maxWidth = symbolPlacement === 'point' ?
233
- layout.get('text-max-width').evaluate(feature, {}, canonical) * ONE_EM :
234
- 0;
235
-
236
- const addVerticalShapingForPointLabelIfNeeded = () => {
237
- if (bucket.allowVerticalPlacement && allowsVerticalWritingMode(unformattedText)) {
238
- // Vertical POI label placement is meant to be used for scripts that support vertical
239
- // writing mode, thus, default left justification is used. If Latin
240
- // scripts would need to be supported, this should take into account other justifications.
241
- shapedTextOrientations.vertical = shapeText(text, glyphMap, glyphPositions, imagePositions, fontstack, maxWidth, lineHeight, textAnchor,
242
- 'left', spacingIfAllowed, textOffset, WritingMode.vertical, true, symbolPlacement, layoutTextSize, layoutTextSizeThisZoom);
243
- }
244
- };
245
-
246
- // If this layer uses text-variable-anchor, generate shapings for all justification possibilities.
247
- if (!textAlongLine && variableTextAnchor) {
248
- const justifications = textJustify === "auto" ?
249
- variableTextAnchor.map(a => getAnchorJustification(a)) :
250
- [textJustify];
251
-
252
- let singleLine = false;
253
- for (let i = 0; i < justifications.length; i++) {
254
- const justification: TextJustify = justifications[i];
255
- if (shapedTextOrientations.horizontal[justification]) continue;
256
- if (singleLine) {
257
- // If the shaping for the first justification was only a single line, we
258
- // can re-use it for the other justifications
259
- shapedTextOrientations.horizontal[justification] = shapedTextOrientations.horizontal[0];
260
- } else {
261
- // If using text-variable-anchor for the layer, we use a center anchor for all shapings and apply
262
- // the offsets for the anchor in the placement step.
263
- const shaping = shapeText(text, glyphMap, glyphPositions, imagePositions, fontstack, maxWidth, lineHeight, 'center',
264
- justification, spacingIfAllowed, textOffset, WritingMode.horizontal, false, symbolPlacement, layoutTextSize, layoutTextSizeThisZoom);
265
- if (shaping) {
266
- shapedTextOrientations.horizontal[justification] = shaping;
267
- singleLine = shaping.positionedLines.length === 1;
268
- }
269
- }
270
- }
271
-
272
- addVerticalShapingForPointLabelIfNeeded();
273
- } else {
274
- if (textJustify === "auto") {
275
- textJustify = getAnchorJustification(textAnchor);
276
- }
277
-
278
- // Horizontal point or line label.
279
- const shaping = shapeText(text, glyphMap, glyphPositions, imagePositions, fontstack, maxWidth, lineHeight, textAnchor, textJustify, spacingIfAllowed,
280
- textOffset, WritingMode.horizontal, false, symbolPlacement, layoutTextSize, layoutTextSizeThisZoom);
281
- if (shaping) shapedTextOrientations.horizontal[textJustify] = shaping;
282
-
283
- // Vertical point label (if allowVerticalPlacement is enabled).
284
- addVerticalShapingForPointLabelIfNeeded();
285
-
286
- // Verticalized line label.
287
- if (allowsVerticalWritingMode(unformattedText) && textAlongLine && keepUpright) {
288
- shapedTextOrientations.vertical = shapeText(text, glyphMap, glyphPositions, imagePositions, fontstack, maxWidth, lineHeight, textAnchor, textJustify,
289
- spacingIfAllowed, textOffset, WritingMode.vertical, false, symbolPlacement, layoutTextSize, layoutTextSizeThisZoom);
290
- }
291
- }
292
- }
293
-
294
- let shapedIcon;
295
- let isSDFIcon = false;
296
- if (feature.icon && feature.icon.name) {
297
- const image = imageMap[feature.icon.name];
298
- if (image) {
299
- shapedIcon = shapeIcon(
300
- imagePositions[feature.icon.name],
301
- layout.get('icon-offset').evaluate(feature, {}, canonical),
302
- layout.get('icon-anchor').evaluate(feature, {}, canonical));
303
- isSDFIcon = image.sdf;
304
- if (bucket.sdfIcons === undefined) {
305
- bucket.sdfIcons = image.sdf;
306
- } else if (bucket.sdfIcons !== image.sdf) {
307
- warnOnce('Style sheet warning: Cannot mix SDF and non-SDF icons in one buffer');
308
- }
309
- if (image.pixelRatio !== bucket.pixelRatio) {
310
- bucket.iconsNeedLinear = true;
311
- } else if (layout.get('icon-rotate').constantOr(1) !== 0) {
312
- bucket.iconsNeedLinear = true;
313
- }
314
- }
315
- }
316
-
317
- const shapedText = getDefaultHorizontalShaping(shapedTextOrientations.horizontal) || shapedTextOrientations.vertical;
318
- bucket.iconsInText = shapedText ? shapedText.iconsInText : false;
319
- if (shapedText || shapedIcon) {
320
- addFeature(bucket, feature, shapedTextOrientations, shapedIcon, imageMap, sizes, layoutTextSize, layoutIconSize, textOffset, isSDFIcon, canonical);
321
- }
322
- }
323
-
324
- if (showCollisionBoxes) {
325
- bucket.generateCollisionDebugBuffers();
326
- }
327
- }
328
-
329
- // Choose the justification that matches the direction of the TextAnchor
330
- export function getAnchorJustification(anchor: TextAnchor): TextJustify {
331
- switch (anchor) {
332
- case 'right':
333
- case 'top-right':
334
- case 'bottom-right':
335
- return 'right';
336
- case 'left':
337
- case 'top-left':
338
- case 'bottom-left':
339
- return 'left';
340
- }
341
- return 'center';
342
- }
343
-
344
- /**
345
- * Given a feature and its shaped text and icon data, add a 'symbol
346
- * instance' for each _possible_ placement of the symbol feature.
347
- * (At render timePlaceSymbols#place() selects which of these instances to
348
- * show or hide based on collisions with symbols in other layers.)
349
- * @private
350
- */
351
- function addFeature(bucket: SymbolBucket,
352
- feature: SymbolFeature,
353
- shapedTextOrientations: any,
354
- shapedIcon: PositionedIcon | void,
355
- imageMap: {[_: string]: StyleImage},
356
- sizes: Sizes,
357
- layoutTextSize: number,
358
- layoutIconSize: number,
359
- textOffset: [number, number],
360
- isSDFIcon: boolean, canonical: CanonicalTileID) {
361
- // To reduce the number of labels that jump around when zooming we need
362
- // to use a text-size value that is the same for all zoom levels.
363
- // bucket calculates text-size at a high zoom level so that all tiles can
364
- // use the same value when calculating anchor positions.
365
- let textMaxSize = sizes.textMaxSize.evaluate(feature, {});
366
- if (textMaxSize === undefined) {
367
- textMaxSize = layoutTextSize;
368
- }
369
- const layout = bucket.layers[0].layout;
370
- const iconOffset = layout.get('icon-offset').evaluate(feature, {}, canonical);
371
- const defaultHorizontalShaping = getDefaultHorizontalShaping(shapedTextOrientations.horizontal);
372
- const glyphSize = 24,
373
- fontScale = layoutTextSize / glyphSize,
374
- textBoxScale = bucket.tilePixelRatio * fontScale,
375
- textMaxBoxScale = bucket.tilePixelRatio * textMaxSize / glyphSize,
376
- iconBoxScale = bucket.tilePixelRatio * layoutIconSize,
377
- symbolMinDistance = bucket.tilePixelRatio * layout.get('symbol-spacing'),
378
- textPadding = layout.get('text-padding') * bucket.tilePixelRatio,
379
- iconPadding = layout.get('icon-padding') * bucket.tilePixelRatio,
380
- textMaxAngle = layout.get('text-max-angle') / 180 * Math.PI,
381
- textAlongLine = layout.get('text-rotation-alignment') === 'map' && layout.get('symbol-placement') !== 'point',
382
- iconAlongLine = layout.get('icon-rotation-alignment') === 'map' && layout.get('symbol-placement') !== 'point',
383
- symbolPlacement = layout.get('symbol-placement'),
384
- textRepeatDistance = symbolMinDistance / 2;
385
-
386
- const iconTextFit = layout.get('icon-text-fit');
387
- let verticallyShapedIcon;
388
- // Adjust shaped icon size when icon-text-fit is used.
389
- if (shapedIcon && iconTextFit !== 'none') {
390
- if (bucket.allowVerticalPlacement && shapedTextOrientations.vertical) {
391
- verticallyShapedIcon = fitIconToText(shapedIcon, shapedTextOrientations.vertical, iconTextFit,
392
- layout.get('icon-text-fit-padding'), iconOffset, fontScale);
393
- }
394
- if (defaultHorizontalShaping) {
395
- shapedIcon = fitIconToText(shapedIcon, defaultHorizontalShaping, iconTextFit,
396
- layout.get('icon-text-fit-padding'), iconOffset, fontScale);
397
- }
398
- }
399
-
400
- const addSymbolAtAnchor = (line, anchor) => {
401
- if (anchor.x < 0 || anchor.x >= EXTENT || anchor.y < 0 || anchor.y >= EXTENT) {
402
- // Symbol layers are drawn across tile boundaries, We filter out symbols
403
- // outside our tile boundaries (which may be included in vector tile buffers)
404
- // to prevent double-drawing symbols.
405
- return;
406
- }
407
-
408
- addSymbol(bucket, anchor, line, shapedTextOrientations, shapedIcon, imageMap, verticallyShapedIcon, bucket.layers[0],
409
- bucket.collisionBoxArray, feature.index, feature.sourceLayerIndex, bucket.index,
410
- textBoxScale, textPadding, textAlongLine, textOffset,
411
- iconBoxScale, iconPadding, iconAlongLine, iconOffset,
412
- feature, sizes, isSDFIcon, canonical);
413
- };
414
-
415
- if (symbolPlacement === 'line') {
416
- for (const line of clipLine(feature.geometry, 0, 0, EXTENT, EXTENT)) {
417
- const anchors = getAnchors(
418
- line,
419
- symbolMinDistance,
420
- textMaxAngle,
421
- shapedTextOrientations.vertical || defaultHorizontalShaping,
422
- shapedIcon,
423
- glyphSize,
424
- textMaxBoxScale,
425
- bucket.overscaling,
426
- EXTENT
427
- );
428
- for (const anchor of anchors) {
429
- const shapedText = defaultHorizontalShaping;
430
- if (!shapedText || !anchorIsTooClose(bucket, shapedText.text, textRepeatDistance, anchor)) {
431
- addSymbolAtAnchor(line, anchor);
432
- }
433
- }
434
- }
435
- } else if (symbolPlacement === 'line-center') {
436
- // No clipping, multiple lines per feature are allowed
437
- // "lines" with only one point are ignored as in clipLines
438
- for (const line of feature.geometry) {
439
- if (line.length > 1) {
440
- const anchor = getCenterAnchor(
441
- line,
442
- textMaxAngle,
443
- shapedTextOrientations.vertical || defaultHorizontalShaping,
444
- shapedIcon,
445
- glyphSize,
446
- textMaxBoxScale);
447
- if (anchor) {
448
- addSymbolAtAnchor(line, anchor);
449
- }
450
- }
451
- }
452
- } else if (feature.type === 'Polygon') {
453
- for (const polygon of classifyRings(feature.geometry, 0)) {
454
- // 16 here represents 2 pixels
455
- const poi = findPoleOfInaccessibility(polygon, 16);
456
- addSymbolAtAnchor(polygon[0], new Anchor(poi.x, poi.y, 0));
457
- }
458
- } else if (feature.type === 'LineString') {
459
- // https://github.com/mapbox/mapbox-gl-js/issues/3808
460
- for (const line of feature.geometry) {
461
- addSymbolAtAnchor(line, new Anchor(line[0].x, line[0].y, 0));
462
- }
463
- } else if (feature.type === 'Point') {
464
- for (const points of feature.geometry) {
465
- for (const point of points) {
466
- addSymbolAtAnchor([point], new Anchor(point.x, point.y, 0));
467
- }
468
- }
469
- }
470
- }
471
-
472
- const MAX_GLYPH_ICON_SIZE = 255;
473
- const MAX_PACKED_SIZE = MAX_GLYPH_ICON_SIZE * SIZE_PACK_FACTOR;
474
- export {MAX_PACKED_SIZE};
475
-
476
- function addTextVertices(bucket: SymbolBucket,
477
- anchor: Point,
478
- shapedText: Shaping,
479
- imageMap: {[_: string]: StyleImage},
480
- layer: SymbolStyleLayer,
481
- textAlongLine: boolean,
482
- feature: SymbolFeature,
483
- textOffset: [number, number],
484
- lineArray: {lineStartIndex: number, lineLength: number},
485
- writingMode: number,
486
- placementTypes: Array<'vertical' | 'center' | 'left' | 'right'>,
487
- placedTextSymbolIndices: {[_: string]: number},
488
- placedIconIndex: number,
489
- sizes: Sizes,
490
- canonical: CanonicalTileID) {
491
- const glyphQuads = getGlyphQuads(anchor, shapedText, textOffset,
492
- layer, textAlongLine, feature, imageMap, bucket.allowVerticalPlacement);
493
-
494
- const sizeData = bucket.textSizeData;
495
- let textSizeData = null;
496
-
497
- if (sizeData.kind === 'source') {
498
- textSizeData = [
499
- SIZE_PACK_FACTOR * layer.layout.get('text-size').evaluate(feature, {})
500
- ];
501
- if (textSizeData[0] > MAX_PACKED_SIZE) {
502
- warnOnce(`${bucket.layerIds[0]}: Value for "text-size" is >= ${MAX_GLYPH_ICON_SIZE}. Reduce your "text-size".`);
503
- }
504
- } else if (sizeData.kind === 'composite') {
505
- textSizeData = [
506
- SIZE_PACK_FACTOR * sizes.compositeTextSizes[0].evaluate(feature, {}, canonical),
507
- SIZE_PACK_FACTOR * sizes.compositeTextSizes[1].evaluate(feature, {}, canonical)
508
- ];
509
- if (textSizeData[0] > MAX_PACKED_SIZE || textSizeData[1] > MAX_PACKED_SIZE) {
510
- warnOnce(`${bucket.layerIds[0]}: Value for "text-size" is >= ${MAX_GLYPH_ICON_SIZE}. Reduce your "text-size".`);
511
- }
512
- }
513
-
514
- bucket.addSymbols(
515
- bucket.text,
516
- glyphQuads,
517
- textSizeData,
518
- textOffset,
519
- textAlongLine,
520
- feature,
521
- writingMode,
522
- anchor,
523
- lineArray.lineStartIndex,
524
- lineArray.lineLength,
525
- placedIconIndex,
526
- canonical);
527
-
528
- // The placedSymbolArray is used at render time in drawTileSymbols
529
- // These indices allow access to the array at collision detection time
530
- for (const placementType of placementTypes) {
531
- placedTextSymbolIndices[placementType] = bucket.text.placedSymbolArray.length - 1;
532
- }
533
-
534
- return glyphQuads.length * 4;
535
- }
536
-
537
- function getDefaultHorizontalShaping(horizontalShaping: {[_: TextJustify]: Shaping}): Shaping | null {
538
- // We don't care which shaping we get because this is used for collision purposes
539
- // and all the justifications have the same collision box
540
- for (const justification: any in horizontalShaping) {
541
- return horizontalShaping[justification];
542
- }
543
- return null;
544
- }
545
-
546
- /**
547
- * Add a single label & icon placement.
548
- *
549
- * @private
550
- */
551
- function addSymbol(bucket: SymbolBucket,
552
- anchor: Anchor,
553
- line: Array<Point>,
554
- shapedTextOrientations: any,
555
- shapedIcon: PositionedIcon | void,
556
- imageMap: {[_: string]: StyleImage},
557
- verticallyShapedIcon: PositionedIcon | void,
558
- layer: SymbolStyleLayer,
559
- collisionBoxArray: CollisionBoxArray,
560
- featureIndex: number,
561
- sourceLayerIndex: number,
562
- bucketIndex: number,
563
- textBoxScale: number,
564
- textPadding: number,
565
- textAlongLine: boolean,
566
- textOffset: [number, number],
567
- iconBoxScale: number,
568
- iconPadding: number,
569
- iconAlongLine: boolean,
570
- iconOffset: [number, number],
571
- feature: SymbolFeature,
572
- sizes: Sizes,
573
- isSDFIcon: boolean,
574
- canonical: CanonicalTileID) {
575
- const lineArray = bucket.addToLineVertexArray(anchor, line);
576
-
577
- let textCollisionFeature, iconCollisionFeature, verticalTextCollisionFeature, verticalIconCollisionFeature;
578
-
579
- let numIconVertices = 0;
580
- let numVerticalIconVertices = 0;
581
- let numHorizontalGlyphVertices = 0;
582
- let numVerticalGlyphVertices = 0;
583
- let placedIconSymbolIndex = -1;
584
- let verticalPlacedIconSymbolIndex = -1;
585
- const placedTextSymbolIndices = {};
586
- let key = murmur3('');
587
-
588
- let textOffset0 = 0;
589
- let textOffset1 = 0;
590
- if (layer._unevaluatedLayout.getValue('text-radial-offset') === undefined) {
591
- [textOffset0, textOffset1] = (layer.layout.get('text-offset').evaluate(feature, {}, canonical).map(t => t * ONE_EM): any);
592
- } else {
593
- textOffset0 = layer.layout.get('text-radial-offset').evaluate(feature, {}, canonical) * ONE_EM;
594
- textOffset1 = INVALID_TEXT_OFFSET;
595
- }
596
-
597
- if (bucket.allowVerticalPlacement && shapedTextOrientations.vertical) {
598
- const textRotation = layer.layout.get('text-rotate').evaluate(feature, {}, canonical);
599
- const verticalTextRotation = textRotation + 90.0;
600
- const verticalShaping = shapedTextOrientations.vertical;
601
- verticalTextCollisionFeature = new CollisionFeature(collisionBoxArray, line, anchor, featureIndex, sourceLayerIndex, bucketIndex, verticalShaping, textBoxScale, textPadding, textAlongLine, bucket.overscaling, verticalTextRotation);
602
-
603
- if (verticallyShapedIcon) {
604
- verticalIconCollisionFeature = new CollisionFeature(collisionBoxArray, line, anchor, featureIndex, sourceLayerIndex, bucketIndex, verticallyShapedIcon, iconBoxScale, iconPadding, textAlongLine, bucket.overscaling, verticalTextRotation);
605
- }
606
- }
607
-
608
- //Place icon first, so text can have a reference to its index in the placed symbol array.
609
- //Text symbols can lazily shift at render-time because of variable anchor placement.
610
- //If the style specifies an `icon-text-fit` then the icon would have to shift along with it.
611
- // For more info check `updateVariableAnchors` in `draw_symbol.js` .
612
- if (shapedIcon) {
613
- const iconRotate = layer.layout.get('icon-rotate').evaluate(feature, {});
614
- const hasIconTextFit = layer.layout.get('icon-text-fit') !== 'none';
615
- const iconQuads = getIconQuads(shapedIcon, iconRotate, isSDFIcon, hasIconTextFit);
616
- const verticalIconQuads = verticallyShapedIcon ? getIconQuads(verticallyShapedIcon, iconRotate, isSDFIcon, hasIconTextFit) : undefined;
617
- iconCollisionFeature = new CollisionFeature(collisionBoxArray, line, anchor, featureIndex, sourceLayerIndex, bucketIndex, shapedIcon, iconBoxScale, iconPadding, /*align boxes to line*/false, bucket.overscaling, iconRotate);
618
-
619
- numIconVertices = iconQuads.length * 4;
620
-
621
- const sizeData = bucket.iconSizeData;
622
- let iconSizeData = null;
623
-
624
- if (sizeData.kind === 'source') {
625
- iconSizeData = [
626
- SIZE_PACK_FACTOR * layer.layout.get('icon-size').evaluate(feature, {})
627
- ];
628
- if (iconSizeData[0] > MAX_PACKED_SIZE) {
629
- warnOnce(`${bucket.layerIds[0]}: Value for "icon-size" is >= ${MAX_GLYPH_ICON_SIZE}. Reduce your "icon-size".`);
630
- }
631
- } else if (sizeData.kind === 'composite') {
632
- iconSizeData = [
633
- SIZE_PACK_FACTOR * sizes.compositeIconSizes[0].evaluate(feature, {}, canonical),
634
- SIZE_PACK_FACTOR * sizes.compositeIconSizes[1].evaluate(feature, {}, canonical)
635
- ];
636
- if (iconSizeData[0] > MAX_PACKED_SIZE || iconSizeData[1] > MAX_PACKED_SIZE) {
637
- warnOnce(`${bucket.layerIds[0]}: Value for "icon-size" is >= ${MAX_GLYPH_ICON_SIZE}. Reduce your "icon-size".`);
638
- }
639
- }
640
-
641
- bucket.addSymbols(
642
- bucket.icon,
643
- iconQuads,
644
- iconSizeData,
645
- iconOffset,
646
- iconAlongLine,
647
- feature,
648
- false,
649
- anchor,
650
- lineArray.lineStartIndex,
651
- lineArray.lineLength,
652
- // The icon itself does not have an associated symbol since the text isnt placed yet
653
- -1, canonical);
654
-
655
- placedIconSymbolIndex = bucket.icon.placedSymbolArray.length - 1;
656
-
657
- if (verticalIconQuads) {
658
- numVerticalIconVertices = verticalIconQuads.length * 4;
659
-
660
- bucket.addSymbols(
661
- bucket.icon,
662
- verticalIconQuads,
663
- iconSizeData,
664
- iconOffset,
665
- iconAlongLine,
666
- feature,
667
- WritingMode.vertical,
668
- anchor,
669
- lineArray.lineStartIndex,
670
- lineArray.lineLength,
671
- // The icon itself does not have an associated symbol since the text isnt placed yet
672
- -1, canonical);
673
-
674
- verticalPlacedIconSymbolIndex = bucket.icon.placedSymbolArray.length - 1;
675
- }
676
- }
677
-
678
- for (const justification: any in shapedTextOrientations.horizontal) {
679
- const shaping = shapedTextOrientations.horizontal[justification];
680
-
681
- if (!textCollisionFeature) {
682
- key = murmur3(shaping.text);
683
- const textRotate = layer.layout.get('text-rotate').evaluate(feature, {}, canonical);
684
- // As a collision approximation, we can use either the vertical or any of the horizontal versions of the feature
685
- // We're counting on all versions having similar dimensions
686
- textCollisionFeature = new CollisionFeature(collisionBoxArray, line, anchor, featureIndex, sourceLayerIndex, bucketIndex, shaping, textBoxScale, textPadding, textAlongLine, bucket.overscaling, textRotate);
687
- }
688
-
689
- const singleLine = shaping.positionedLines.length === 1;
690
- numHorizontalGlyphVertices += addTextVertices(
691
- bucket, anchor, shaping, imageMap, layer, textAlongLine, feature, textOffset, lineArray,
692
- shapedTextOrientations.vertical ? WritingMode.horizontal : WritingMode.horizontalOnly,
693
- singleLine ? (Object.keys(shapedTextOrientations.horizontal): any) : [justification],
694
- placedTextSymbolIndices, placedIconSymbolIndex, sizes, canonical);
695
-
696
- if (singleLine) {
697
- break;
698
- }
699
- }
700
-
701
- if (shapedTextOrientations.vertical) {
702
- numVerticalGlyphVertices += addTextVertices(
703
- bucket, anchor, shapedTextOrientations.vertical, imageMap, layer, textAlongLine, feature,
704
- textOffset, lineArray, WritingMode.vertical, ['vertical'], placedTextSymbolIndices, verticalPlacedIconSymbolIndex, sizes, canonical);
705
- }
706
-
707
- const textBoxStartIndex = textCollisionFeature ? textCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;
708
- const textBoxEndIndex = textCollisionFeature ? textCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;
709
-
710
- const verticalTextBoxStartIndex = verticalTextCollisionFeature ? verticalTextCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;
711
- const verticalTextBoxEndIndex = verticalTextCollisionFeature ? verticalTextCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;
712
-
713
- const iconBoxStartIndex = iconCollisionFeature ? iconCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;
714
- const iconBoxEndIndex = iconCollisionFeature ? iconCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;
715
-
716
- const verticalIconBoxStartIndex = verticalIconCollisionFeature ? verticalIconCollisionFeature.boxStartIndex : bucket.collisionBoxArray.length;
717
- const verticalIconBoxEndIndex = verticalIconCollisionFeature ? verticalIconCollisionFeature.boxEndIndex : bucket.collisionBoxArray.length;
718
-
719
- if (bucket.glyphOffsetArray.length >= SymbolBucket.MAX_GLYPHS) warnOnce(
720
- "Too many glyphs being rendered in a tile. See https://github.com/mapbox/mapbox-gl-js/issues/2907"
721
- );
722
-
723
- if (feature.sortKey !== undefined) {
724
- bucket.addToSortKeyRanges(bucket.symbolInstances.length, feature.sortKey);
725
- }
726
-
727
- bucket.symbolInstances.emplaceBack(
728
- anchor.x,
729
- anchor.y,
730
- placedTextSymbolIndices.right >= 0 ? placedTextSymbolIndices.right : -1,
731
- placedTextSymbolIndices.center >= 0 ? placedTextSymbolIndices.center : -1,
732
- placedTextSymbolIndices.left >= 0 ? placedTextSymbolIndices.left : -1,
733
- placedTextSymbolIndices.vertical || -1,
734
- placedIconSymbolIndex,
735
- verticalPlacedIconSymbolIndex,
736
- key,
737
- textBoxStartIndex,
738
- textBoxEndIndex,
739
- verticalTextBoxStartIndex,
740
- verticalTextBoxEndIndex,
741
- iconBoxStartIndex,
742
- iconBoxEndIndex,
743
- verticalIconBoxStartIndex,
744
- verticalIconBoxEndIndex,
745
- featureIndex,
746
- numHorizontalGlyphVertices,
747
- numVerticalGlyphVertices,
748
- numIconVertices,
749
- numVerticalIconVertices,
750
- 0,
751
- textBoxScale,
752
- textOffset0,
753
- textOffset1);
754
- }
755
-
756
- function anchorIsTooClose(bucket: any, text: string, repeatDistance: number, anchor: Point) {
757
- const compareText = bucket.compareText;
758
- if (!(text in compareText)) {
759
- compareText[text] = [];
760
- } else {
761
- const otherAnchors = compareText[text];
762
- for (let k = otherAnchors.length - 1; k >= 0; k--) {
763
- if (anchor.dist(otherAnchors[k]) < repeatDistance) {
764
- // If it's within repeatDistance of one anchor, stop looking
765
- return true;
766
- }
767
- }
768
- }
769
- // If anchor is not within repeatDistance of any other anchor, add to array
770
- compareText[text].push(anchor);
771
- return false;
772
- }