mapbox-gl 1.13.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.flowconfig +61 -0
- package/CHANGELOG.md +2485 -0
- package/LICENSE.txt +84 -0
- package/README.md +34 -0
- package/build/banner.js +4 -0
- package/build/check-bundle-size.js +140 -0
- package/build/diff-tarball.js +18 -0
- package/build/generate-access-token-script.js +11 -0
- package/build/generate-flow-typed-style-spec.js +188 -0
- package/build/generate-release-list.js +21 -0
- package/build/generate-struct-arrays.js +243 -0
- package/build/generate-style-code.js +159 -0
- package/build/mapbox-gl.js.flow +3 -0
- package/build/print-release-url.js +6 -0
- package/build/rollup_plugin_minify_style_spec.js +24 -0
- package/build/rollup_plugins.js +80 -0
- package/build/run-node +3 -0
- package/build/run-tap +8 -0
- package/build/test/build-tape.js +19 -0
- package/dist/mapbox-gl-csp-worker.js +2 -0
- package/dist/mapbox-gl-csp-worker.js.map +1 -0
- package/dist/mapbox-gl-csp.js +2 -0
- package/dist/mapbox-gl-csp.js.map +1 -0
- package/dist/mapbox-gl-dev.js +65889 -0
- package/dist/mapbox-gl-dev.js.flow +3 -0
- package/dist/mapbox-gl-unminified.js +42889 -0
- package/dist/mapbox-gl-unminified.js.map +1 -0
- package/dist/mapbox-gl.css +1 -0
- package/dist/mapbox-gl.js +42 -0
- package/dist/mapbox-gl.js.flow +3 -0
- package/dist/mapbox-gl.js.map +1 -0
- package/dist/style-spec/index.es.js +15032 -0
- package/dist/style-spec/index.es.js.map +1 -0
- package/dist/style-spec/index.js +15058 -0
- package/dist/style-spec/index.js.map +1 -0
- package/flow-typed/gl.js +5 -0
- package/flow-typed/jsdom.js +18 -0
- package/flow-typed/mapbox-gl-supported.js +9 -0
- package/flow-typed/mapbox-unitbezier.js +14 -0
- package/flow-typed/offscreen-canvas.js +9 -0
- package/flow-typed/pbf.js +25 -0
- package/flow-typed/point-geometry.js +44 -0
- package/flow-typed/potpack.js +12 -0
- package/flow-typed/sinon.js +28 -0
- package/flow-typed/vector-tile.js +41 -0
- package/package.json +173 -0
- package/src/css/mapbox-gl.css +812 -0
- package/src/css/svg/mapboxgl-ctrl-attrib.svg +3 -0
- package/src/css/svg/mapboxgl-ctrl-compass.svg +4 -0
- package/src/css/svg/mapboxgl-ctrl-fullscreen.svg +3 -0
- package/src/css/svg/mapboxgl-ctrl-geolocate.svg +5 -0
- package/src/css/svg/mapboxgl-ctrl-logo.svg +20 -0
- package/src/css/svg/mapboxgl-ctrl-shrink.svg +3 -0
- package/src/css/svg/mapboxgl-ctrl-zoom-in.svg +3 -0
- package/src/css/svg/mapboxgl-ctrl-zoom-out.svg +3 -0
- package/src/data/array_types.js +1135 -0
- package/src/data/bucket/circle_attributes.js +9 -0
- package/src/data/bucket/circle_bucket.js +201 -0
- package/src/data/bucket/fill_attributes.js +9 -0
- package/src/data/bucket/fill_bucket.js +229 -0
- package/src/data/bucket/fill_extrusion_attributes.js +10 -0
- package/src/data/bucket/fill_extrusion_bucket.js +283 -0
- package/src/data/bucket/heatmap_bucket.js +17 -0
- package/src/data/bucket/line_attributes.js +10 -0
- package/src/data/bucket/line_attributes_ext.js +10 -0
- package/src/data/bucket/line_bucket.js +594 -0
- package/src/data/bucket/pattern_attributes.js +12 -0
- package/src/data/bucket/pattern_bucket_features.js +60 -0
- package/src/data/bucket/symbol_attributes.js +117 -0
- package/src/data/bucket/symbol_bucket.js +937 -0
- package/src/data/bucket.js +123 -0
- package/src/data/dem_data.js +125 -0
- package/src/data/evaluation_feature.js +25 -0
- package/src/data/extent.js +18 -0
- package/src/data/feature_index.js +322 -0
- package/src/data/feature_position_map.js +131 -0
- package/src/data/index_array_type.js +16 -0
- package/src/data/load_geometry.js +46 -0
- package/src/data/pos_attributes.js +6 -0
- package/src/data/program_configuration.js +708 -0
- package/src/data/raster_bounds_attributes.js +7 -0
- package/src/data/segment.js +76 -0
- package/src/geo/edge_insets.js +102 -0
- package/src/geo/lng_lat.js +168 -0
- package/src/geo/lng_lat_bounds.js +276 -0
- package/src/geo/mercator_coordinate.js +150 -0
- package/src/geo/transform.js +834 -0
- package/src/gl/color_mode.js +34 -0
- package/src/gl/context.js +302 -0
- package/src/gl/cull_face_mode.js +26 -0
- package/src/gl/depth_mode.js +29 -0
- package/src/gl/framebuffer.js +44 -0
- package/src/gl/index_buffer.js +55 -0
- package/src/gl/stencil_mode.js +30 -0
- package/src/gl/types.js +84 -0
- package/src/gl/value.js +520 -0
- package/src/gl/vertex_buffer.js +119 -0
- package/src/index.js +230 -0
- package/src/render/draw_background.js +57 -0
- package/src/render/draw_circle.js +113 -0
- package/src/render/draw_collision_debug.js +172 -0
- package/src/render/draw_custom.js +49 -0
- package/src/render/draw_debug.js +127 -0
- package/src/render/draw_fill.js +124 -0
- package/src/render/draw_fill_extrusion.js +95 -0
- package/src/render/draw_heatmap.js +133 -0
- package/src/render/draw_hillshade.js +107 -0
- package/src/render/draw_line.js +125 -0
- package/src/render/draw_raster.js +125 -0
- package/src/render/draw_symbol.js +392 -0
- package/src/render/glyph_atlas.js +71 -0
- package/src/render/glyph_manager.js +182 -0
- package/src/render/image_atlas.js +149 -0
- package/src/render/image_manager.js +306 -0
- package/src/render/line_atlas.js +210 -0
- package/src/render/painter.js +654 -0
- package/src/render/program/background_program.js +103 -0
- package/src/render/program/circle_program.js +69 -0
- package/src/render/program/clipping_mask_program.js +20 -0
- package/src/render/program/collision_program.js +76 -0
- package/src/render/program/debug_program.js +35 -0
- package/src/render/program/fill_extrusion_program.js +122 -0
- package/src/render/program/fill_program.js +126 -0
- package/src/render/program/heatmap_program.js +83 -0
- package/src/render/program/hillshade_program.js +119 -0
- package/src/render/program/line_program.js +211 -0
- package/src/render/program/pattern.js +102 -0
- package/src/render/program/program_uniforms.js +42 -0
- package/src/render/program/raster_program.js +92 -0
- package/src/render/program/symbol_program.js +224 -0
- package/src/render/program.js +188 -0
- package/src/render/texture.js +122 -0
- package/src/render/uniform_binding.js +147 -0
- package/src/render/vertex_array_object.js +163 -0
- package/src/shaders/README.md +42 -0
- package/src/shaders/_prelude.fragment.glsl +17 -0
- package/src/shaders/_prelude.vertex.glsl +73 -0
- package/src/shaders/background.fragment.glsl +10 -0
- package/src/shaders/background.vertex.glsl +7 -0
- package/src/shaders/background_pattern.fragment.glsl +28 -0
- package/src/shaders/background_pattern.vertex.glsl +20 -0
- package/src/shaders/circle.fragment.glsl +39 -0
- package/src/shaders/circle.vertex.glsl +64 -0
- package/src/shaders/clipping_mask.fragment.glsl +3 -0
- package/src/shaders/clipping_mask.vertex.glsl +7 -0
- package/src/shaders/collision_box.fragment.glsl +21 -0
- package/src/shaders/collision_box.vertex.glsl +27 -0
- package/src/shaders/collision_circle.fragment.glsl +17 -0
- package/src/shaders/collision_circle.vertex.glsl +59 -0
- package/src/shaders/debug.fragment.glsl +9 -0
- package/src/shaders/debug.vertex.glsl +12 -0
- package/src/shaders/encode_attribute.js +17 -0
- package/src/shaders/fill.fragment.glsl +13 -0
- package/src/shaders/fill.vertex.glsl +13 -0
- package/src/shaders/fill_extrusion.fragment.glsl +9 -0
- package/src/shaders/fill_extrusion.vertex.glsl +66 -0
- package/src/shaders/fill_extrusion_pattern.fragment.glsl +45 -0
- package/src/shaders/fill_extrusion_pattern.vertex.glsl +79 -0
- package/src/shaders/fill_outline.fragment.glsl +17 -0
- package/src/shaders/fill_outline.vertex.glsl +17 -0
- package/src/shaders/fill_outline_pattern.fragment.glsl +43 -0
- package/src/shaders/fill_outline_pattern.vertex.glsl +44 -0
- package/src/shaders/fill_pattern.fragment.glsl +36 -0
- package/src/shaders/fill_pattern.vertex.glsl +39 -0
- package/src/shaders/heatmap.fragment.glsl +22 -0
- package/src/shaders/heatmap.vertex.glsl +54 -0
- package/src/shaders/heatmap_texture.fragment.glsl +14 -0
- package/src/shaders/heatmap_texture.vertex.glsl +11 -0
- package/src/shaders/hillshade.fragment.glsl +52 -0
- package/src/shaders/hillshade.vertex.glsl +11 -0
- package/src/shaders/hillshade_prepare.fragment.glsl +75 -0
- package/src/shaders/hillshade_prepare.vertex.glsl +15 -0
- package/src/shaders/index.js +20 -0
- package/src/shaders/line.fragment.glsl +30 -0
- package/src/shaders/line.vertex.glsl +85 -0
- package/src/shaders/line_gradient.fragment.glsl +34 -0
- package/src/shaders/line_gradient.vertex.glsl +88 -0
- package/src/shaders/line_pattern.fragment.glsl +74 -0
- package/src/shaders/line_pattern.vertex.glsl +99 -0
- package/src/shaders/line_sdf.fragment.glsl +45 -0
- package/src/shaders/line_sdf.vertex.glsl +98 -0
- package/src/shaders/raster.fragment.glsl +52 -0
- package/src/shaders/raster.vertex.glsl +21 -0
- package/src/shaders/shaders.js +185 -0
- package/src/shaders/symbol_icon.fragment.glsl +17 -0
- package/src/shaders/symbol_icon.vertex.glsl +94 -0
- package/src/shaders/symbol_sdf.fragment.glsl +52 -0
- package/src/shaders/symbol_sdf.vertex.glsl +115 -0
- package/src/shaders/symbol_text_and_icon.fragment.glsl +68 -0
- package/src/shaders/symbol_text_and_icon.vertex.glsl +116 -0
- package/src/source/canvas_source.js +238 -0
- package/src/source/geojson_source.js +370 -0
- package/src/source/geojson_worker_source.js +366 -0
- package/src/source/geojson_wrapper.js +94 -0
- package/src/source/image_source.js +307 -0
- package/src/source/load_tilejson.js +39 -0
- package/src/source/pixels_to_tile_units.js +21 -0
- package/src/source/query_features.js +208 -0
- package/src/source/raster_dem_tile_source.js +138 -0
- package/src/source/raster_dem_tile_worker_source.js +62 -0
- package/src/source/raster_tile_source.js +169 -0
- package/src/source/rtl_text_plugin.js +143 -0
- package/src/source/source.js +137 -0
- package/src/source/source_cache.js +953 -0
- package/src/source/source_state.js +159 -0
- package/src/source/tile.js +458 -0
- package/src/source/tile_bounds.js +38 -0
- package/src/source/tile_cache.js +212 -0
- package/src/source/tile_id.js +199 -0
- package/src/source/vector_tile_source.js +259 -0
- package/src/source/vector_tile_worker_source.js +216 -0
- package/src/source/video_source.js +203 -0
- package/src/source/worker.js +240 -0
- package/src/source/worker_source.js +107 -0
- package/src/source/worker_tile.js +224 -0
- package/src/style/create_style_layer.js +36 -0
- package/src/style/evaluation_parameters.js +62 -0
- package/src/style/format_section_override.js +56 -0
- package/src/style/light.js +130 -0
- package/src/style/load_glyph_range.js +38 -0
- package/src/style/load_sprite.js +67 -0
- package/src/style/parse_glyph_pbf.js +44 -0
- package/src/style/pauseable_placement.js +132 -0
- package/src/style/properties.js +753 -0
- package/src/style/query_utils.js +43 -0
- package/src/style/style.js +1374 -0
- package/src/style/style_glyph.js +17 -0
- package/src/style/style_image.js +137 -0
- package/src/style/style_layer/background_style_layer.js +21 -0
- package/src/style/style_layer/background_style_layer_properties.js +40 -0
- package/src/style/style_layer/circle_style_layer.js +98 -0
- package/src/style/style_layer/circle_style_layer_properties.js +63 -0
- package/src/style/style_layer/custom_style_layer.js +223 -0
- package/src/style/style_layer/fill_extrusion_style_layer.js +224 -0
- package/src/style/style_layer/fill_extrusion_style_layer_properties.js +50 -0
- package/src/style/style_layer/fill_style_layer.js +67 -0
- package/src/style/style_layer/fill_style_layer_properties.js +55 -0
- package/src/style/style_layer/heatmap_style_layer.js +73 -0
- package/src/style/style_layer/heatmap_style_layer_properties.js +44 -0
- package/src/style/style_layer/hillshade_style_layer.js +25 -0
- package/src/style/style_layer/hillshade_style_layer_properties.js +46 -0
- package/src/style/style_layer/layer_properties.js.ejs +69 -0
- package/src/style/style_layer/line_style_layer.js +150 -0
- package/src/style/style_layer/line_style_layer_properties.js +71 -0
- package/src/style/style_layer/raster_style_layer.js +21 -0
- package/src/style/style_layer/raster_style_layer_properties.js +50 -0
- package/src/style/style_layer/symbol_style_layer.js +190 -0
- package/src/style/style_layer/symbol_style_layer_properties.js +153 -0
- package/src/style/style_layer/typed_style_layer.js +17 -0
- package/src/style/style_layer.js +283 -0
- package/src/style/style_layer_index.js +80 -0
- package/src/style/validate_style.js +42 -0
- package/src/style/zoom_history.js +44 -0
- package/src/style-spec/.eslintrc +5 -0
- package/src/style-spec/CHANGELOG.md +468 -0
- package/src/style-spec/README.md +59 -0
- package/src/style-spec/bin/gl-style-composite +9 -0
- package/src/style-spec/bin/gl-style-format +22 -0
- package/src/style-spec/bin/gl-style-migrate +9 -0
- package/src/style-spec/bin/gl-style-validate +50 -0
- package/src/style-spec/composite.js +50 -0
- package/src/style-spec/declass.js +42 -0
- package/src/style-spec/deref.js +52 -0
- package/src/style-spec/diff.js +393 -0
- package/src/style-spec/dist/.gitkeep +0 -0
- package/src/style-spec/dist/index.es.js +15032 -0
- package/src/style-spec/dist/index.es.js.map +1 -0
- package/src/style-spec/dist/index.js +15058 -0
- package/src/style-spec/dist/index.js.map +1 -0
- package/src/style-spec/empty.js +29 -0
- package/src/style-spec/error/parsing_error.js +16 -0
- package/src/style-spec/error/validation_error.js +18 -0
- package/src/style-spec/expression/compound_expression.js +162 -0
- package/src/style-spec/expression/definitions/assertion.js +130 -0
- package/src/style-spec/expression/definitions/at.js +70 -0
- package/src/style-spec/expression/definitions/case.js +85 -0
- package/src/style-spec/expression/definitions/coalesce.js +93 -0
- package/src/style-spec/expression/definitions/coercion.js +133 -0
- package/src/style-spec/expression/definitions/collator.js +78 -0
- package/src/style-spec/expression/definitions/comparison.js +184 -0
- package/src/style-spec/expression/definitions/format.js +144 -0
- package/src/style-spec/expression/definitions/image.js +52 -0
- package/src/style-spec/expression/definitions/in.js +72 -0
- package/src/style-spec/expression/definitions/index.js +565 -0
- package/src/style-spec/expression/definitions/index_of.js +89 -0
- package/src/style-spec/expression/definitions/interpolate.js +267 -0
- package/src/style-spec/expression/definitions/length.js +61 -0
- package/src/style-spec/expression/definitions/let.js +72 -0
- package/src/style-spec/expression/definitions/literal.js +77 -0
- package/src/style-spec/expression/definitions/match.js +158 -0
- package/src/style-spec/expression/definitions/number_format.js +142 -0
- package/src/style-spec/expression/definitions/slice.js +86 -0
- package/src/style-spec/expression/definitions/step.js +120 -0
- package/src/style-spec/expression/definitions/var.js +46 -0
- package/src/style-spec/expression/definitions/within.js +342 -0
- package/src/style-spec/expression/evaluation_context.js +59 -0
- package/src/style-spec/expression/expression.js +27 -0
- package/src/style-spec/expression/index.js +392 -0
- package/src/style-spec/expression/is_constant.js +59 -0
- package/src/style-spec/expression/parsing_context.js +233 -0
- package/src/style-spec/expression/parsing_error.js +13 -0
- package/src/style-spec/expression/runtime_error.js +17 -0
- package/src/style-spec/expression/scope.js +36 -0
- package/src/style-spec/expression/stops.js +39 -0
- package/src/style-spec/expression/types/collator.js +61 -0
- package/src/style-spec/expression/types/formatted.js +73 -0
- package/src/style-spec/expression/types/resolved_image.js +29 -0
- package/src/style-spec/expression/types.js +126 -0
- package/src/style-spec/expression/values.js +123 -0
- package/src/style-spec/feature_filter/README.md +55 -0
- package/src/style-spec/feature_filter/convert.js +208 -0
- package/src/style-spec/feature_filter/index.js +175 -0
- package/src/style-spec/format.js +51 -0
- package/src/style-spec/function/convert.js +270 -0
- package/src/style-spec/function/index.js +262 -0
- package/src/style-spec/group_by_layout.js +75 -0
- package/src/style-spec/migrate/expressions.js +39 -0
- package/src/style-spec/migrate/v8.js +203 -0
- package/src/style-spec/migrate/v9.js +26 -0
- package/src/style-spec/migrate.js +36 -0
- package/src/style-spec/package.json +41 -0
- package/src/style-spec/read_style.js +14 -0
- package/src/style-spec/reference/latest.js +3 -0
- package/src/style-spec/reference/v8.json +5914 -0
- package/src/style-spec/rollup.config.js +65 -0
- package/src/style-spec/style-spec.js +124 -0
- package/src/style-spec/types.js +432 -0
- package/src/style-spec/util/color.js +95 -0
- package/src/style-spec/util/color_spaces.js +139 -0
- package/src/style-spec/util/deep_equal.js +28 -0
- package/src/style-spec/util/extend.js +10 -0
- package/src/style-spec/util/get_type.js +17 -0
- package/src/style-spec/util/interpolate.js +22 -0
- package/src/style-spec/util/properties.js +15 -0
- package/src/style-spec/util/ref_properties.js +2 -0
- package/src/style-spec/util/result.js +19 -0
- package/src/style-spec/util/unbundle_jsonlint.js +24 -0
- package/src/style-spec/validate/latest.js +11 -0
- package/src/style-spec/validate/validate.js +75 -0
- package/src/style-spec/validate/validate_array.js +52 -0
- package/src/style-spec/validate/validate_boolean.js +15 -0
- package/src/style-spec/validate/validate_color.js +20 -0
- package/src/style-spec/validate/validate_constants.js +13 -0
- package/src/style-spec/validate/validate_enum.js +21 -0
- package/src/style-spec/validate/validate_expression.js +43 -0
- package/src/style-spec/validate/validate_filter.js +117 -0
- package/src/style-spec/validate/validate_formatted.js +11 -0
- package/src/style-spec/validate/validate_function.js +207 -0
- package/src/style-spec/validate/validate_glyphs_url.js +21 -0
- package/src/style-spec/validate/validate_image.js +11 -0
- package/src/style-spec/validate/validate_layer.js +134 -0
- package/src/style-spec/validate/validate_layout_property.js +6 -0
- package/src/style-spec/validate/validate_light.js +47 -0
- package/src/style-spec/validate/validate_number.js +29 -0
- package/src/style-spec/validate/validate_object.js +61 -0
- package/src/style-spec/validate/validate_paint_property.js +6 -0
- package/src/style-spec/validate/validate_property.js +64 -0
- package/src/style-spec/validate/validate_source.js +111 -0
- package/src/style-spec/validate/validate_string.js +15 -0
- package/src/style-spec/validate_mapbox_api_supported.js +171 -0
- package/src/style-spec/validate_style.js +39 -0
- package/src/style-spec/validate_style.min.js +78 -0
- package/src/style-spec/visit.js +77 -0
- package/src/symbol/anchor.js +26 -0
- package/src/symbol/check_max_angle.js +81 -0
- package/src/symbol/clip_line.js +71 -0
- package/src/symbol/collision_feature.js +109 -0
- package/src/symbol/collision_index.js +373 -0
- package/src/symbol/cross_tile_symbol_index.js +301 -0
- package/src/symbol/get_anchors.js +167 -0
- package/src/symbol/grid_index.js +335 -0
- package/src/symbol/mergelines.js +82 -0
- package/src/symbol/one_em.js +4 -0
- package/src/symbol/opacity_state.js +27 -0
- package/src/symbol/path_interpolator.js +61 -0
- package/src/symbol/placement.js +1124 -0
- package/src/symbol/projection.js +451 -0
- package/src/symbol/quads.js +334 -0
- package/src/symbol/shaping.js +816 -0
- package/src/symbol/symbol_layout.js +796 -0
- package/src/symbol/symbol_size.js +113 -0
- package/src/symbol/transform_text.js +29 -0
- package/src/types/callback.js +17 -0
- package/src/types/cancelable.js +3 -0
- package/src/types/tilejson.js +17 -0
- package/src/types/transferable.js +3 -0
- package/src/types/window.js +172 -0
- package/src/ui/anchor.js +32 -0
- package/src/ui/camera.js +1277 -0
- package/src/ui/control/attribution_control.js +212 -0
- package/src/ui/control/fullscreen_control.js +147 -0
- package/src/ui/control/geolocate_control.js +707 -0
- package/src/ui/control/logo_control.js +92 -0
- package/src/ui/control/navigation_control.js +257 -0
- package/src/ui/control/scale_control.js +142 -0
- package/src/ui/default_locale.js +22 -0
- package/src/ui/events.js +1301 -0
- package/src/ui/handler/box_zoom.js +170 -0
- package/src/ui/handler/click_zoom.js +52 -0
- package/src/ui/handler/handler_util.js +12 -0
- package/src/ui/handler/keyboard.js +208 -0
- package/src/ui/handler/map_event.js +156 -0
- package/src/ui/handler/mouse.js +171 -0
- package/src/ui/handler/scroll_zoom.js +350 -0
- package/src/ui/handler/shim/dblclick_zoom.js +62 -0
- package/src/ui/handler/shim/drag_pan.js +88 -0
- package/src/ui/handler/shim/drag_rotate.js +67 -0
- package/src/ui/handler/shim/touch_zoom_rotate.js +108 -0
- package/src/ui/handler/tap_drag_zoom.js +103 -0
- package/src/ui/handler/tap_recognizer.js +133 -0
- package/src/ui/handler/tap_zoom.js +93 -0
- package/src/ui/handler/touch_pan.js +101 -0
- package/src/ui/handler/touch_zoom_rotate.js +305 -0
- package/src/ui/handler_inertia.js +158 -0
- package/src/ui/handler_manager.js +531 -0
- package/src/ui/hash.js +148 -0
- package/src/ui/map.js +2874 -0
- package/src/ui/marker.js +672 -0
- package/src/ui/popup.js +640 -0
- package/src/util/actor.js +212 -0
- package/src/util/ajax.js +388 -0
- package/src/util/browser/web_worker.js +10 -0
- package/src/util/browser/window.js +6 -0
- package/src/util/browser.js +70 -0
- package/src/util/classify_rings.js +52 -0
- package/src/util/color_ramp.js +61 -0
- package/src/util/config.js +30 -0
- package/src/util/debug.js +28 -0
- package/src/util/dictionary_coder.js +30 -0
- package/src/util/dispatcher.js +70 -0
- package/src/util/dom.js +142 -0
- package/src/util/evented.js +174 -0
- package/src/util/find_pole_of_inaccessibility.js +129 -0
- package/src/util/global_worker_pool.js +35 -0
- package/src/util/image.js +142 -0
- package/src/util/intersection_tests.js +208 -0
- package/src/util/is_char_in_unicode_block.js +311 -0
- package/src/util/mapbox.js +491 -0
- package/src/util/offscreen_canvas_supported.js +14 -0
- package/src/util/performance.js +112 -0
- package/src/util/primitives.js +145 -0
- package/src/util/resolve_tokens.js +16 -0
- package/src/util/script_detection.js +328 -0
- package/src/util/sku_token.js +42 -0
- package/src/util/smart_wrap.js +55 -0
- package/src/util/struct_array.js +243 -0
- package/src/util/struct_array.js.ejs +112 -0
- package/src/util/struct_array_layout.js.ejs +98 -0
- package/src/util/task_queue.js +68 -0
- package/src/util/throttle.js +27 -0
- package/src/util/throttled_invoker.js +46 -0
- package/src/util/tile_request_cache.js +172 -0
- package/src/util/util.js +524 -0
- package/src/util/vectortile_to_geojson.js +50 -0
- package/src/util/verticalize_punctuation.js +114 -0
- package/src/util/web_worker.js +91 -0
- package/src/util/web_worker_transfer.js +266 -0
- package/src/util/webp_supported.js +69 -0
- package/src/util/window.js +102 -0
- package/src/util/worker_pool.js +57 -0
|
@@ -0,0 +1,307 @@
|
|
|
1
|
+
// @flow
|
|
2
|
+
|
|
3
|
+
import {CanonicalTileID} from './tile_id';
|
|
4
|
+
import {Event, ErrorEvent, Evented} from '../util/evented';
|
|
5
|
+
import {getImage, ResourceType} from '../util/ajax';
|
|
6
|
+
import EXTENT from '../data/extent';
|
|
7
|
+
import {RasterBoundsArray} from '../data/array_types';
|
|
8
|
+
import rasterBoundsAttributes from '../data/raster_bounds_attributes';
|
|
9
|
+
import SegmentVector from '../data/segment';
|
|
10
|
+
import Texture from '../render/texture';
|
|
11
|
+
import MercatorCoordinate from '../geo/mercator_coordinate';
|
|
12
|
+
|
|
13
|
+
import type {Source} from './source';
|
|
14
|
+
import type {CanvasSourceSpecification} from './canvas_source';
|
|
15
|
+
import type Map from '../ui/map';
|
|
16
|
+
import type Dispatcher from '../util/dispatcher';
|
|
17
|
+
import type Tile from './tile';
|
|
18
|
+
import type {Callback} from '../types/callback';
|
|
19
|
+
import type VertexBuffer from '../gl/vertex_buffer';
|
|
20
|
+
import type {
|
|
21
|
+
ImageSourceSpecification,
|
|
22
|
+
VideoSourceSpecification
|
|
23
|
+
} from '../style-spec/types';
|
|
24
|
+
|
|
25
|
+
type Coordinates = [[number, number], [number, number], [number, number], [number, number]];
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* A data source containing an image.
|
|
29
|
+
* (See the [Style Specification](https://www.mapbox.com/mapbox-gl-style-spec/#sources-image) for detailed documentation of options.)
|
|
30
|
+
*
|
|
31
|
+
* @example
|
|
32
|
+
* // add to map
|
|
33
|
+
* map.addSource('some id', {
|
|
34
|
+
* type: 'image',
|
|
35
|
+
* url: 'https://www.mapbox.com/images/foo.png',
|
|
36
|
+
* coordinates: [
|
|
37
|
+
* [-76.54, 39.18],
|
|
38
|
+
* [-76.52, 39.18],
|
|
39
|
+
* [-76.52, 39.17],
|
|
40
|
+
* [-76.54, 39.17]
|
|
41
|
+
* ]
|
|
42
|
+
* });
|
|
43
|
+
*
|
|
44
|
+
* // update coordinates
|
|
45
|
+
* var mySource = map.getSource('some id');
|
|
46
|
+
* mySource.setCoordinates([
|
|
47
|
+
* [-76.54335737228394, 39.18579907229748],
|
|
48
|
+
* [-76.52803659439087, 39.1838364847587],
|
|
49
|
+
* [-76.5295386314392, 39.17683392507606],
|
|
50
|
+
* [-76.54520273208618, 39.17876344106642]
|
|
51
|
+
* ]);
|
|
52
|
+
*
|
|
53
|
+
* // update url and coordinates simultaneously
|
|
54
|
+
* mySource.updateImage({
|
|
55
|
+
* url: 'https://www.mapbox.com/images/bar.png',
|
|
56
|
+
* coordinates: [
|
|
57
|
+
* [-76.54335737228394, 39.18579907229748],
|
|
58
|
+
* [-76.52803659439087, 39.1838364847587],
|
|
59
|
+
* [-76.5295386314392, 39.17683392507606],
|
|
60
|
+
* [-76.54520273208618, 39.17876344106642]
|
|
61
|
+
* ]
|
|
62
|
+
* })
|
|
63
|
+
*
|
|
64
|
+
* map.removeSource('some id'); // remove
|
|
65
|
+
* @see [Add an image](https://www.mapbox.com/mapbox-gl-js/example/image-on-a-map/)
|
|
66
|
+
*/
|
|
67
|
+
class ImageSource extends Evented implements Source {
|
|
68
|
+
type: string;
|
|
69
|
+
id: string;
|
|
70
|
+
minzoom: number;
|
|
71
|
+
maxzoom: number;
|
|
72
|
+
tileSize: number;
|
|
73
|
+
url: string;
|
|
74
|
+
|
|
75
|
+
coordinates: Coordinates;
|
|
76
|
+
tiles: {[_: string]: Tile};
|
|
77
|
+
options: any;
|
|
78
|
+
dispatcher: Dispatcher;
|
|
79
|
+
map: Map;
|
|
80
|
+
texture: Texture | null;
|
|
81
|
+
image: HTMLImageElement | ImageBitmap;
|
|
82
|
+
tileID: CanonicalTileID;
|
|
83
|
+
_boundsArray: RasterBoundsArray;
|
|
84
|
+
boundsBuffer: VertexBuffer;
|
|
85
|
+
boundsSegments: SegmentVector;
|
|
86
|
+
_loaded: boolean;
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* @private
|
|
90
|
+
*/
|
|
91
|
+
constructor(id: string, options: ImageSourceSpecification | VideoSourceSpecification | CanvasSourceSpecification, dispatcher: Dispatcher, eventedParent: Evented) {
|
|
92
|
+
super();
|
|
93
|
+
this.id = id;
|
|
94
|
+
this.dispatcher = dispatcher;
|
|
95
|
+
this.coordinates = options.coordinates;
|
|
96
|
+
|
|
97
|
+
this.type = 'image';
|
|
98
|
+
this.minzoom = 0;
|
|
99
|
+
this.maxzoom = 22;
|
|
100
|
+
this.tileSize = 512;
|
|
101
|
+
this.tiles = {};
|
|
102
|
+
this._loaded = false;
|
|
103
|
+
|
|
104
|
+
this.setEventedParent(eventedParent);
|
|
105
|
+
|
|
106
|
+
this.options = options;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
load(newCoordinates?: Coordinates, successCallback?: () => void) {
|
|
110
|
+
this._loaded = false;
|
|
111
|
+
this.fire(new Event('dataloading', {dataType: 'source'}));
|
|
112
|
+
|
|
113
|
+
this.url = this.options.url;
|
|
114
|
+
|
|
115
|
+
getImage(this.map._requestManager.transformRequest(this.url, ResourceType.Image), (err, image) => {
|
|
116
|
+
this._loaded = true;
|
|
117
|
+
if (err) {
|
|
118
|
+
this.fire(new ErrorEvent(err));
|
|
119
|
+
} else if (image) {
|
|
120
|
+
this.image = image;
|
|
121
|
+
if (newCoordinates) {
|
|
122
|
+
this.coordinates = newCoordinates;
|
|
123
|
+
}
|
|
124
|
+
if (successCallback) {
|
|
125
|
+
successCallback();
|
|
126
|
+
}
|
|
127
|
+
this._finishLoading();
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
loaded(): boolean {
|
|
133
|
+
return this._loaded;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
/**
|
|
137
|
+
* Updates the image URL and, optionally, the coordinates. To avoid having the image flash after changing,
|
|
138
|
+
* set the `raster-fade-duration` paint property on the raster layer to 0.
|
|
139
|
+
*
|
|
140
|
+
* @param {Object} options Options object.
|
|
141
|
+
* @param {string} [options.url] Required image URL.
|
|
142
|
+
* @param {Array<Array<number>>} [options.coordinates] Four geographical coordinates,
|
|
143
|
+
* represented as arrays of longitude and latitude numbers, which define the corners of the image.
|
|
144
|
+
* The coordinates start at the top left corner of the image and proceed in clockwise order.
|
|
145
|
+
* They do not have to represent a rectangle.
|
|
146
|
+
* @returns {ImageSource} this
|
|
147
|
+
*/
|
|
148
|
+
updateImage(options: {url: string, coordinates?: Coordinates}) {
|
|
149
|
+
if (!this.image || !options.url) {
|
|
150
|
+
return this;
|
|
151
|
+
}
|
|
152
|
+
this.options.url = options.url;
|
|
153
|
+
this.load(options.coordinates, () => { this.texture = null; });
|
|
154
|
+
return this;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
_finishLoading() {
|
|
158
|
+
if (this.map) {
|
|
159
|
+
this.setCoordinates(this.coordinates);
|
|
160
|
+
this.fire(new Event('data', {dataType: 'source', sourceDataType: 'metadata'}));
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
onAdd(map: Map) {
|
|
165
|
+
this.map = map;
|
|
166
|
+
this.load();
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
/**
|
|
170
|
+
* Sets the image's coordinates and re-renders the map.
|
|
171
|
+
*
|
|
172
|
+
* @param {Array<Array<number>>} coordinates Four geographical coordinates,
|
|
173
|
+
* represented as arrays of longitude and latitude numbers, which define the corners of the image.
|
|
174
|
+
* The coordinates start at the top left corner of the image and proceed in clockwise order.
|
|
175
|
+
* They do not have to represent a rectangle.
|
|
176
|
+
* @returns {ImageSource} this
|
|
177
|
+
*/
|
|
178
|
+
setCoordinates(coordinates: Coordinates) {
|
|
179
|
+
this.coordinates = coordinates;
|
|
180
|
+
|
|
181
|
+
// Calculate which mercator tile is suitable for rendering the video in
|
|
182
|
+
// and create a buffer with the corner coordinates. These coordinates
|
|
183
|
+
// may be outside the tile, because raster tiles aren't clipped when rendering.
|
|
184
|
+
|
|
185
|
+
// transform the geo coordinates into (zoom 0) tile space coordinates
|
|
186
|
+
const cornerCoords = coordinates.map(MercatorCoordinate.fromLngLat);
|
|
187
|
+
|
|
188
|
+
// Compute the coordinates of the tile we'll use to hold this image's
|
|
189
|
+
// render data
|
|
190
|
+
this.tileID = getCoordinatesCenterTileID(cornerCoords);
|
|
191
|
+
|
|
192
|
+
// Constrain min/max zoom to our tile's zoom level in order to force
|
|
193
|
+
// SourceCache to request this tile (no matter what the map's zoom
|
|
194
|
+
// level)
|
|
195
|
+
this.minzoom = this.maxzoom = this.tileID.z;
|
|
196
|
+
|
|
197
|
+
// Transform the corner coordinates into the coordinate space of our
|
|
198
|
+
// tile.
|
|
199
|
+
const tileCoords = cornerCoords.map((coord) => this.tileID.getTilePoint(coord)._round());
|
|
200
|
+
|
|
201
|
+
this._boundsArray = new RasterBoundsArray();
|
|
202
|
+
this._boundsArray.emplaceBack(tileCoords[0].x, tileCoords[0].y, 0, 0);
|
|
203
|
+
this._boundsArray.emplaceBack(tileCoords[1].x, tileCoords[1].y, EXTENT, 0);
|
|
204
|
+
this._boundsArray.emplaceBack(tileCoords[3].x, tileCoords[3].y, 0, EXTENT);
|
|
205
|
+
this._boundsArray.emplaceBack(tileCoords[2].x, tileCoords[2].y, EXTENT, EXTENT);
|
|
206
|
+
|
|
207
|
+
if (this.boundsBuffer) {
|
|
208
|
+
this.boundsBuffer.destroy();
|
|
209
|
+
delete this.boundsBuffer;
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
this.fire(new Event('data', {dataType:'source', sourceDataType: 'content'}));
|
|
213
|
+
return this;
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
prepare() {
|
|
217
|
+
if (Object.keys(this.tiles).length === 0 || !this.image) {
|
|
218
|
+
return;
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
const context = this.map.painter.context;
|
|
222
|
+
const gl = context.gl;
|
|
223
|
+
|
|
224
|
+
if (!this.boundsBuffer) {
|
|
225
|
+
this.boundsBuffer = context.createVertexBuffer(this._boundsArray, rasterBoundsAttributes.members);
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
if (!this.boundsSegments) {
|
|
229
|
+
this.boundsSegments = SegmentVector.simpleSegment(0, 0, 4, 2);
|
|
230
|
+
}
|
|
231
|
+
|
|
232
|
+
if (!this.texture) {
|
|
233
|
+
this.texture = new Texture(context, this.image, gl.RGBA);
|
|
234
|
+
this.texture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
for (const w in this.tiles) {
|
|
238
|
+
const tile = this.tiles[w];
|
|
239
|
+
if (tile.state !== 'loaded') {
|
|
240
|
+
tile.state = 'loaded';
|
|
241
|
+
tile.texture = this.texture;
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
loadTile(tile: Tile, callback: Callback<void>) {
|
|
247
|
+
// We have a single tile -- whoose coordinates are this.tileID -- that
|
|
248
|
+
// covers the image we want to render. If that's the one being
|
|
249
|
+
// requested, set it up with the image; otherwise, mark the tile as
|
|
250
|
+
// `errored` to indicate that we have no data for it.
|
|
251
|
+
// If the world wraps, we may have multiple "wrapped" copies of the
|
|
252
|
+
// single tile.
|
|
253
|
+
if (this.tileID && this.tileID.equals(tile.tileID.canonical)) {
|
|
254
|
+
this.tiles[String(tile.tileID.wrap)] = tile;
|
|
255
|
+
tile.buckets = {};
|
|
256
|
+
callback(null);
|
|
257
|
+
} else {
|
|
258
|
+
tile.state = 'errored';
|
|
259
|
+
callback(null);
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
serialize(): Object {
|
|
264
|
+
return {
|
|
265
|
+
type: 'image',
|
|
266
|
+
url: this.options.url,
|
|
267
|
+
coordinates: this.coordinates
|
|
268
|
+
};
|
|
269
|
+
}
|
|
270
|
+
|
|
271
|
+
hasTransition() {
|
|
272
|
+
return false;
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
|
|
276
|
+
/**
|
|
277
|
+
* Given a list of coordinates, get their center as a coordinate.
|
|
278
|
+
*
|
|
279
|
+
* @returns centerpoint
|
|
280
|
+
* @private
|
|
281
|
+
*/
|
|
282
|
+
export function getCoordinatesCenterTileID(coords: Array<MercatorCoordinate>) {
|
|
283
|
+
let minX = Infinity;
|
|
284
|
+
let minY = Infinity;
|
|
285
|
+
let maxX = -Infinity;
|
|
286
|
+
let maxY = -Infinity;
|
|
287
|
+
|
|
288
|
+
for (const coord of coords) {
|
|
289
|
+
minX = Math.min(minX, coord.x);
|
|
290
|
+
minY = Math.min(minY, coord.y);
|
|
291
|
+
maxX = Math.max(maxX, coord.x);
|
|
292
|
+
maxY = Math.max(maxY, coord.y);
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
const dx = maxX - minX;
|
|
296
|
+
const dy = maxY - minY;
|
|
297
|
+
const dMax = Math.max(dx, dy);
|
|
298
|
+
const zoom = Math.max(0, Math.floor(-Math.log(dMax) / Math.LN2));
|
|
299
|
+
const tilesAtZoom = Math.pow(2, zoom);
|
|
300
|
+
|
|
301
|
+
return new CanonicalTileID(
|
|
302
|
+
zoom,
|
|
303
|
+
Math.floor((minX + maxX) / 2 * tilesAtZoom),
|
|
304
|
+
Math.floor((minY + maxY) / 2 * tilesAtZoom));
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
export default ImageSource;
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
// @flow
|
|
2
|
+
|
|
3
|
+
import {pick, extend} from '../util/util';
|
|
4
|
+
|
|
5
|
+
import {getJSON, ResourceType} from '../util/ajax';
|
|
6
|
+
import browser from '../util/browser';
|
|
7
|
+
|
|
8
|
+
import type {RequestManager} from '../util/mapbox';
|
|
9
|
+
import type {Callback} from '../types/callback';
|
|
10
|
+
import type {TileJSON} from '../types/tilejson';
|
|
11
|
+
import type {Cancelable} from '../types/cancelable';
|
|
12
|
+
|
|
13
|
+
export default function(options: any, requestManager: RequestManager, callback: Callback<TileJSON>): Cancelable {
|
|
14
|
+
const loaded = function(err: ?Error, tileJSON: ?Object) {
|
|
15
|
+
if (err) {
|
|
16
|
+
return callback(err);
|
|
17
|
+
} else if (tileJSON) {
|
|
18
|
+
const result: any = pick(
|
|
19
|
+
// explicit source options take precedence over TileJSON
|
|
20
|
+
extend(tileJSON, options),
|
|
21
|
+
['tiles', 'minzoom', 'maxzoom', 'attribution', 'mapbox_logo', 'bounds', 'scheme', 'tileSize', 'encoding']
|
|
22
|
+
);
|
|
23
|
+
|
|
24
|
+
if (tileJSON.vector_layers) {
|
|
25
|
+
result.vectorLayers = tileJSON.vector_layers;
|
|
26
|
+
result.vectorLayerIds = result.vectorLayers.map((layer) => { return layer.id; });
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
result.tiles = requestManager.canonicalizeTileset(result, options.url);
|
|
30
|
+
callback(null, result);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
if (options.url) {
|
|
35
|
+
return getJSON(requestManager.transformRequest(requestManager.normalizeSourceURL(options.url), ResourceType.Source), loaded);
|
|
36
|
+
} else {
|
|
37
|
+
return browser.frame(() => loaded(null, options));
|
|
38
|
+
}
|
|
39
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
// @flow
|
|
2
|
+
|
|
3
|
+
import EXTENT from '../data/extent';
|
|
4
|
+
|
|
5
|
+
import type {OverscaledTileID} from './tile_id';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Converts a pixel value at a the given zoom level to tile units.
|
|
9
|
+
*
|
|
10
|
+
* The shaders mostly calculate everything in tile units so style
|
|
11
|
+
* properties need to be converted from pixels to tile units using this.
|
|
12
|
+
*
|
|
13
|
+
* For example, a translation by 30 pixels at zoom 6.5 will be a
|
|
14
|
+
* translation by pixelsToTileUnits(30, 6.5) tile units.
|
|
15
|
+
*
|
|
16
|
+
* @returns value in tile units
|
|
17
|
+
* @private
|
|
18
|
+
*/
|
|
19
|
+
export default function(tile: {tileID: OverscaledTileID, tileSize: number}, pixelValue: number, z: number): number {
|
|
20
|
+
return pixelValue * (EXTENT / (tile.tileSize * Math.pow(2, z - tile.tileID.overscaledZ)));
|
|
21
|
+
}
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
// @flow
|
|
2
|
+
|
|
3
|
+
import type SourceCache from './source_cache';
|
|
4
|
+
import type StyleLayer from '../style/style_layer';
|
|
5
|
+
import type CollisionIndex from '../symbol/collision_index';
|
|
6
|
+
import type Transform from '../geo/transform';
|
|
7
|
+
import type {RetainedQueryData} from '../symbol/placement';
|
|
8
|
+
import type {FilterSpecification} from '../style-spec/types';
|
|
9
|
+
import assert from 'assert';
|
|
10
|
+
import {mat4} from 'gl-matrix';
|
|
11
|
+
|
|
12
|
+
/*
|
|
13
|
+
* Returns a matrix that can be used to convert from tile coordinates to viewport pixel coordinates.
|
|
14
|
+
*/
|
|
15
|
+
function getPixelPosMatrix(transform, tileID) {
|
|
16
|
+
const t = mat4.identity([]);
|
|
17
|
+
mat4.translate(t, t, [1, 1, 0]);
|
|
18
|
+
mat4.scale(t, t, [transform.width * 0.5, transform.height * 0.5, 1]);
|
|
19
|
+
return mat4.multiply(t, t, transform.calculatePosMatrix(tileID.toUnwrapped()));
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
function queryIncludes3DLayer(layers?: Array<string>, styleLayers: {[_: string]: StyleLayer}, sourceID: string) {
|
|
23
|
+
if (layers) {
|
|
24
|
+
for (const layerID of layers) {
|
|
25
|
+
const layer = styleLayers[layerID];
|
|
26
|
+
if (layer && layer.source === sourceID && layer.type === 'fill-extrusion') {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
} else {
|
|
31
|
+
for (const key in styleLayers) {
|
|
32
|
+
const layer = styleLayers[key];
|
|
33
|
+
if (layer.source === sourceID && layer.type === 'fill-extrusion') {
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
return false;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export function queryRenderedFeatures(sourceCache: SourceCache,
|
|
42
|
+
styleLayers: {[_: string]: StyleLayer},
|
|
43
|
+
serializedLayers: {[_: string]: Object},
|
|
44
|
+
queryGeometry: Array<Point>,
|
|
45
|
+
params: { filter: FilterSpecification, layers: Array<string>, availableImages: Array<string> },
|
|
46
|
+
transform: Transform) {
|
|
47
|
+
|
|
48
|
+
const has3DLayer = queryIncludes3DLayer(params && params.layers, styleLayers, sourceCache.id);
|
|
49
|
+
const maxPitchScaleFactor = transform.maxPitchScaleFactor();
|
|
50
|
+
const tilesIn = sourceCache.tilesIn(queryGeometry, maxPitchScaleFactor, has3DLayer);
|
|
51
|
+
|
|
52
|
+
tilesIn.sort(sortTilesIn);
|
|
53
|
+
const renderedFeatureLayers = [];
|
|
54
|
+
for (const tileIn of tilesIn) {
|
|
55
|
+
renderedFeatureLayers.push({
|
|
56
|
+
wrappedTileID: tileIn.tileID.wrapped().key,
|
|
57
|
+
queryResults: tileIn.tile.queryRenderedFeatures(
|
|
58
|
+
styleLayers,
|
|
59
|
+
serializedLayers,
|
|
60
|
+
sourceCache._state,
|
|
61
|
+
tileIn.queryGeometry,
|
|
62
|
+
tileIn.cameraQueryGeometry,
|
|
63
|
+
tileIn.scale,
|
|
64
|
+
params,
|
|
65
|
+
transform,
|
|
66
|
+
maxPitchScaleFactor,
|
|
67
|
+
getPixelPosMatrix(sourceCache.transform, tileIn.tileID))
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
const result = mergeRenderedFeatureLayers(renderedFeatureLayers);
|
|
72
|
+
|
|
73
|
+
// Merge state from SourceCache into the results
|
|
74
|
+
for (const layerID in result) {
|
|
75
|
+
result[layerID].forEach((featureWrapper) => {
|
|
76
|
+
const feature = featureWrapper.feature;
|
|
77
|
+
const state = sourceCache.getFeatureState(feature.layer['source-layer'], feature.id);
|
|
78
|
+
feature.source = feature.layer.source;
|
|
79
|
+
if (feature.layer['source-layer']) {
|
|
80
|
+
feature.sourceLayer = feature.layer['source-layer'];
|
|
81
|
+
}
|
|
82
|
+
feature.state = state;
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
return result;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
export function queryRenderedSymbols(styleLayers: {[_: string]: StyleLayer},
|
|
89
|
+
serializedLayers: {[_: string]: StyleLayer},
|
|
90
|
+
sourceCaches: {[_: string]: SourceCache},
|
|
91
|
+
queryGeometry: Array<Point>,
|
|
92
|
+
params: { filter: FilterSpecification, layers: Array<string>, availableImages: Array<string> },
|
|
93
|
+
collisionIndex: CollisionIndex,
|
|
94
|
+
retainedQueryData: {[_: number]: RetainedQueryData}) {
|
|
95
|
+
const result = {};
|
|
96
|
+
const renderedSymbols = collisionIndex.queryRenderedSymbols(queryGeometry);
|
|
97
|
+
const bucketQueryData = [];
|
|
98
|
+
for (const bucketInstanceId of Object.keys(renderedSymbols).map(Number)) {
|
|
99
|
+
bucketQueryData.push(retainedQueryData[bucketInstanceId]);
|
|
100
|
+
}
|
|
101
|
+
bucketQueryData.sort(sortTilesIn);
|
|
102
|
+
|
|
103
|
+
for (const queryData of bucketQueryData) {
|
|
104
|
+
const bucketSymbols = queryData.featureIndex.lookupSymbolFeatures(
|
|
105
|
+
renderedSymbols[queryData.bucketInstanceId],
|
|
106
|
+
serializedLayers,
|
|
107
|
+
queryData.bucketIndex,
|
|
108
|
+
queryData.sourceLayerIndex,
|
|
109
|
+
params.filter,
|
|
110
|
+
params.layers,
|
|
111
|
+
params.availableImages,
|
|
112
|
+
styleLayers);
|
|
113
|
+
|
|
114
|
+
for (const layerID in bucketSymbols) {
|
|
115
|
+
const resultFeatures = result[layerID] = result[layerID] || [];
|
|
116
|
+
const layerSymbols = bucketSymbols[layerID];
|
|
117
|
+
layerSymbols.sort((a, b) => {
|
|
118
|
+
// Match topDownFeatureComparator from FeatureIndex, but using
|
|
119
|
+
// most recent sorting of features from bucket.sortFeatures
|
|
120
|
+
const featureSortOrder = queryData.featureSortOrder;
|
|
121
|
+
if (featureSortOrder) {
|
|
122
|
+
// queryRenderedSymbols documentation says we'll return features in
|
|
123
|
+
// "top-to-bottom" rendering order (aka last-to-first).
|
|
124
|
+
// Actually there can be multiple symbol instances per feature, so
|
|
125
|
+
// we sort each feature based on the first matching symbol instance.
|
|
126
|
+
const sortedA = featureSortOrder.indexOf(a.featureIndex);
|
|
127
|
+
const sortedB = featureSortOrder.indexOf(b.featureIndex);
|
|
128
|
+
assert(sortedA >= 0);
|
|
129
|
+
assert(sortedB >= 0);
|
|
130
|
+
return sortedB - sortedA;
|
|
131
|
+
} else {
|
|
132
|
+
// Bucket hasn't been re-sorted based on angle, so use the
|
|
133
|
+
// reverse of the order the features appeared in the data.
|
|
134
|
+
return b.featureIndex - a.featureIndex;
|
|
135
|
+
}
|
|
136
|
+
});
|
|
137
|
+
for (const symbolFeature of layerSymbols) {
|
|
138
|
+
resultFeatures.push(symbolFeature);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
// Merge state from SourceCache into the results
|
|
144
|
+
for (const layerName in result) {
|
|
145
|
+
result[layerName].forEach((featureWrapper) => {
|
|
146
|
+
const feature = featureWrapper.feature;
|
|
147
|
+
const layer = styleLayers[layerName];
|
|
148
|
+
const sourceCache = sourceCaches[layer.source];
|
|
149
|
+
const state = sourceCache.getFeatureState(feature.layer['source-layer'], feature.id);
|
|
150
|
+
feature.source = feature.layer.source;
|
|
151
|
+
if (feature.layer['source-layer']) {
|
|
152
|
+
feature.sourceLayer = feature.layer['source-layer'];
|
|
153
|
+
}
|
|
154
|
+
feature.state = state;
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
return result;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
export function querySourceFeatures(sourceCache: SourceCache, params: any) {
|
|
161
|
+
const tiles = sourceCache.getRenderableIds().map((id) => {
|
|
162
|
+
return sourceCache.getTileByID(id);
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
const result = [];
|
|
166
|
+
|
|
167
|
+
const dataTiles = {};
|
|
168
|
+
for (let i = 0; i < tiles.length; i++) {
|
|
169
|
+
const tile = tiles[i];
|
|
170
|
+
const dataID = tile.tileID.canonical.key;
|
|
171
|
+
if (!dataTiles[dataID]) {
|
|
172
|
+
dataTiles[dataID] = true;
|
|
173
|
+
tile.querySourceFeatures(result, params);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
return result;
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
function sortTilesIn(a, b) {
|
|
181
|
+
const idA = a.tileID;
|
|
182
|
+
const idB = b.tileID;
|
|
183
|
+
return (idA.overscaledZ - idB.overscaledZ) || (idA.canonical.y - idB.canonical.y) || (idA.wrap - idB.wrap) || (idA.canonical.x - idB.canonical.x);
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
function mergeRenderedFeatureLayers(tiles) {
|
|
187
|
+
// Merge results from all tiles, but if two tiles share the same
|
|
188
|
+
// wrapped ID, don't duplicate features between the two tiles
|
|
189
|
+
const result = {};
|
|
190
|
+
const wrappedIDLayerMap = {};
|
|
191
|
+
for (const tile of tiles) {
|
|
192
|
+
const queryResults = tile.queryResults;
|
|
193
|
+
const wrappedID = tile.wrappedTileID;
|
|
194
|
+
const wrappedIDLayers = wrappedIDLayerMap[wrappedID] = wrappedIDLayerMap[wrappedID] || {};
|
|
195
|
+
for (const layerID in queryResults) {
|
|
196
|
+
const tileFeatures = queryResults[layerID];
|
|
197
|
+
const wrappedIDFeatures = wrappedIDLayers[layerID] = wrappedIDLayers[layerID] || {};
|
|
198
|
+
const resultFeatures = result[layerID] = result[layerID] || [];
|
|
199
|
+
for (const tileFeature of tileFeatures) {
|
|
200
|
+
if (!wrappedIDFeatures[tileFeature.featureIndex]) {
|
|
201
|
+
wrappedIDFeatures[tileFeature.featureIndex] = true;
|
|
202
|
+
resultFeatures.push(tileFeature);
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
return result;
|
|
208
|
+
}
|