@mapwhit/tilerenderer 0.47.1

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 (356) hide show
  1. package/LICENSE.txt +87 -0
  2. package/README.md +25 -0
  3. package/build/min/.dir +0 -0
  4. package/build/min/package.json +3 -0
  5. package/build/min/src/shaders/_prelude.fragment.glsl.txt +13 -0
  6. package/build/min/src/shaders/_prelude.vertex.glsl.txt +14 -0
  7. package/build/min/src/shaders/background.fragment.glsl.txt +5 -0
  8. package/build/min/src/shaders/background.vertex.glsl.txt +1 -0
  9. package/build/min/src/shaders/background_pattern.fragment.glsl.txt +5 -0
  10. package/build/min/src/shaders/background_pattern.vertex.glsl.txt +1 -0
  11. package/build/min/src/shaders/circle.fragment.glsl.txt +20 -0
  12. package/build/min/src/shaders/circle.vertex.glsl.txt +17 -0
  13. package/build/min/src/shaders/clipping_mask.fragment.glsl.txt +1 -0
  14. package/build/min/src/shaders/clipping_mask.vertex.glsl.txt +1 -0
  15. package/build/min/src/shaders/collision_box.fragment.glsl.txt +1 -0
  16. package/build/min/src/shaders/collision_box.vertex.glsl.txt +1 -0
  17. package/build/min/src/shaders/collision_circle.fragment.glsl.txt +1 -0
  18. package/build/min/src/shaders/collision_circle.vertex.glsl.txt +1 -0
  19. package/build/min/src/shaders/debug.fragment.glsl.txt +1 -0
  20. package/build/min/src/shaders/debug.vertex.glsl.txt +1 -0
  21. package/build/min/src/shaders/fill.fragment.glsl.txt +10 -0
  22. package/build/min/src/shaders/fill.vertex.glsl.txt +7 -0
  23. package/build/min/src/shaders/fill_extrusion.fragment.glsl.txt +13 -0
  24. package/build/min/src/shaders/fill_extrusion.vertex.glsl.txt +9 -0
  25. package/build/min/src/shaders/fill_extrusion_pattern.fragment.glsl.txt +15 -0
  26. package/build/min/src/shaders/fill_extrusion_pattern.vertex.glsl.txt +11 -0
  27. package/build/min/src/shaders/fill_outline.fragment.glsl.txt +10 -0
  28. package/build/min/src/shaders/fill_outline.vertex.glsl.txt +7 -0
  29. package/build/min/src/shaders/fill_outline_pattern.fragment.glsl.txt +13 -0
  30. package/build/min/src/shaders/fill_outline_pattern.vertex.glsl.txt +9 -0
  31. package/build/min/src/shaders/fill_pattern.fragment.glsl.txt +13 -0
  32. package/build/min/src/shaders/fill_pattern.vertex.glsl.txt +9 -0
  33. package/build/min/src/shaders/heatmap.fragment.glsl.txt +10 -0
  34. package/build/min/src/shaders/heatmap.vertex.glsl.txt +8 -0
  35. package/build/min/src/shaders/heatmap_texture.fragment.glsl.txt +5 -0
  36. package/build/min/src/shaders/heatmap_texture.vertex.glsl.txt +1 -0
  37. package/build/min/src/shaders/hillshade.fragment.glsl.txt +7 -0
  38. package/build/min/src/shaders/hillshade.vertex.glsl.txt +1 -0
  39. package/build/min/src/shaders/hillshade_prepare.fragment.glsl.txt +8 -0
  40. package/build/min/src/shaders/hillshade_prepare.vertex.glsl.txt +1 -0
  41. package/build/min/src/shaders/line.fragment.glsl.txt +12 -0
  42. package/build/min/src/shaders/line.vertex.glsl.txt +17 -0
  43. package/build/min/src/shaders/line_gradient.fragment.glsl.txt +10 -0
  44. package/build/min/src/shaders/line_gradient.vertex.glsl.txt +16 -0
  45. package/build/min/src/shaders/line_pattern.fragment.glsl.txt +15 -0
  46. package/build/min/src/shaders/line_pattern.vertex.glsl.txt +20 -0
  47. package/build/min/src/shaders/line_sdf.fragment.glsl.txt +17 -0
  48. package/build/min/src/shaders/line_sdf.vertex.glsl.txt +20 -0
  49. package/build/min/src/shaders/raster.fragment.glsl.txt +5 -0
  50. package/build/min/src/shaders/raster.vertex.glsl.txt +1 -0
  51. package/build/min/src/shaders/symbol_icon.fragment.glsl.txt +9 -0
  52. package/build/min/src/shaders/symbol_icon.vertex.glsl.txt +5 -0
  53. package/build/min/src/shaders/symbol_sdf.fragment.glsl.txt +19 -0
  54. package/build/min/src/shaders/symbol_sdf.vertex.glsl.txt +13 -0
  55. package/package.json +44 -0
  56. package/src/css/mapbox-gl.css +506 -0
  57. package/src/css/svg/mapboxgl-ctrl-attrib.svg +3 -0
  58. package/src/css/svg/mapboxgl-ctrl-compass.svg +4 -0
  59. package/src/css/svg/mapboxgl-ctrl-fullscreen.svg +3 -0
  60. package/src/css/svg/mapboxgl-ctrl-geolocate-background.svg +3 -0
  61. package/src/css/svg/mapboxgl-ctrl-geolocate.svg +3 -0
  62. package/src/css/svg/mapboxgl-ctrl-logo-compact.svg +2 -0
  63. package/src/css/svg/mapboxgl-ctrl-logo.svg +1 -0
  64. package/src/css/svg/mapboxgl-ctrl-shrink.svg +3 -0
  65. package/src/css/svg/mapboxgl-ctrl-zoom-in.svg +3 -0
  66. package/src/css/svg/mapboxgl-ctrl-zoom-out.svg +3 -0
  67. package/src/data/array_types.js +1138 -0
  68. package/src/data/bucket/circle_attributes.js +5 -0
  69. package/src/data/bucket/circle_bucket.js +118 -0
  70. package/src/data/bucket/fill_attributes.js +5 -0
  71. package/src/data/bucket/fill_bucket.js +166 -0
  72. package/src/data/bucket/fill_extrusion_attributes.js +11 -0
  73. package/src/data/bucket/fill_extrusion_bucket.js +247 -0
  74. package/src/data/bucket/heatmap_bucket.js +12 -0
  75. package/src/data/bucket/line_attributes.js +11 -0
  76. package/src/data/bucket/line_bucket.js +625 -0
  77. package/src/data/bucket/pattern_attributes.js +9 -0
  78. package/src/data/bucket/pattern_bucket_features.js +44 -0
  79. package/src/data/bucket/symbol_attributes.js +95 -0
  80. package/src/data/bucket/symbol_bucket.js +697 -0
  81. package/src/data/bucket.js +53 -0
  82. package/src/data/dem_data.js +126 -0
  83. package/src/data/extent.js +17 -0
  84. package/src/data/feature_index.js +254 -0
  85. package/src/data/index_array_type.js +14 -0
  86. package/src/data/load_geometry.js +42 -0
  87. package/src/data/pos_attributes.js +3 -0
  88. package/src/data/program_configuration.js +782 -0
  89. package/src/data/raster_bounds_attributes.js +6 -0
  90. package/src/data/segment.js +63 -0
  91. package/src/geo/coordinate.js +78 -0
  92. package/src/geo/lng_lat.js +129 -0
  93. package/src/geo/lng_lat_bounds.js +253 -0
  94. package/src/geo/transform.js +605 -0
  95. package/src/gl/color_mode.js +21 -0
  96. package/src/gl/context.js +193 -0
  97. package/src/gl/cull_face_mode.js +22 -0
  98. package/src/gl/depth_mode.js +18 -0
  99. package/src/gl/framebuffer.js +28 -0
  100. package/src/gl/index_buffer.js +52 -0
  101. package/src/gl/stencil_mode.js +17 -0
  102. package/src/gl/types.js +0 -0
  103. package/src/gl/value.js +676 -0
  104. package/src/gl/vertex_buffer.js +101 -0
  105. package/src/index.js +50 -0
  106. package/src/render/draw_background.js +60 -0
  107. package/src/render/draw_circle.js +55 -0
  108. package/src/render/draw_collision_debug.js +45 -0
  109. package/src/render/draw_debug.js +429 -0
  110. package/src/render/draw_fill.js +143 -0
  111. package/src/render/draw_fill_extrusion.js +101 -0
  112. package/src/render/draw_heatmap.js +159 -0
  113. package/src/render/draw_hillshade.js +144 -0
  114. package/src/render/draw_line.js +99 -0
  115. package/src/render/draw_raster.js +151 -0
  116. package/src/render/draw_symbol.js +231 -0
  117. package/src/render/glyph_atlas.js +55 -0
  118. package/src/render/glyph_manager.js +145 -0
  119. package/src/render/image_atlas.js +97 -0
  120. package/src/render/image_manager.js +183 -0
  121. package/src/render/line_atlas.js +139 -0
  122. package/src/render/painter.js +483 -0
  123. package/src/render/program/background_program.js +46 -0
  124. package/src/render/program/circle_program.js +40 -0
  125. package/src/render/program/clipping_mask_program.js +11 -0
  126. package/src/render/program/collision_program.js +28 -0
  127. package/src/render/program/debug_program.js +13 -0
  128. package/src/render/program/fill_extrusion_program.js +76 -0
  129. package/src/render/program/fill_program.js +60 -0
  130. package/src/render/program/heatmap_program.js +46 -0
  131. package/src/render/program/hillshade_program.js +77 -0
  132. package/src/render/program/line_program.js +119 -0
  133. package/src/render/program/pattern.js +57 -0
  134. package/src/render/program/program_uniforms.js +46 -0
  135. package/src/render/program/raster_program.js +50 -0
  136. package/src/render/program/symbol_program.js +112 -0
  137. package/src/render/program.js +133 -0
  138. package/src/render/texture.js +88 -0
  139. package/src/render/tile_mask.js +108 -0
  140. package/src/render/uniform_binding.js +129 -0
  141. package/src/render/vertex_array_object.js +155 -0
  142. package/src/shaders/README.md +42 -0
  143. package/src/shaders/_prelude.fragment.glsl +17 -0
  144. package/src/shaders/_prelude.vertex.glsl +73 -0
  145. package/src/shaders/background.fragment.glsl +10 -0
  146. package/src/shaders/background.vertex.glsl +7 -0
  147. package/src/shaders/background_pattern.fragment.glsl +28 -0
  148. package/src/shaders/background_pattern.vertex.glsl +20 -0
  149. package/src/shaders/circle.fragment.glsl +39 -0
  150. package/src/shaders/circle.vertex.glsl +63 -0
  151. package/src/shaders/clipping_mask.fragment.glsl +3 -0
  152. package/src/shaders/clipping_mask.vertex.glsl +7 -0
  153. package/src/shaders/collision_box.fragment.glsl +21 -0
  154. package/src/shaders/collision_box.vertex.glsl +26 -0
  155. package/src/shaders/collision_circle.fragment.glsl +34 -0
  156. package/src/shaders/collision_circle.vertex.glsl +36 -0
  157. package/src/shaders/debug.fragment.glsl +5 -0
  158. package/src/shaders/debug.vertex.glsl +7 -0
  159. package/src/shaders/encode_attribute.js +19 -0
  160. package/src/shaders/fill.fragment.glsl +13 -0
  161. package/src/shaders/fill.vertex.glsl +13 -0
  162. package/src/shaders/fill_extrusion.fragment.glsl +16 -0
  163. package/src/shaders/fill_extrusion.vertex.glsl +66 -0
  164. package/src/shaders/fill_extrusion_pattern.fragment.glsl +41 -0
  165. package/src/shaders/fill_extrusion_pattern.vertex.glsl +76 -0
  166. package/src/shaders/fill_outline.fragment.glsl +17 -0
  167. package/src/shaders/fill_outline.vertex.glsl +17 -0
  168. package/src/shaders/fill_outline_pattern.fragment.glsl +43 -0
  169. package/src/shaders/fill_outline_pattern.vertex.glsl +41 -0
  170. package/src/shaders/fill_pattern.fragment.glsl +36 -0
  171. package/src/shaders/fill_pattern.vertex.glsl +36 -0
  172. package/src/shaders/heatmap.fragment.glsl +21 -0
  173. package/src/shaders/heatmap.vertex.glsl +53 -0
  174. package/src/shaders/heatmap_texture.fragment.glsl +14 -0
  175. package/src/shaders/heatmap_texture.vertex.glsl +11 -0
  176. package/src/shaders/hillshade.fragment.glsl +52 -0
  177. package/src/shaders/hillshade.vertex.glsl +11 -0
  178. package/src/shaders/hillshade_prepare.fragment.glsl +72 -0
  179. package/src/shaders/hillshade_prepare.vertex.glsl +15 -0
  180. package/src/shaders/index.js +194 -0
  181. package/src/shaders/line.fragment.glsl +28 -0
  182. package/src/shaders/line.vertex.glsl +84 -0
  183. package/src/shaders/line_gradient.fragment.glsl +34 -0
  184. package/src/shaders/line_gradient.vertex.glsl +84 -0
  185. package/src/shaders/line_pattern.fragment.glsl +69 -0
  186. package/src/shaders/line_pattern.vertex.glsl +88 -0
  187. package/src/shaders/line_sdf.fragment.glsl +44 -0
  188. package/src/shaders/line_sdf.vertex.glsl +95 -0
  189. package/src/shaders/raster.fragment.glsl +52 -0
  190. package/src/shaders/raster.vertex.glsl +21 -0
  191. package/src/shaders/symbol_icon.fragment.glsl +17 -0
  192. package/src/shaders/symbol_icon.vertex.glsl +91 -0
  193. package/src/shaders/symbol_sdf.fragment.glsl +50 -0
  194. package/src/shaders/symbol_sdf.vertex.glsl +117 -0
  195. package/src/source/geojson_source.js +267 -0
  196. package/src/source/geojson_worker_source.js +210 -0
  197. package/src/source/geojson_wrapper.js +67 -0
  198. package/src/source/image_source.js +213 -0
  199. package/src/source/load_tilejson.js +40 -0
  200. package/src/source/pixels_to_tile_units.js +17 -0
  201. package/src/source/query_features.js +198 -0
  202. package/src/source/raster_dem_tile_source.js +140 -0
  203. package/src/source/raster_dem_tile_worker_source.js +26 -0
  204. package/src/source/raster_tile_source.js +126 -0
  205. package/src/source/rtl_text_plugin.js +63 -0
  206. package/src/source/source.js +75 -0
  207. package/src/source/source_cache.js +794 -0
  208. package/src/source/source_state.js +55 -0
  209. package/src/source/tile.js +332 -0
  210. package/src/source/tile_bounds.js +40 -0
  211. package/src/source/tile_cache.js +122 -0
  212. package/src/source/tile_id.js +150 -0
  213. package/src/source/vector_tile_source.js +144 -0
  214. package/src/source/vector_tile_worker_source.js +126 -0
  215. package/src/source/worker.js +175 -0
  216. package/src/source/worker_source.js +14 -0
  217. package/src/source/worker_tile.js +199 -0
  218. package/src/style/create_style_layer.js +25 -0
  219. package/src/style/evaluation_parameters.js +45 -0
  220. package/src/style/light.js +112 -0
  221. package/src/style/load_glyph_range.js +17 -0
  222. package/src/style/load_sprite.js +26 -0
  223. package/src/style/parse_glyph_pbf.js +45 -0
  224. package/src/style/pauseable_placement.js +88 -0
  225. package/src/style/properties.js +691 -0
  226. package/src/style/query_utils.js +39 -0
  227. package/src/style/style.js +955 -0
  228. package/src/style/style_layer/background_style_layer.js +11 -0
  229. package/src/style/style_layer/background_style_layer_properties.js +25 -0
  230. package/src/style/style_layer/circle_style_layer.js +93 -0
  231. package/src/style/style_layer/circle_style_layer_properties.js +76 -0
  232. package/src/style/style_layer/fill_extrusion_style_layer.js +194 -0
  233. package/src/style/style_layer/fill_extrusion_style_layer_properties.js +56 -0
  234. package/src/style/style_layer/fill_style_layer.js +46 -0
  235. package/src/style/style_layer/fill_style_layer_properties.js +45 -0
  236. package/src/style/style_layer/heatmap_style_layer.js +51 -0
  237. package/src/style/style_layer/heatmap_style_layer_properties.js +52 -0
  238. package/src/style/style_layer/hillshade_style_layer.js +15 -0
  239. package/src/style/style_layer/hillshade_style_layer_properties.js +43 -0
  240. package/src/style/style_layer/line_style_layer.js +129 -0
  241. package/src/style/style_layer/line_style_layer_properties.js +104 -0
  242. package/src/style/style_layer/raster_style_layer.js +11 -0
  243. package/src/style/style_layer/raster_style_layer_properties.js +55 -0
  244. package/src/style/style_layer/symbol_style_layer.js +66 -0
  245. package/src/style/style_layer/symbol_style_layer_properties.js +288 -0
  246. package/src/style/style_layer.js +183 -0
  247. package/src/style/style_layer_index.js +61 -0
  248. package/src/style/zoom_history.js +36 -0
  249. package/src/style-spec/deref.js +51 -0
  250. package/src/style-spec/error/parsing_error.js +8 -0
  251. package/src/style-spec/error/validation_error.js +10 -0
  252. package/src/style-spec/expression/compound_expression.js +118 -0
  253. package/src/style-spec/expression/definitions/array.js +82 -0
  254. package/src/style-spec/expression/definitions/assertion.js +69 -0
  255. package/src/style-spec/expression/definitions/at.js +57 -0
  256. package/src/style-spec/expression/definitions/case.js +73 -0
  257. package/src/style-spec/expression/definitions/coalesce.js +68 -0
  258. package/src/style-spec/expression/definitions/coercion.js +96 -0
  259. package/src/style-spec/expression/definitions/collator.js +102 -0
  260. package/src/style-spec/expression/definitions/equals.js +93 -0
  261. package/src/style-spec/expression/definitions/index.js +407 -0
  262. package/src/style-spec/expression/definitions/interpolate.js +235 -0
  263. package/src/style-spec/expression/definitions/length.js +54 -0
  264. package/src/style-spec/expression/definitions/let.js +60 -0
  265. package/src/style-spec/expression/definitions/literal.js +64 -0
  266. package/src/style-spec/expression/definitions/match.js +142 -0
  267. package/src/style-spec/expression/definitions/step.js +116 -0
  268. package/src/style-spec/expression/definitions/var.js +38 -0
  269. package/src/style-spec/expression/evaluation_context.js +35 -0
  270. package/src/style-spec/expression/index.js +329 -0
  271. package/src/style-spec/expression/is_constant.js +63 -0
  272. package/src/style-spec/expression/parsing_context.js +213 -0
  273. package/src/style-spec/expression/parsing_error.js +9 -0
  274. package/src/style-spec/expression/runtime_error.js +12 -0
  275. package/src/style-spec/expression/scope.js +34 -0
  276. package/src/style-spec/expression/stops.js +37 -0
  277. package/src/style-spec/expression/types.js +77 -0
  278. package/src/style-spec/expression/values.js +126 -0
  279. package/src/style-spec/feature_filter/README.md +55 -0
  280. package/src/style-spec/feature_filter/index.js +158 -0
  281. package/src/style-spec/function/convert.js +256 -0
  282. package/src/style-spec/function/index.js +299 -0
  283. package/src/style-spec/group_by_layout.js +68 -0
  284. package/src/style-spec/reference/v8.json +5356 -0
  285. package/src/style-spec/util/color.js +73 -0
  286. package/src/style-spec/util/color_spaces.js +128 -0
  287. package/src/style-spec/util/eval_support.js +8 -0
  288. package/src/style-spec/util/get_type.js +18 -0
  289. package/src/style-spec/util/interpolate.js +21 -0
  290. package/src/style-spec/util/properties.js +17 -0
  291. package/src/style-spec/util/ref_properties.js +1 -0
  292. package/src/style-spec/util/result.js +19 -0
  293. package/src/symbol/anchor.js +21 -0
  294. package/src/symbol/check_max_angle.js +75 -0
  295. package/src/symbol/clip_line.js +73 -0
  296. package/src/symbol/collision_feature.js +230 -0
  297. package/src/symbol/collision_index.js +379 -0
  298. package/src/symbol/cross_tile_symbol_index.js +270 -0
  299. package/src/symbol/get_anchors.js +177 -0
  300. package/src/symbol/grid_index.js +318 -0
  301. package/src/symbol/mergelines.js +75 -0
  302. package/src/symbol/opacity_state.js +21 -0
  303. package/src/symbol/placement.js +563 -0
  304. package/src/symbol/projection.js +601 -0
  305. package/src/symbol/quads.js +173 -0
  306. package/src/symbol/shaping.js +347 -0
  307. package/src/symbol/symbol_layout.js +519 -0
  308. package/src/symbol/symbol_size.js +110 -0
  309. package/src/symbol/transform_text.js +16 -0
  310. package/src/ui/anchor.js +24 -0
  311. package/src/ui/bind_handlers.js +199 -0
  312. package/src/ui/camera.js +954 -0
  313. package/src/ui/events.js +210 -0
  314. package/src/ui/handler/box_zoom.js +151 -0
  315. package/src/ui/handler/dblclick_zoom.js +91 -0
  316. package/src/ui/handler/drag_pan.js +285 -0
  317. package/src/ui/handler/drag_rotate.js +290 -0
  318. package/src/ui/handler/frame.js +28 -0
  319. package/src/ui/handler/inertia.js +45 -0
  320. package/src/ui/handler/keyboard.js +148 -0
  321. package/src/ui/handler/scroll_zoom.js +284 -0
  322. package/src/ui/handler/touch_zoom_rotate.js +263 -0
  323. package/src/ui/map.js +1645 -0
  324. package/src/util/actor.js +104 -0
  325. package/src/util/async.js +23 -0
  326. package/src/util/browser.js +61 -0
  327. package/src/util/callback.js +26 -0
  328. package/src/util/classify_rings.js +43 -0
  329. package/src/util/color_ramp.js +24 -0
  330. package/src/util/config.js +24 -0
  331. package/src/util/dictionary_coder.js +25 -0
  332. package/src/util/dispatcher.js +68 -0
  333. package/src/util/dom.js +102 -0
  334. package/src/util/evented.js +182 -0
  335. package/src/util/find_pole_of_inaccessibility.js +129 -0
  336. package/src/util/global_worker_pool.js +15 -0
  337. package/src/util/image.js +124 -0
  338. package/src/util/interpolate.js +5 -0
  339. package/src/util/intersection_tests.js +207 -0
  340. package/src/util/is_char_in_unicode_block.js +287 -0
  341. package/src/util/loader/image.js +32 -0
  342. package/src/util/object.js +178 -0
  343. package/src/util/script_detection.js +337 -0
  344. package/src/util/struct_array.js +197 -0
  345. package/src/util/task_queue.js +57 -0
  346. package/src/util/throttle.js +26 -0
  347. package/src/util/tile_cover.js +114 -0
  348. package/src/util/token.js +13 -0
  349. package/src/util/unique_id.js +12 -0
  350. package/src/util/util.js +192 -0
  351. package/src/util/vectortile_to_geojson.js +44 -0
  352. package/src/util/verticalize_punctuation.js +112 -0
  353. package/src/util/warn.js +21 -0
  354. package/src/util/web_worker.js +5 -0
  355. package/src/util/web_worker_transfer.js +228 -0
  356. package/src/util/worker_pool.js +41 -0
@@ -0,0 +1,213 @@
1
+ const { getCoordinatesCenter } = require('../util/util');
2
+
3
+ const { CanonicalTileID } = require('./tile_id');
4
+ const LngLat = require('../geo/lng_lat');
5
+ const Point = require('@mapbox/point-geometry');
6
+ const { Event, ErrorEvent, Evented } = require('../util/evented');
7
+ const loadImage = require('../util/loader/image');
8
+ const EXTENT = require('../data/extent');
9
+ const { RasterBoundsArray } = require('../data/array_types');
10
+ const rasterBoundsAttributes = require('../data/raster_bounds_attributes');
11
+ const SegmentVector = require('../data/segment');
12
+ const Texture = require('../render/texture');
13
+
14
+ /**
15
+ * A data source containing an image.
16
+ * (See the [Style Specification](https://www.mapbox.com/mapbox-gl-style-spec/#sources-image) for detailed documentation of options.)
17
+ *
18
+ * @example
19
+ * // add to map
20
+ * map.addSource('some id', {
21
+ * type: 'image',
22
+ * url: 'https://www.mapbox.com/images/foo.png',
23
+ * coordinates: [
24
+ * [-76.54, 39.18],
25
+ * [-76.52, 39.18],
26
+ * [-76.52, 39.17],
27
+ * [-76.54, 39.17]
28
+ * ]
29
+ * });
30
+ *
31
+ * // update
32
+ * var mySource = map.getSource('some id');
33
+ * mySource.setCoordinates([
34
+ * [-76.54335737228394, 39.18579907229748],
35
+ * [-76.52803659439087, 39.1838364847587],
36
+ * [-76.5295386314392, 39.17683392507606],
37
+ * [-76.54520273208618, 39.17876344106642]
38
+ * ]);
39
+ *
40
+ * map.removeSource('some id'); // remove
41
+ * @see [Add an image](https://www.mapbox.com/mapbox-gl-js/example/image-on-a-map/)
42
+ */
43
+ class ImageSource extends Evented {
44
+ /**
45
+ * @private
46
+ */
47
+ constructor(id, options, dispatcher, eventedParent) {
48
+ super();
49
+ this.id = id;
50
+ this.dispatcher = dispatcher;
51
+ this.coordinates = options.coordinates;
52
+
53
+ this.type = 'image';
54
+ this.minzoom = 0;
55
+ this.maxzoom = 22;
56
+ this.tileSize = 512;
57
+ this.tiles = {};
58
+
59
+ this.setEventedParent(eventedParent);
60
+
61
+ this.options = options;
62
+ }
63
+
64
+ load() {
65
+ this.fire(new Event('dataloading', { dataType: 'source' }));
66
+
67
+ this.url = this.options.url;
68
+
69
+ loadImage(this.url, (err, image) => {
70
+ if (err) {
71
+ this.fire(new ErrorEvent(err));
72
+ } else if (image) {
73
+ this.image = image;
74
+ this._finishLoading();
75
+ }
76
+ });
77
+ }
78
+
79
+ _finishLoading() {
80
+ if (this.map) {
81
+ this.setCoordinates(this.coordinates);
82
+ this.fire(new Event('data', { dataType: 'source', sourceDataType: 'metadata' }));
83
+ }
84
+ }
85
+
86
+ onAdd(map) {
87
+ this.map = map;
88
+ this.load();
89
+ }
90
+
91
+ /**
92
+ * Sets the image's coordinates and re-renders the map.
93
+ *
94
+ * @param {Array<Array<number>>} coordinates Four geographical coordinates,
95
+ * represented as arrays of longitude and latitude numbers, which define the corners of the image.
96
+ * The coordinates start at the top left corner of the image and proceed in clockwise order.
97
+ * They do not have to represent a rectangle.
98
+ * @returns {ImageSource} this
99
+ */
100
+ setCoordinates(coordinates) {
101
+ this.coordinates = coordinates;
102
+
103
+ // Calculate which mercator tile is suitable for rendering the video in
104
+ // and create a buffer with the corner coordinates. These coordinates
105
+ // may be outside the tile, because raster tiles aren't clipped when rendering.
106
+
107
+ const map = this.map;
108
+
109
+ // transform the geo coordinates into (zoom 0) tile space coordinates
110
+ const cornerZ0Coords = coordinates.map(coord => {
111
+ return map.transform.locationCoordinate(LngLat.convert(coord)).zoomTo(0);
112
+ });
113
+
114
+ // Compute the coordinates of the tile we'll use to hold this image's
115
+ // render data
116
+ const centerCoord = (this.centerCoord = getCoordinatesCenter(cornerZ0Coords));
117
+ // `column` and `row` may be fractional; round them down so that they
118
+ // represent integer tile coordinates
119
+ centerCoord.column = Math.floor(centerCoord.column);
120
+ centerCoord.row = Math.floor(centerCoord.row);
121
+ this.tileID = new CanonicalTileID(centerCoord.zoom, centerCoord.column, centerCoord.row);
122
+
123
+ // Constrain min/max zoom to our tile's zoom level in order to force
124
+ // SourceCache to request this tile (no matter what the map's zoom
125
+ // level)
126
+ this.minzoom = this.maxzoom = centerCoord.zoom;
127
+
128
+ // Transform the corner coordinates into the coordinate space of our
129
+ // tile.
130
+ const tileCoords = cornerZ0Coords.map(coord => {
131
+ const zoomedCoord = coord.zoomTo(centerCoord.zoom);
132
+ return new Point(
133
+ Math.round((zoomedCoord.column - centerCoord.column) * EXTENT),
134
+ Math.round((zoomedCoord.row - centerCoord.row) * EXTENT)
135
+ );
136
+ });
137
+
138
+ this._boundsArray = new RasterBoundsArray();
139
+ this._boundsArray.emplaceBack(tileCoords[0].x, tileCoords[0].y, 0, 0);
140
+ this._boundsArray.emplaceBack(tileCoords[1].x, tileCoords[1].y, EXTENT, 0);
141
+ this._boundsArray.emplaceBack(tileCoords[3].x, tileCoords[3].y, 0, EXTENT);
142
+ this._boundsArray.emplaceBack(tileCoords[2].x, tileCoords[2].y, EXTENT, EXTENT);
143
+
144
+ if (this.boundsBuffer) {
145
+ this.boundsBuffer.destroy();
146
+ delete this.boundsBuffer;
147
+ }
148
+
149
+ this.fire(new Event('data', { dataType: 'source', sourceDataType: 'content' }));
150
+ return this;
151
+ }
152
+
153
+ prepare() {
154
+ if (Object.keys(this.tiles).length === 0 || !this.image) {
155
+ return;
156
+ }
157
+
158
+ const context = this.map.painter.context;
159
+ const gl = context.gl;
160
+
161
+ if (!this.boundsBuffer) {
162
+ this.boundsBuffer = context.createVertexBuffer(this._boundsArray, rasterBoundsAttributes.members);
163
+ }
164
+
165
+ if (!this.boundsSegments) {
166
+ this.boundsSegments = SegmentVector.simpleSegment(0, 0, 4, 2);
167
+ }
168
+
169
+ if (!this.texture) {
170
+ this.texture = new Texture(context, this.image, gl.RGBA);
171
+ this.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);
172
+ }
173
+
174
+ for (const w in this.tiles) {
175
+ const tile = this.tiles[w];
176
+ if (tile.state !== 'loaded') {
177
+ tile.state = 'loaded';
178
+ tile.texture = this.texture;
179
+ }
180
+ }
181
+ }
182
+
183
+ loadTile(tile, callback) {
184
+ // We have a single tile -- whoose coordinates are this.tileID -- that
185
+ // covers the image we want to render. If that's the one being
186
+ // requested, set it up with the image; otherwise, mark the tile as
187
+ // `errored` to indicate that we have no data for it.
188
+ // If the world wraps, we may have multiple "wrapped" copies of the
189
+ // single tile.
190
+ if (this.tileID?.equals(tile.tileID.canonical)) {
191
+ this.tiles[String(tile.tileID.wrap)] = tile;
192
+ tile.buckets = {};
193
+ callback(null);
194
+ } else {
195
+ tile.state = 'errored';
196
+ callback(null);
197
+ }
198
+ }
199
+
200
+ serialize() {
201
+ return {
202
+ type: 'image',
203
+ url: this.options.url,
204
+ coordinates: this.coordinates
205
+ };
206
+ }
207
+
208
+ hasTransition() {
209
+ return false;
210
+ }
211
+ }
212
+
213
+ module.exports = ImageSource;
@@ -0,0 +1,40 @@
1
+ const { pick } = require('../util/object');
2
+ const browser = require('../util/browser');
3
+
4
+ module.exports = function (options, callback) {
5
+ function loaded(err, tileJSON) {
6
+ if (err) return callback(err);
7
+ if (tileJSON) {
8
+ const { resourceSets } = tileJSON;
9
+ if (resourceSets) {
10
+ if (!resourceSets.length) {
11
+ return callback('expected resources');
12
+ }
13
+ const { resources } = resourceSets[0];
14
+ if (!resources?.length) {
15
+ return callback('expected resources');
16
+ }
17
+ const { imageUrl, imageUrlSubdomains } = resources[0];
18
+ const result = Object.assign(
19
+ {
20
+ tiles: imageUrlSubdomains.map(sub => imageUrl.replace('{subdomain}', sub).replace('http:', 'https:'))
21
+ },
22
+ options
23
+ );
24
+ delete result.url;
25
+ return callback(null, result);
26
+ }
27
+ const result = pick(tileJSON, ['tiles', 'minzoom', 'maxzoom', 'attribution', 'mapbox_logo', 'bounds']);
28
+
29
+ if (tileJSON.vector_layers) {
30
+ result.vectorLayers = tileJSON.vector_layers;
31
+ result.vectorLayerIds = result.vectorLayers.map(layer => layer.id);
32
+ }
33
+
34
+ callback(null, result);
35
+ }
36
+ }
37
+
38
+ // expects already loaded object, `url` property is ignored
39
+ browser.frame(() => loaded(null, options));
40
+ };
@@ -0,0 +1,17 @@
1
+ const EXTENT = require('../data/extent');
2
+
3
+ /**
4
+ * Converts a pixel value at a the given zoom level to tile units.
5
+ *
6
+ * The shaders mostly calculate everything in tile units so style
7
+ * properties need to be converted from pixels to tile units using this.
8
+ *
9
+ * For example, a translation by 30 pixels at zoom 6.5 will be a
10
+ * translation by pixelsToTileUnits(30, 6.5) tile units.
11
+ *
12
+ * @returns value in tile units
13
+ * @private
14
+ */
15
+ module.exports = function (tile, pixelValue, z) {
16
+ return pixelValue * (EXTENT / (tile.tileSize * 2 ** (z - tile.tileID.overscaledZ)));
17
+ };
@@ -0,0 +1,198 @@
1
+ const assert = require('assert');
2
+ const { mat4 } = require('@mapbox/gl-matrix');
3
+
4
+ module.exports = {
5
+ queryRenderedFeatures,
6
+ queryRenderedSymbols,
7
+ querySourceFeatures
8
+ };
9
+
10
+ /*
11
+ * Returns a matrix that can be used to convert from tile coordinates to viewport pixel coordinates.
12
+ */
13
+ function getPixelPosMatrix(transform, tileID) {
14
+ const t = mat4.identity([]);
15
+ mat4.translate(t, t, [1, 1, 0]);
16
+ mat4.scale(t, t, [transform.width * 0.5, transform.height * 0.5, 1]);
17
+ return mat4.multiply(t, t, transform.calculatePosMatrix(tileID.toUnwrapped()));
18
+ }
19
+
20
+ function queryIncludes3DLayer(layers, styleLayers, sourceID) {
21
+ if (layers) {
22
+ for (const layerID of layers) {
23
+ const layer = styleLayers[layerID];
24
+ if (layer && layer.source === sourceID && layer.type === 'fill-extrusion') {
25
+ return true;
26
+ }
27
+ }
28
+ } else {
29
+ for (const key in styleLayers) {
30
+ const layer = styleLayers[key];
31
+ if (layer.source === sourceID && layer.type === 'fill-extrusion') {
32
+ return true;
33
+ }
34
+ }
35
+ }
36
+ return false;
37
+ }
38
+
39
+ function queryRenderedFeatures(sourceCache, styleLayers, queryGeometry, params, transform) {
40
+ const has3DLayer = queryIncludes3DLayer(params?.layers, styleLayers, sourceCache.id);
41
+ const maxPitchScaleFactor = transform.maxPitchScaleFactor();
42
+ const tilesIn = sourceCache.tilesIn(queryGeometry, maxPitchScaleFactor, has3DLayer);
43
+
44
+ tilesIn.sort(sortTilesIn);
45
+
46
+ const renderedFeatureLayers = [];
47
+ for (const tileIn of tilesIn) {
48
+ renderedFeatureLayers.push({
49
+ wrappedTileID: tileIn.tileID.wrapped().key,
50
+ queryResults: tileIn.tile.queryRenderedFeatures(
51
+ styleLayers,
52
+ sourceCache._state,
53
+ tileIn.queryGeometry,
54
+ tileIn.cameraQueryGeometry,
55
+ tileIn.scale,
56
+ params,
57
+ transform,
58
+ maxPitchScaleFactor,
59
+ getPixelPosMatrix(sourceCache.transform, tileIn.tileID)
60
+ )
61
+ });
62
+ }
63
+
64
+ const result = mergeRenderedFeatureLayers(renderedFeatureLayers);
65
+
66
+ // Merge state from SourceCache into the results
67
+ for (const layerID in result) {
68
+ result[layerID].forEach(featureWrapper => {
69
+ const feature = featureWrapper.feature;
70
+ const state = sourceCache.getFeatureState(feature.layer['source-layer'], feature.id);
71
+ feature.source = feature.layer.source;
72
+ if (feature.layer['source-layer']) {
73
+ feature.sourceLayer = feature.layer['source-layer'];
74
+ }
75
+ feature.state = state;
76
+ });
77
+ }
78
+ return result;
79
+ }
80
+
81
+ function queryRenderedSymbols(styleLayers, sourceCaches, queryGeometry, params, collisionIndex, retainedQueryData) {
82
+ const result = {};
83
+ const renderedSymbols = collisionIndex.queryRenderedSymbols(queryGeometry);
84
+ const bucketQueryData = [];
85
+ for (const bucketInstanceId of Object.keys(renderedSymbols).map(Number)) {
86
+ bucketQueryData.push(retainedQueryData[bucketInstanceId]);
87
+ }
88
+ bucketQueryData.sort(sortTilesIn);
89
+
90
+ for (const queryData of bucketQueryData) {
91
+ const bucketSymbols = queryData.featureIndex.lookupSymbolFeatures(
92
+ renderedSymbols[queryData.bucketInstanceId],
93
+ queryData.bucketIndex,
94
+ queryData.sourceLayerIndex,
95
+ params.filter,
96
+ params.layers,
97
+ styleLayers
98
+ );
99
+
100
+ for (const layerID in bucketSymbols) {
101
+ const resultFeatures = (result[layerID] = result[layerID] || []);
102
+ const layerSymbols = bucketSymbols[layerID];
103
+ layerSymbols.sort((a, b) => {
104
+ // Match topDownFeatureComparator from FeatureIndex, but using
105
+ // most recent sorting of features from bucket.sortFeatures
106
+ const featureSortOrder = queryData.featureSortOrder;
107
+ if (featureSortOrder) {
108
+ // queryRenderedSymbols documentation says we'll return features in
109
+ // "top-to-bottom" rendering order (aka last-to-first).
110
+ // Actually there can be multiple symbol instances per feature, so
111
+ // we sort each feature based on the first matching symbol instance.
112
+ const sortedA = featureSortOrder.indexOf(a.featureIndex);
113
+ const sortedB = featureSortOrder.indexOf(b.featureIndex);
114
+ assert(sortedA >= 0);
115
+ assert(sortedB >= 0);
116
+ return sortedB - sortedA;
117
+ }
118
+ // Bucket hasn't been re-sorted based on angle, so use the
119
+ // reverse of the order the features appeared in the data.
120
+ return b.featureIndex - a.featureIndex;
121
+ });
122
+ for (const symbolFeature of layerSymbols) {
123
+ resultFeatures.push(symbolFeature);
124
+ }
125
+ }
126
+ }
127
+
128
+ // Merge state from SourceCache into the results
129
+ for (const layerName in result) {
130
+ result[layerName].forEach(featureWrapper => {
131
+ const feature = featureWrapper.feature;
132
+ const layer = styleLayers[layerName];
133
+ const sourceCache = sourceCaches[layer.source];
134
+ const state = sourceCache.getFeatureState(feature.layer['source-layer'], feature.id);
135
+ feature.source = feature.layer.source;
136
+ if (feature.layer['source-layer']) {
137
+ feature.sourceLayer = feature.layer['source-layer'];
138
+ }
139
+ feature.state = state;
140
+ });
141
+ }
142
+ return result;
143
+ }
144
+
145
+ function querySourceFeatures(sourceCache, params) {
146
+ const tiles = sourceCache.getRenderableIds().map(id => {
147
+ return sourceCache.getTileByID(id);
148
+ });
149
+
150
+ const result = [];
151
+
152
+ const dataTiles = {};
153
+ for (let i = 0; i < tiles.length; i++) {
154
+ const tile = tiles[i];
155
+ const dataID = tile.tileID.canonical.key;
156
+ if (!dataTiles[dataID]) {
157
+ dataTiles[dataID] = true;
158
+ tile.querySourceFeatures(result, params);
159
+ }
160
+ }
161
+
162
+ return result;
163
+ }
164
+
165
+ function sortTilesIn(a, b) {
166
+ const idA = a.tileID;
167
+ const idB = b.tileID;
168
+ return (
169
+ idA.overscaledZ - idB.overscaledZ ||
170
+ idA.canonical.y - idB.canonical.y ||
171
+ idA.wrap - idB.wrap ||
172
+ idA.canonical.x - idB.canonical.x
173
+ );
174
+ }
175
+
176
+ function mergeRenderedFeatureLayers(tiles) {
177
+ // Merge results from all tiles, but if two tiles share the same
178
+ // wrapped ID, don't duplicate features between the two tiles
179
+ const result = {};
180
+ const wrappedIDLayerMap = {};
181
+ for (const tile of tiles) {
182
+ const queryResults = tile.queryResults;
183
+ const wrappedID = tile.wrappedTileID;
184
+ const wrappedIDLayers = (wrappedIDLayerMap[wrappedID] = wrappedIDLayerMap[wrappedID] || {});
185
+ for (const layerID in queryResults) {
186
+ const tileFeatures = queryResults[layerID];
187
+ const wrappedIDFeatures = (wrappedIDLayers[layerID] = wrappedIDLayers[layerID] || {});
188
+ const resultFeatures = (result[layerID] = result[layerID] || []);
189
+ for (const tileFeature of tileFeatures) {
190
+ if (!wrappedIDFeatures[tileFeature.featureIndex]) {
191
+ wrappedIDFeatures[tileFeature.featureIndex] = true;
192
+ resultFeatures.push(tileFeature);
193
+ }
194
+ }
195
+ }
196
+ }
197
+ return result;
198
+ }
@@ -0,0 +1,140 @@
1
+ const browser = require('../util/browser');
2
+ const loadImage = require('../util/loader/image');
3
+ const { OverscaledTileID } = require('./tile_id');
4
+ const RasterTileSource = require('./raster_tile_source');
5
+ // ensure DEMData is registered for worker transfer on main thread:
6
+ require('../data/dem_data');
7
+
8
+ class RasterDEMTileSource extends RasterTileSource {
9
+ constructor(id, options, dispatcher, eventedParent) {
10
+ super(id, options, dispatcher, eventedParent);
11
+ this.type = 'raster-dem';
12
+ this.maxzoom = 22;
13
+ this._options = Object.assign({}, options);
14
+ this.encoding = options.encoding || 'mapbox';
15
+ }
16
+
17
+ serialize() {
18
+ return {
19
+ type: 'raster-dem',
20
+ url: this.url,
21
+ tileSize: this.tileSize,
22
+ tiles: this.tiles,
23
+ bounds: this.bounds,
24
+ encoding: this.encoding
25
+ };
26
+ }
27
+
28
+ loadTile(tile, callback) {
29
+ const done = (err, dem) => {
30
+ if (err) {
31
+ tile.state = 'errored';
32
+ callback(err);
33
+ }
34
+
35
+ if (dem) {
36
+ tile.dem = dem;
37
+ tile.needsHillshadePrepare = true;
38
+ tile.state = 'loaded';
39
+ callback(null);
40
+ }
41
+ };
42
+ const imageLoaded = (err, img) => {
43
+ delete tile.request;
44
+ if (tile.aborted) {
45
+ tile.state = 'unloaded';
46
+ callback(null);
47
+ } else if (err) {
48
+ tile.state = 'errored';
49
+ callback(err);
50
+ } else if (img) {
51
+ const rawImageData = browser.getImageData(img);
52
+ const params = {
53
+ uid: tile.uid,
54
+ coord: tile.tileID,
55
+ source: this.id,
56
+ rawImageData: rawImageData,
57
+ encoding: this.encoding
58
+ };
59
+
60
+ if (!tile.workerID || tile.state === 'expired') {
61
+ tile.workerID = this.dispatcher.send('loadDEMTile', params, done);
62
+ }
63
+ }
64
+ };
65
+
66
+ tile.abortController = new window.AbortController();
67
+ this.tiles(tile.tileID.canonical, tile.abortController)
68
+ .catch(() => {})
69
+ .then(data => {
70
+ tile.neighboringTiles = this._getNeighboringTiles(tile.tileID);
71
+ if (!data) {
72
+ const err = new Error('Tile could not be loaded');
73
+ err.status = 404; // will try to use the parent/child tile
74
+ return done(err);
75
+ }
76
+ tile.request = loadImage(data, imageLoaded);
77
+ });
78
+ }
79
+
80
+ _getNeighboringTiles(tileID) {
81
+ const canonical = tileID.canonical;
82
+ const dim = 2 ** canonical.z;
83
+
84
+ const px = (canonical.x - 1 + dim) % dim;
85
+ const pxw = canonical.x === 0 ? tileID.wrap - 1 : tileID.wrap;
86
+ const nx = (canonical.x + 1 + dim) % dim;
87
+ const nxw = canonical.x + 1 === dim ? tileID.wrap + 1 : tileID.wrap;
88
+
89
+ const neighboringTiles = {};
90
+ // add adjacent tiles
91
+ neighboringTiles[new OverscaledTileID(tileID.overscaledZ, pxw, canonical.z, px, canonical.y).key] = {
92
+ backfilled: false
93
+ };
94
+ neighboringTiles[new OverscaledTileID(tileID.overscaledZ, nxw, canonical.z, nx, canonical.y).key] = {
95
+ backfilled: false
96
+ };
97
+
98
+ // Add upper neighboringTiles
99
+ if (canonical.y > 0) {
100
+ neighboringTiles[new OverscaledTileID(tileID.overscaledZ, pxw, canonical.z, px, canonical.y - 1).key] = {
101
+ backfilled: false
102
+ };
103
+ neighboringTiles[
104
+ new OverscaledTileID(tileID.overscaledZ, tileID.wrap, canonical.z, canonical.x, canonical.y - 1).key
105
+ ] = { backfilled: false };
106
+ neighboringTiles[new OverscaledTileID(tileID.overscaledZ, nxw, canonical.z, nx, canonical.y - 1).key] = {
107
+ backfilled: false
108
+ };
109
+ }
110
+ // Add lower neighboringTiles
111
+ if (canonical.y + 1 < dim) {
112
+ neighboringTiles[new OverscaledTileID(tileID.overscaledZ, pxw, canonical.z, px, canonical.y + 1).key] = {
113
+ backfilled: false
114
+ };
115
+ neighboringTiles[
116
+ new OverscaledTileID(tileID.overscaledZ, tileID.wrap, canonical.z, canonical.x, canonical.y + 1).key
117
+ ] = { backfilled: false };
118
+ neighboringTiles[new OverscaledTileID(tileID.overscaledZ, nxw, canonical.z, nx, canonical.y + 1).key] = {
119
+ backfilled: false
120
+ };
121
+ }
122
+
123
+ return neighboringTiles;
124
+ }
125
+
126
+ unloadTile(tile) {
127
+ if (tile.demTexture) this.map.painter.saveTileTexture(tile.demTexture);
128
+ if (tile.fbo) {
129
+ tile.fbo.destroy();
130
+ delete tile.fbo;
131
+ }
132
+ if (tile.dem) delete tile.dem;
133
+ delete tile.neighboringTiles;
134
+
135
+ tile.state = 'unloaded';
136
+ this.dispatcher.send('removeDEMTile', { uid: tile.uid, source: this.id }, undefined, tile.workerID);
137
+ }
138
+ }
139
+
140
+ module.exports = RasterDEMTileSource;
@@ -0,0 +1,26 @@
1
+ const DEMData = require('../data/dem_data');
2
+
3
+ class RasterDEMTileWorkerSource {
4
+ constructor() {
5
+ this.loaded = {};
6
+ }
7
+
8
+ loadTile(params, callback) {
9
+ const { uid, encoding, rawImageData } = params;
10
+ const dem = new DEMData(uid, rawImageData, encoding);
11
+
12
+ this.loaded = this.loaded || {};
13
+ this.loaded[uid] = dem;
14
+ callback(null, dem);
15
+ }
16
+
17
+ removeTile(params) {
18
+ const loaded = this.loaded;
19
+ const uid = params.uid;
20
+ if (loaded?.[uid]) {
21
+ delete loaded[uid];
22
+ }
23
+ }
24
+ }
25
+
26
+ module.exports = RasterDEMTileWorkerSource;