@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.
- package/dist/mapbox-gl.js +3 -3
- package/dist/mapbox-gl.js.map +1 -1
- package/package.json +1 -1
- package/.flowconfig +0 -61
- package/LICENSE.txt +0 -84
- package/README.md +0 -34
- package/build/banner.js +0 -4
- package/build/check-bundle-size.js +0 -140
- package/build/generate-access-token-script.js +0 -11
- package/build/generate-flow-typed-style-spec.js +0 -188
- package/build/generate-release-list.js +0 -21
- package/build/generate-struct-arrays.js +0 -237
- package/build/generate-style-code.js +0 -159
- package/build/mapbox-gl.js.flow +0 -3
- package/build/print-release-url.js +0 -6
- package/build/rollup_plugin_minify_style_spec.js +0 -20
- package/build/rollup_plugins.js +0 -80
- package/build/run-node +0 -3
- package/build/run-tap +0 -8
- package/build/test/build-tape.js +0 -19
- package/flow-typed/gl.js +0 -5
- package/flow-typed/jsdom.js +0 -18
- package/flow-typed/mapbox-gl-supported.js +0 -9
- package/flow-typed/mapbox-unitbezier.js +0 -14
- package/flow-typed/offscreen-canvas.js +0 -9
- package/flow-typed/pbf.js +0 -25
- package/flow-typed/point-geometry.js +0 -44
- package/flow-typed/potpack.js +0 -12
- package/flow-typed/sinon.js +0 -28
- package/flow-typed/vector-tile.js +0 -41
- package/src/css/mapbox-gl.css +0 -798
- package/src/css/svg/mapboxgl-ctrl-attrib.svg +0 -3
- package/src/css/svg/mapboxgl-ctrl-compass.svg +0 -4
- package/src/css/svg/mapboxgl-ctrl-fullscreen.svg +0 -3
- package/src/css/svg/mapboxgl-ctrl-geolocate.svg +0 -5
- package/src/css/svg/mapboxgl-ctrl-logo.svg +0 -20
- package/src/css/svg/mapboxgl-ctrl-shrink.svg +0 -3
- package/src/css/svg/mapboxgl-ctrl-zoom-in.svg +0 -3
- package/src/css/svg/mapboxgl-ctrl-zoom-out.svg +0 -3
- package/src/data/array_types.js +0 -1095
- package/src/data/bucket/circle_attributes.js +0 -9
- package/src/data/bucket/circle_bucket.js +0 -204
- package/src/data/bucket/fill_attributes.js +0 -9
- package/src/data/bucket/fill_bucket.js +0 -233
- package/src/data/bucket/fill_extrusion_attributes.js +0 -10
- package/src/data/bucket/fill_extrusion_bucket.js +0 -289
- package/src/data/bucket/heatmap_bucket.js +0 -17
- package/src/data/bucket/line_attributes.js +0 -10
- package/src/data/bucket/line_bucket.js +0 -556
- package/src/data/bucket/pattern_attributes.js +0 -10
- package/src/data/bucket/pattern_bucket_features.js +0 -60
- package/src/data/bucket/symbol_attributes.js +0 -117
- package/src/data/bucket/symbol_bucket.js +0 -972
- package/src/data/bucket.js +0 -123
- package/src/data/dem_data.js +0 -125
- package/src/data/extent.js +0 -18
- package/src/data/feature_index.js +0 -321
- package/src/data/feature_position_map.js +0 -125
- package/src/data/index_array_type.js +0 -16
- package/src/data/load_geometry.js +0 -48
- package/src/data/pos_attributes.js +0 -6
- package/src/data/program_configuration.js +0 -687
- package/src/data/raster_bounds_attributes.js +0 -7
- package/src/data/segment.js +0 -76
- package/src/geo/edge_insets.js +0 -102
- package/src/geo/lng_lat.js +0 -165
- package/src/geo/lng_lat_bounds.js +0 -267
- package/src/geo/mercator_coordinate.js +0 -153
- package/src/geo/transform.js +0 -864
- package/src/gl/color_mode.js +0 -34
- package/src/gl/context.js +0 -298
- package/src/gl/cull_face_mode.js +0 -26
- package/src/gl/depth_mode.js +0 -29
- package/src/gl/framebuffer.js +0 -44
- package/src/gl/index_buffer.js +0 -55
- package/src/gl/stencil_mode.js +0 -30
- package/src/gl/types.js +0 -84
- package/src/gl/value.js +0 -520
- package/src/gl/vertex_buffer.js +0 -119
- package/src/index.js +0 -201
- package/src/render/draw_background.js +0 -57
- package/src/render/draw_circle.js +0 -113
- package/src/render/draw_collision_debug.js +0 -49
- package/src/render/draw_custom.js +0 -49
- package/src/render/draw_debug.js +0 -127
- package/src/render/draw_fill.js +0 -126
- package/src/render/draw_fill_extrusion.js +0 -96
- package/src/render/draw_heatmap.js +0 -140
- package/src/render/draw_hillshade.js +0 -108
- package/src/render/draw_line.js +0 -98
- package/src/render/draw_raster.js +0 -125
- package/src/render/draw_symbol.js +0 -394
- package/src/render/glyph_atlas.js +0 -71
- package/src/render/glyph_manager.js +0 -182
- package/src/render/image_atlas.js +0 -149
- package/src/render/image_manager.js +0 -306
- package/src/render/line_atlas.js +0 -210
- package/src/render/painter.js +0 -653
- package/src/render/program/background_program.js +0 -103
- package/src/render/program/circle_program.js +0 -69
- package/src/render/program/clipping_mask_program.js +0 -20
- package/src/render/program/collision_program.js +0 -49
- package/src/render/program/debug_program.js +0 -35
- package/src/render/program/fill_extrusion_program.js +0 -122
- package/src/render/program/fill_program.js +0 -126
- package/src/render/program/heatmap_program.js +0 -83
- package/src/render/program/hillshade_program.js +0 -122
- package/src/render/program/line_program.js +0 -207
- package/src/render/program/pattern.js +0 -102
- package/src/render/program/program_uniforms.js +0 -42
- package/src/render/program/raster_program.js +0 -92
- package/src/render/program/symbol_program.js +0 -224
- package/src/render/program.js +0 -168
- package/src/render/texture.js +0 -122
- package/src/render/uniform_binding.js +0 -147
- package/src/render/vertex_array_object.js +0 -163
- package/src/shaders/README.md +0 -42
- package/src/shaders/_prelude.fragment.glsl +0 -17
- package/src/shaders/_prelude.vertex.glsl +0 -73
- package/src/shaders/background.fragment.glsl +0 -10
- package/src/shaders/background.vertex.glsl +0 -7
- package/src/shaders/background_pattern.fragment.glsl +0 -28
- package/src/shaders/background_pattern.vertex.glsl +0 -20
- package/src/shaders/circle.fragment.glsl +0 -39
- package/src/shaders/circle.vertex.glsl +0 -64
- package/src/shaders/clipping_mask.fragment.glsl +0 -3
- package/src/shaders/clipping_mask.vertex.glsl +0 -7
- package/src/shaders/collision_box.fragment.glsl +0 -21
- package/src/shaders/collision_box.vertex.glsl +0 -27
- package/src/shaders/collision_circle.fragment.glsl +0 -34
- package/src/shaders/collision_circle.vertex.glsl +0 -36
- package/src/shaders/debug.fragment.glsl +0 -9
- package/src/shaders/debug.vertex.glsl +0 -12
- package/src/shaders/encode_attribute.js +0 -17
- package/src/shaders/fill.fragment.glsl +0 -13
- package/src/shaders/fill.vertex.glsl +0 -13
- package/src/shaders/fill_extrusion.fragment.glsl +0 -9
- package/src/shaders/fill_extrusion.vertex.glsl +0 -66
- package/src/shaders/fill_extrusion_pattern.fragment.glsl +0 -45
- package/src/shaders/fill_extrusion_pattern.vertex.glsl +0 -79
- package/src/shaders/fill_outline.fragment.glsl +0 -17
- package/src/shaders/fill_outline.vertex.glsl +0 -17
- package/src/shaders/fill_outline_pattern.fragment.glsl +0 -43
- package/src/shaders/fill_outline_pattern.vertex.glsl +0 -44
- package/src/shaders/fill_pattern.fragment.glsl +0 -36
- package/src/shaders/fill_pattern.vertex.glsl +0 -39
- package/src/shaders/heatmap.fragment.glsl +0 -22
- package/src/shaders/heatmap.vertex.glsl +0 -54
- package/src/shaders/heatmap_texture.fragment.glsl +0 -14
- package/src/shaders/heatmap_texture.vertex.glsl +0 -11
- package/src/shaders/hillshade.fragment.glsl +0 -52
- package/src/shaders/hillshade.vertex.glsl +0 -11
- package/src/shaders/hillshade_prepare.fragment.glsl +0 -74
- package/src/shaders/hillshade_prepare.vertex.glsl +0 -15
- package/src/shaders/index.js +0 -20
- package/src/shaders/line.fragment.glsl +0 -30
- package/src/shaders/line.vertex.glsl +0 -85
- package/src/shaders/line_gradient.fragment.glsl +0 -34
- package/src/shaders/line_gradient.vertex.glsl +0 -87
- package/src/shaders/line_pattern.fragment.glsl +0 -74
- package/src/shaders/line_pattern.vertex.glsl +0 -99
- package/src/shaders/line_sdf.fragment.glsl +0 -45
- package/src/shaders/line_sdf.vertex.glsl +0 -98
- package/src/shaders/raster.fragment.glsl +0 -52
- package/src/shaders/raster.vertex.glsl +0 -21
- package/src/shaders/shaders.js +0 -180
- package/src/shaders/symbol_icon.fragment.glsl +0 -17
- package/src/shaders/symbol_icon.vertex.glsl +0 -94
- package/src/shaders/symbol_sdf.fragment.glsl +0 -52
- package/src/shaders/symbol_sdf.vertex.glsl +0 -115
- package/src/shaders/symbol_text_and_icon.fragment.glsl +0 -68
- package/src/shaders/symbol_text_and_icon.vertex.glsl +0 -116
- package/src/source/canvas_source.js +0 -238
- package/src/source/geojson_helper.js +0 -92
- package/src/source/geojson_source.js +0 -374
- package/src/source/geojson_worker_source.js +0 -357
- package/src/source/geojson_wrapper.js +0 -94
- package/src/source/image_source.js +0 -307
- package/src/source/load_tilejson.js +0 -39
- package/src/source/mbtiles_source.js +0 -115
- package/src/source/offline_database.js +0 -61
- package/src/source/offline_database_root.js +0 -62
- package/src/source/pixels_to_tile_units.js +0 -21
- package/src/source/query_features.js +0 -208
- package/src/source/raster_dem_tile_source.js +0 -138
- package/src/source/raster_dem_tile_worker_source.js +0 -62
- package/src/source/raster_tile_offline_source.js +0 -136
- package/src/source/raster_tile_source.js +0 -177
- package/src/source/rtl_text_plugin.js +0 -138
- package/src/source/source.js +0 -137
- package/src/source/source_cache.js +0 -957
- package/src/source/source_state.js +0 -159
- package/src/source/tile.js +0 -465
- package/src/source/tile_bounds.js +0 -38
- package/src/source/tile_cache.js +0 -212
- package/src/source/tile_id.js +0 -402
- package/src/source/vector_tile_source.js +0 -192
- package/src/source/vector_tile_worker_source.js +0 -216
- package/src/source/video_source.js +0 -203
- package/src/source/worker.js +0 -237
- package/src/source/worker_source.js +0 -106
- package/src/source/worker_tile.js +0 -224
- package/src/style/create_style_layer.js +0 -36
- package/src/style/evaluation_parameters.js +0 -62
- package/src/style/light.js +0 -130
- package/src/style/load_glyph_range.js +0 -38
- package/src/style/load_sprite.js +0 -67
- package/src/style/parse_glyph_pbf.js +0 -44
- package/src/style/pauseable_placement.js +0 -132
- package/src/style/properties.js +0 -753
- package/src/style/query_utils.js +0 -43
- package/src/style/style.js +0 -1361
- package/src/style/style_glyph.js +0 -17
- package/src/style/style_image.js +0 -137
- package/src/style/style_layer/background_style_layer.js +0 -21
- package/src/style/style_layer/background_style_layer_properties.js +0 -40
- package/src/style/style_layer/circle_style_layer.js +0 -98
- package/src/style/style_layer/circle_style_layer_properties.js +0 -63
- package/src/style/style_layer/custom_style_layer.js +0 -223
- package/src/style/style_layer/fill_extrusion_style_layer.js +0 -224
- package/src/style/style_layer/fill_extrusion_style_layer_properties.js +0 -50
- package/src/style/style_layer/fill_style_layer.js +0 -67
- package/src/style/style_layer/fill_style_layer_properties.js +0 -55
- package/src/style/style_layer/heatmap_style_layer.js +0 -69
- package/src/style/style_layer/heatmap_style_layer_properties.js +0 -44
- package/src/style/style_layer/hillshade_style_layer.js +0 -25
- package/src/style/style_layer/hillshade_style_layer_properties.js +0 -46
- package/src/style/style_layer/layer_properties.js.ejs +0 -69
- package/src/style/style_layer/line_style_layer.js +0 -151
- package/src/style/style_layer/line_style_layer_properties.js +0 -71
- package/src/style/style_layer/raster_style_layer.js +0 -21
- package/src/style/style_layer/raster_style_layer_properties.js +0 -50
- package/src/style/style_layer/symbol_style_layer.js +0 -190
- package/src/style/style_layer/symbol_style_layer_properties.js +0 -153
- package/src/style/style_layer/typed_style_layer.js +0 -17
- package/src/style/style_layer.js +0 -281
- package/src/style/style_layer_index.js +0 -80
- package/src/style/validate_style.js +0 -42
- package/src/style/zoom_history.js +0 -44
- package/src/style-spec/.eslintrc +0 -5
- package/src/style-spec/CHANGELOG.md +0 -438
- package/src/style-spec/README.md +0 -59
- package/src/style-spec/bin/gl-style-composite +0 -9
- package/src/style-spec/bin/gl-style-format +0 -22
- package/src/style-spec/bin/gl-style-migrate +0 -9
- package/src/style-spec/bin/gl-style-validate +0 -50
- package/src/style-spec/composite.js +0 -50
- package/src/style-spec/declass.js +0 -42
- package/src/style-spec/deref.js +0 -52
- package/src/style-spec/diff.js +0 -393
- package/src/style-spec/dist/.gitkeep +0 -0
- package/src/style-spec/empty.js +0 -29
- package/src/style-spec/error/parsing_error.js +0 -16
- package/src/style-spec/error/validation_error.js +0 -18
- package/src/style-spec/expression/compound_expression.js +0 -162
- package/src/style-spec/expression/definitions/assertion.js +0 -130
- package/src/style-spec/expression/definitions/at.js +0 -70
- package/src/style-spec/expression/definitions/case.js +0 -85
- package/src/style-spec/expression/definitions/coalesce.js +0 -93
- package/src/style-spec/expression/definitions/coercion.js +0 -133
- package/src/style-spec/expression/definitions/collator.js +0 -78
- package/src/style-spec/expression/definitions/comparison.js +0 -184
- package/src/style-spec/expression/definitions/format.js +0 -144
- package/src/style-spec/expression/definitions/format_section_override.js +0 -54
- package/src/style-spec/expression/definitions/image.js +0 -52
- package/src/style-spec/expression/definitions/in.js +0 -92
- package/src/style-spec/expression/definitions/index.js +0 -561
- package/src/style-spec/expression/definitions/interpolate.js +0 -267
- package/src/style-spec/expression/definitions/length.js +0 -61
- package/src/style-spec/expression/definitions/let.js +0 -72
- package/src/style-spec/expression/definitions/literal.js +0 -77
- package/src/style-spec/expression/definitions/match.js +0 -158
- package/src/style-spec/expression/definitions/number_format.js +0 -142
- package/src/style-spec/expression/definitions/step.js +0 -120
- package/src/style-spec/expression/definitions/var.js +0 -46
- package/src/style-spec/expression/definitions/within.js +0 -333
- package/src/style-spec/expression/evaluation_context.js +0 -59
- package/src/style-spec/expression/expression.js +0 -27
- package/src/style-spec/expression/index.js +0 -392
- package/src/style-spec/expression/is_constant.js +0 -59
- package/src/style-spec/expression/parsing_context.js +0 -233
- package/src/style-spec/expression/parsing_error.js +0 -13
- package/src/style-spec/expression/runtime_error.js +0 -17
- package/src/style-spec/expression/scope.js +0 -36
- package/src/style-spec/expression/stops.js +0 -39
- package/src/style-spec/expression/types/collator.js +0 -61
- package/src/style-spec/expression/types/formatted.js +0 -73
- package/src/style-spec/expression/types/resolved_image.js +0 -29
- package/src/style-spec/expression/types.js +0 -106
- package/src/style-spec/expression/values.js +0 -123
- package/src/style-spec/feature_filter/README.md +0 -55
- package/src/style-spec/feature_filter/convert.js +0 -208
- package/src/style-spec/feature_filter/index.js +0 -165
- package/src/style-spec/format.js +0 -51
- package/src/style-spec/function/convert.js +0 -254
- package/src/style-spec/function/index.js +0 -262
- package/src/style-spec/group_by_layout.js +0 -75
- package/src/style-spec/migrate/expressions.js +0 -39
- package/src/style-spec/migrate/v8.js +0 -203
- package/src/style-spec/migrate/v9.js +0 -26
- package/src/style-spec/migrate.js +0 -36
- package/src/style-spec/package.json +0 -41
- package/src/style-spec/read_style.js +0 -14
- package/src/style-spec/reference/latest.js +0 -3
- package/src/style-spec/reference/v8.json +0 -5808
- package/src/style-spec/rollup.config.js +0 -45
- package/src/style-spec/style-spec.js +0 -122
- package/src/style-spec/types.js +0 -438
- package/src/style-spec/util/color.js +0 -95
- package/src/style-spec/util/color_spaces.js +0 -139
- package/src/style-spec/util/deep_equal.js +0 -28
- package/src/style-spec/util/extend.js +0 -10
- package/src/style-spec/util/get_type.js +0 -17
- package/src/style-spec/util/interpolate.js +0 -22
- package/src/style-spec/util/properties.js +0 -15
- package/src/style-spec/util/ref_properties.js +0 -2
- package/src/style-spec/util/result.js +0 -19
- package/src/style-spec/util/unbundle_jsonlint.js +0 -24
- package/src/style-spec/validate/latest.js +0 -11
- package/src/style-spec/validate/validate.js +0 -75
- package/src/style-spec/validate/validate_array.js +0 -52
- package/src/style-spec/validate/validate_boolean.js +0 -15
- package/src/style-spec/validate/validate_color.js +0 -20
- package/src/style-spec/validate/validate_constants.js +0 -13
- package/src/style-spec/validate/validate_enum.js +0 -21
- package/src/style-spec/validate/validate_expression.js +0 -43
- package/src/style-spec/validate/validate_filter.js +0 -111
- package/src/style-spec/validate/validate_formatted.js +0 -11
- package/src/style-spec/validate/validate_function.js +0 -207
- package/src/style-spec/validate/validate_glyphs_url.js +0 -21
- package/src/style-spec/validate/validate_image.js +0 -11
- package/src/style-spec/validate/validate_layer.js +0 -134
- package/src/style-spec/validate/validate_layout_property.js +0 -6
- package/src/style-spec/validate/validate_light.js +0 -47
- package/src/style-spec/validate/validate_number.js +0 -29
- package/src/style-spec/validate/validate_object.js +0 -61
- package/src/style-spec/validate/validate_paint_property.js +0 -6
- package/src/style-spec/validate/validate_property.js +0 -64
- package/src/style-spec/validate/validate_source.js +0 -111
- package/src/style-spec/validate/validate_string.js +0 -15
- package/src/style-spec/validate_mapbox_api_supported.js +0 -171
- package/src/style-spec/validate_style.js +0 -39
- package/src/style-spec/validate_style.min.js +0 -78
- package/src/style-spec/visit.js +0 -77
- package/src/symbol/anchor.js +0 -26
- package/src/symbol/check_max_angle.js +0 -81
- package/src/symbol/clip_line.js +0 -71
- package/src/symbol/collision_feature.js +0 -217
- package/src/symbol/collision_index.js +0 -372
- package/src/symbol/cross_tile_symbol_index.js +0 -301
- package/src/symbol/get_anchors.js +0 -167
- package/src/symbol/grid_index.js +0 -335
- package/src/symbol/mergelines.js +0 -82
- package/src/symbol/one_em.js +0 -4
- package/src/symbol/opacity_state.js +0 -27
- package/src/symbol/placement.js +0 -1062
- package/src/symbol/projection.js +0 -450
- package/src/symbol/quads.js +0 -334
- package/src/symbol/shaping.js +0 -816
- package/src/symbol/symbol_layout.js +0 -772
- package/src/symbol/symbol_size.js +0 -113
- package/src/symbol/transform_text.js +0 -29
- package/src/types/callback.js +0 -17
- package/src/types/cancelable.js +0 -3
- package/src/types/tilejson.js +0 -17
- package/src/types/transferable.js +0 -3
- package/src/types/window.js +0 -172
- package/src/ui/anchor.js +0 -32
- package/src/ui/bind_handlers.js +0 -202
- package/src/ui/camera.js +0 -1152
- package/src/ui/control/attribution_control.js +0 -189
- package/src/ui/control/fps_control.js +0 -185
- package/src/ui/control/fullscreen_control.js +0 -147
- package/src/ui/control/geolocate_control.js +0 -594
- package/src/ui/control/logo_control.js +0 -92
- package/src/ui/control/navigation_control.js +0 -148
- package/src/ui/control/scale_control.js +0 -142
- package/src/ui/crs.js +0 -64
- package/src/ui/default_locale.js +0 -20
- package/src/ui/events.js +0 -806
- package/src/ui/handler/box_zoom.js +0 -175
- package/src/ui/handler/dblclick_zoom.js +0 -139
- package/src/ui/handler/drag_pan.js +0 -416
- package/src/ui/handler/drag_rotate.js +0 -378
- package/src/ui/handler/keyboard.js +0 -161
- package/src/ui/handler/scroll_zoom.js +0 -333
- package/src/ui/handler/touch_zoom_rotate.js +0 -293
- package/src/ui/hash.js +0 -147
- package/src/ui/map.js +0 -2883
- package/src/ui/marker.js +0 -607
- package/src/ui/offline_map.js +0 -91
- package/src/ui/popup.js +0 -530
- package/src/util/actor.js +0 -212
- package/src/util/ajax.js +0 -371
- package/src/util/browser/web_worker.js +0 -10
- package/src/util/browser/window.js +0 -5
- package/src/util/browser.js +0 -70
- package/src/util/classify_rings.js +0 -52
- package/src/util/color_ramp.js +0 -28
- package/src/util/config.js +0 -30
- package/src/util/debug.js +0 -12
- package/src/util/dictionary_coder.js +0 -30
- package/src/util/dispatcher.js +0 -70
- package/src/util/dom.js +0 -144
- package/src/util/evented.js +0 -174
- package/src/util/find_pole_of_inaccessibility.js +0 -129
- package/src/util/global_worker_pool.js +0 -17
- package/src/util/image.js +0 -142
- package/src/util/intersection_tests.js +0 -208
- package/src/util/is_char_in_unicode_block.js +0 -311
- package/src/util/mapbox.js +0 -486
- package/src/util/offscreen_canvas_supported.js +0 -14
- package/src/util/performance.js +0 -112
- package/src/util/primitives.js +0 -145
- package/src/util/resolve_tokens.js +0 -16
- package/src/util/script_detection.js +0 -328
- package/src/util/sku_token.js +0 -42
- package/src/util/smart_wrap.js +0 -55
- package/src/util/struct_array.js +0 -243
- package/src/util/struct_array.js.ejs +0 -112
- package/src/util/struct_array_layout.js.ejs +0 -98
- package/src/util/task_queue.js +0 -68
- package/src/util/throttle.js +0 -28
- package/src/util/throttled_invoker.js +0 -46
- package/src/util/tile_cover.js +0 -101
- package/src/util/tile_request_cache.js +0 -172
- package/src/util/util.js +0 -504
- package/src/util/vectortile_to_geojson.js +0 -54
- package/src/util/verticalize_punctuation.js +0 -114
- package/src/util/web_worker.js +0 -91
- package/src/util/web_worker_transfer.js +0 -266
- package/src/util/webp_supported.js +0 -69
- package/src/util/window.js +0 -102
- package/src/util/worker_pool.js +0 -47
|
@@ -1,159 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import {extend} from '../util/util';
|
|
4
|
-
import Tile from './tile';
|
|
5
|
-
import type {FeatureState} from '../style-spec/expression';
|
|
6
|
-
|
|
7
|
-
export type FeatureStates = {[feature_id: string]: FeatureState};
|
|
8
|
-
export type LayerFeatureStates = {[layer: string]: FeatureStates};
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* SourceFeatureState manages the state and pending changes
|
|
12
|
-
* to features in a source, separated by source layer.
|
|
13
|
-
* stateChanges and deletedStates batch all changes to the tile (updates and removes, respectively)
|
|
14
|
-
* between coalesce() events. addFeatureState() and removeFeatureState() also update their counterpart's
|
|
15
|
-
* list of changes, such that coalesce() can apply the proper state changes while agnostic to the order of operations.
|
|
16
|
-
* In deletedStates, all null's denote complete removal of state at that scope
|
|
17
|
-
* @private
|
|
18
|
-
*/
|
|
19
|
-
class SourceFeatureState {
|
|
20
|
-
state: LayerFeatureStates;
|
|
21
|
-
stateChanges: LayerFeatureStates;
|
|
22
|
-
deletedStates: {};
|
|
23
|
-
|
|
24
|
-
constructor() {
|
|
25
|
-
this.state = {};
|
|
26
|
-
this.stateChanges = {};
|
|
27
|
-
this.deletedStates = {};
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
updateState(sourceLayer: string, featureId: number | string, newState: Object) {
|
|
31
|
-
const feature = String(featureId);
|
|
32
|
-
this.stateChanges[sourceLayer] = this.stateChanges[sourceLayer] || {};
|
|
33
|
-
this.stateChanges[sourceLayer][feature] = this.stateChanges[sourceLayer][feature] || {};
|
|
34
|
-
extend(this.stateChanges[sourceLayer][feature], newState);
|
|
35
|
-
|
|
36
|
-
if (this.deletedStates[sourceLayer] === null) {
|
|
37
|
-
this.deletedStates[sourceLayer] = {};
|
|
38
|
-
for (const ft in this.state[sourceLayer]) {
|
|
39
|
-
if (ft !== feature) this.deletedStates[sourceLayer][ft] = null;
|
|
40
|
-
}
|
|
41
|
-
} else {
|
|
42
|
-
const featureDeletionQueued = this.deletedStates[sourceLayer] && this.deletedStates[sourceLayer][feature] === null;
|
|
43
|
-
if (featureDeletionQueued) {
|
|
44
|
-
this.deletedStates[sourceLayer][feature] = {};
|
|
45
|
-
for (const prop in this.state[sourceLayer][feature]) {
|
|
46
|
-
if (!newState[prop]) this.deletedStates[sourceLayer][feature][prop] = null;
|
|
47
|
-
}
|
|
48
|
-
} else {
|
|
49
|
-
for (const key in newState) {
|
|
50
|
-
const deletionInQueue = this.deletedStates[sourceLayer] && this.deletedStates[sourceLayer][feature] && this.deletedStates[sourceLayer][feature][key] === null;
|
|
51
|
-
if (deletionInQueue) delete this.deletedStates[sourceLayer][feature][key];
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
removeFeatureState(sourceLayer: string, featureId?: number | string, key?: string) {
|
|
58
|
-
const sourceLayerDeleted = this.deletedStates[sourceLayer] === null;
|
|
59
|
-
if (sourceLayerDeleted) return;
|
|
60
|
-
|
|
61
|
-
const feature = String(featureId);
|
|
62
|
-
|
|
63
|
-
this.deletedStates[sourceLayer] = this.deletedStates[sourceLayer] || {};
|
|
64
|
-
|
|
65
|
-
if (key && featureId !== undefined) {
|
|
66
|
-
if (this.deletedStates[sourceLayer][feature] !== null) {
|
|
67
|
-
this.deletedStates[sourceLayer][feature] = this.deletedStates[sourceLayer][feature] || {};
|
|
68
|
-
this.deletedStates[sourceLayer][feature][key] = null;
|
|
69
|
-
}
|
|
70
|
-
} else if (featureId !== undefined) {
|
|
71
|
-
const updateInQueue = this.stateChanges[sourceLayer] && this.stateChanges[sourceLayer][feature];
|
|
72
|
-
if (updateInQueue) {
|
|
73
|
-
this.deletedStates[sourceLayer][feature] = {};
|
|
74
|
-
for (key in this.stateChanges[sourceLayer][feature]) this.deletedStates[sourceLayer][feature][key] = null;
|
|
75
|
-
|
|
76
|
-
} else {
|
|
77
|
-
this.deletedStates[sourceLayer][feature] = null;
|
|
78
|
-
}
|
|
79
|
-
} else {
|
|
80
|
-
this.deletedStates[sourceLayer] = null;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
getState(sourceLayer: string, featureId: number | string) {
|
|
86
|
-
const feature = String(featureId);
|
|
87
|
-
const base = this.state[sourceLayer] || {};
|
|
88
|
-
const changes = this.stateChanges[sourceLayer] || {};
|
|
89
|
-
|
|
90
|
-
const reconciledState = extend({}, base[feature], changes[feature]);
|
|
91
|
-
|
|
92
|
-
//return empty object if the whole source layer is awaiting deletion
|
|
93
|
-
if (this.deletedStates[sourceLayer] === null) return {};
|
|
94
|
-
else if (this.deletedStates[sourceLayer]) {
|
|
95
|
-
const featureDeletions = this.deletedStates[sourceLayer][featureId];
|
|
96
|
-
if (featureDeletions === null) return {};
|
|
97
|
-
for (const prop in featureDeletions) delete reconciledState[prop];
|
|
98
|
-
}
|
|
99
|
-
return reconciledState;
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
initializeTileState(tile: Tile, painter: any) {
|
|
103
|
-
tile.setFeatureState(this.state, painter);
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
coalesceChanges(tiles: {[_: any]: Tile}, painter: any) {
|
|
107
|
-
//track changes with full state objects, but only for features that got modified
|
|
108
|
-
const featuresChanged: LayerFeatureStates = {};
|
|
109
|
-
|
|
110
|
-
for (const sourceLayer in this.stateChanges) {
|
|
111
|
-
this.state[sourceLayer] = this.state[sourceLayer] || {};
|
|
112
|
-
const layerStates = {};
|
|
113
|
-
for (const feature in this.stateChanges[sourceLayer]) {
|
|
114
|
-
if (!this.state[sourceLayer][feature]) this.state[sourceLayer][feature] = {};
|
|
115
|
-
extend(this.state[sourceLayer][feature], this.stateChanges[sourceLayer][feature]);
|
|
116
|
-
layerStates[feature] = this.state[sourceLayer][feature];
|
|
117
|
-
}
|
|
118
|
-
featuresChanged[sourceLayer] = layerStates;
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
for (const sourceLayer in this.deletedStates) {
|
|
122
|
-
this.state[sourceLayer] = this.state[sourceLayer] || {};
|
|
123
|
-
const layerStates = {};
|
|
124
|
-
|
|
125
|
-
if (this.deletedStates[sourceLayer] === null) {
|
|
126
|
-
for (const ft in this.state[sourceLayer]) {
|
|
127
|
-
layerStates[ft] = {};
|
|
128
|
-
this.state[sourceLayer][ft] = {};
|
|
129
|
-
}
|
|
130
|
-
} else {
|
|
131
|
-
for (const feature in this.deletedStates[sourceLayer]) {
|
|
132
|
-
const deleteWholeFeatureState = this.deletedStates[sourceLayer][feature] === null;
|
|
133
|
-
if (deleteWholeFeatureState) this.state[sourceLayer][feature] = {};
|
|
134
|
-
else {
|
|
135
|
-
for (const key of Object.keys(this.deletedStates[sourceLayer][feature])) {
|
|
136
|
-
delete this.state[sourceLayer][feature][key];
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
layerStates[feature] = this.state[sourceLayer][feature];
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
featuresChanged[sourceLayer] = featuresChanged[sourceLayer] || {};
|
|
144
|
-
extend(featuresChanged[sourceLayer], layerStates);
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
this.stateChanges = {};
|
|
148
|
-
this.deletedStates = {};
|
|
149
|
-
|
|
150
|
-
if (Object.keys(featuresChanged).length === 0) return;
|
|
151
|
-
|
|
152
|
-
for (const id in tiles) {
|
|
153
|
-
const tile = tiles[id];
|
|
154
|
-
tile.setFeatureState(featuresChanged, painter);
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
export default SourceFeatureState;
|
package/src/source/tile.js
DELETED
|
@@ -1,465 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import {uniqueId, parseCacheControl} from '../util/util';
|
|
4
|
-
import {deserialize as deserializeBucket} from '../data/bucket';
|
|
5
|
-
import FeatureIndex from '../data/feature_index';
|
|
6
|
-
import GeoJSONFeature from '../util/vectortile_to_geojson';
|
|
7
|
-
import featureFilter from '../style-spec/feature_filter';
|
|
8
|
-
import SymbolBucket from '../data/bucket/symbol_bucket';
|
|
9
|
-
import {CollisionBoxArray} from '../data/array_types';
|
|
10
|
-
import Texture from '../render/texture';
|
|
11
|
-
import browser from '../util/browser';
|
|
12
|
-
import EvaluationParameters from '../style/evaluation_parameters';
|
|
13
|
-
import SourceFeatureState from '../source/source_state';
|
|
14
|
-
import {lazyLoadRTLTextPlugin} from './rtl_text_plugin';
|
|
15
|
-
|
|
16
|
-
const CLOCK_SKEW_RETRY_TIMEOUT = 30000;
|
|
17
|
-
|
|
18
|
-
import type {Bucket} from '../data/bucket';
|
|
19
|
-
import type StyleLayer from '../style/style_layer';
|
|
20
|
-
import type {WorkerTileResult} from './worker_source';
|
|
21
|
-
import type Actor from '../util/actor';
|
|
22
|
-
import type DEMData from '../data/dem_data';
|
|
23
|
-
import type {AlphaImage} from '../util/image';
|
|
24
|
-
import type ImageAtlas from '../render/image_atlas';
|
|
25
|
-
import type ImageManager from '../render/image_manager';
|
|
26
|
-
import type Context from '../gl/context';
|
|
27
|
-
import type {OverscaledTileID} from './tile_id';
|
|
28
|
-
import type Framebuffer from '../gl/framebuffer';
|
|
29
|
-
import type Transform from '../geo/transform';
|
|
30
|
-
import type {LayerFeatureStates} from './source_state';
|
|
31
|
-
import type {Cancelable} from '../types/cancelable';
|
|
32
|
-
import type {FilterSpecification} from '../style-spec/types';
|
|
33
|
-
|
|
34
|
-
export type TileState =
|
|
35
|
-
| 'loading' // Tile data is in the process of loading.
|
|
36
|
-
| 'loaded' // Tile data has been loaded. Tile can be rendered.
|
|
37
|
-
| 'reloading' // Tile data has been loaded and is being updated. Tile can be rendered.
|
|
38
|
-
| 'unloaded' // Tile data has been deleted.
|
|
39
|
-
| 'errored' // Tile data was not loaded because of an error.
|
|
40
|
-
| 'expired'; /* Tile data was previously loaded, but has expired per its
|
|
41
|
-
* HTTP headers and is in the process of refreshing. */
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* A tile object is the combination of a Coordinate, which defines
|
|
45
|
-
* its place, as well as a unique ID and data tracking for its content
|
|
46
|
-
*
|
|
47
|
-
* @private
|
|
48
|
-
*/
|
|
49
|
-
class Tile {
|
|
50
|
-
tileID: OverscaledTileID;
|
|
51
|
-
uid: number;
|
|
52
|
-
uses: number;
|
|
53
|
-
tileSize: number;
|
|
54
|
-
buckets: {[_: string]: Bucket};
|
|
55
|
-
latestFeatureIndex: ?FeatureIndex;
|
|
56
|
-
latestRawTileData: ?ArrayBuffer;
|
|
57
|
-
imageAtlas: ?ImageAtlas;
|
|
58
|
-
imageAtlasTexture: Texture;
|
|
59
|
-
glyphAtlasImage: ?AlphaImage;
|
|
60
|
-
glyphAtlasTexture: Texture;
|
|
61
|
-
expirationTime: any;
|
|
62
|
-
expiredRequestCount: number;
|
|
63
|
-
state: TileState;
|
|
64
|
-
timeAdded: any;
|
|
65
|
-
fadeEndTime: any;
|
|
66
|
-
collisionBoxArray: ?CollisionBoxArray;
|
|
67
|
-
redoWhenDone: boolean;
|
|
68
|
-
showCollisionBoxes: boolean;
|
|
69
|
-
placementSource: any;
|
|
70
|
-
actor: ?Actor;
|
|
71
|
-
vtLayers: {[_: string]: VectorTileLayer};
|
|
72
|
-
|
|
73
|
-
neighboringTiles: ?Object;
|
|
74
|
-
dem: ?DEMData;
|
|
75
|
-
aborted: ?boolean;
|
|
76
|
-
needsHillshadePrepare: ?boolean;
|
|
77
|
-
request: ?Cancelable;
|
|
78
|
-
texture: any;
|
|
79
|
-
fbo: ?Framebuffer;
|
|
80
|
-
demTexture: ?Texture;
|
|
81
|
-
refreshedUponExpiration: boolean;
|
|
82
|
-
reloadCallback: any;
|
|
83
|
-
resourceTiming: ?Array<PerformanceResourceTiming>;
|
|
84
|
-
queryPadding: number;
|
|
85
|
-
|
|
86
|
-
symbolFadeHoldUntil: ?number;
|
|
87
|
-
hasSymbolBuckets: boolean;
|
|
88
|
-
hasRTLText: boolean;
|
|
89
|
-
dependencies: Object;
|
|
90
|
-
|
|
91
|
-
/**
|
|
92
|
-
* @param {OverscaledTileID} tileID
|
|
93
|
-
* @param size
|
|
94
|
-
* @private
|
|
95
|
-
*/
|
|
96
|
-
constructor(tileID: OverscaledTileID, size: number) {
|
|
97
|
-
this.tileID = tileID;
|
|
98
|
-
this.uid = uniqueId();
|
|
99
|
-
this.uses = 0;
|
|
100
|
-
this.tileSize = size;
|
|
101
|
-
this.buckets = {};
|
|
102
|
-
this.expirationTime = null;
|
|
103
|
-
this.queryPadding = 0;
|
|
104
|
-
this.hasSymbolBuckets = false;
|
|
105
|
-
this.hasRTLText = false;
|
|
106
|
-
this.dependencies = {};
|
|
107
|
-
|
|
108
|
-
// Counts the number of times a response was already expired when
|
|
109
|
-
// received. We're using this to add a delay when making a new request
|
|
110
|
-
// so we don't have to keep retrying immediately in case of a server
|
|
111
|
-
// serving expired tiles.
|
|
112
|
-
this.expiredRequestCount = 0;
|
|
113
|
-
|
|
114
|
-
this.state = 'loading';
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
registerFadeDuration(duration: number) {
|
|
118
|
-
const fadeEndTime = duration + this.timeAdded;
|
|
119
|
-
if (fadeEndTime < browser.now()) return;
|
|
120
|
-
if (this.fadeEndTime && fadeEndTime < this.fadeEndTime) return;
|
|
121
|
-
|
|
122
|
-
this.fadeEndTime = fadeEndTime;
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
wasRequested() {
|
|
126
|
-
return this.state === 'errored' || this.state === 'loaded' || this.state === 'reloading';
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
/**
|
|
130
|
-
* Given a data object with a 'buffers' property, load it into
|
|
131
|
-
* this tile's elementGroups and buffers properties and set loaded
|
|
132
|
-
* to true. If the data is null, like in the case of an empty
|
|
133
|
-
* GeoJSON tile, no-op but still set loaded to true.
|
|
134
|
-
* @param {Object} data
|
|
135
|
-
* @param painter
|
|
136
|
-
* @returns {undefined}
|
|
137
|
-
* @private
|
|
138
|
-
*/
|
|
139
|
-
loadVectorData(data: WorkerTileResult, painter: any, justReloaded: ?boolean) {
|
|
140
|
-
if (this.hasData()) {
|
|
141
|
-
this.unloadVectorData();
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
this.state = 'loaded';
|
|
145
|
-
|
|
146
|
-
// empty GeoJSON tile
|
|
147
|
-
if (!data) {
|
|
148
|
-
this.collisionBoxArray = new CollisionBoxArray();
|
|
149
|
-
return;
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
if (data.featureIndex) {
|
|
153
|
-
this.latestFeatureIndex = data.featureIndex;
|
|
154
|
-
if (data.rawTileData) {
|
|
155
|
-
// Only vector tiles have rawTileData, and they won't update it for
|
|
156
|
-
// 'reloadTile'
|
|
157
|
-
this.latestRawTileData = data.rawTileData;
|
|
158
|
-
this.latestFeatureIndex.rawTileData = data.rawTileData;
|
|
159
|
-
} else if (this.latestRawTileData) {
|
|
160
|
-
// If rawTileData hasn't updated, hold onto a pointer to the last
|
|
161
|
-
// one we received
|
|
162
|
-
this.latestFeatureIndex.rawTileData = this.latestRawTileData;
|
|
163
|
-
}
|
|
164
|
-
}
|
|
165
|
-
this.collisionBoxArray = data.collisionBoxArray;
|
|
166
|
-
this.buckets = deserializeBucket(data.buckets, painter.style);
|
|
167
|
-
|
|
168
|
-
this.hasSymbolBuckets = false;
|
|
169
|
-
for (const id in this.buckets) {
|
|
170
|
-
const bucket = this.buckets[id];
|
|
171
|
-
if (bucket instanceof SymbolBucket) {
|
|
172
|
-
this.hasSymbolBuckets = true;
|
|
173
|
-
if (justReloaded) {
|
|
174
|
-
bucket.justReloaded = true;
|
|
175
|
-
} else {
|
|
176
|
-
break;
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
this.hasRTLText = false;
|
|
182
|
-
if (this.hasSymbolBuckets) {
|
|
183
|
-
for (const id in this.buckets) {
|
|
184
|
-
const bucket = this.buckets[id];
|
|
185
|
-
if (bucket instanceof SymbolBucket) {
|
|
186
|
-
if (bucket.hasRTLText) {
|
|
187
|
-
this.hasRTLText = true;
|
|
188
|
-
lazyLoadRTLTextPlugin();
|
|
189
|
-
break;
|
|
190
|
-
}
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
this.queryPadding = 0;
|
|
196
|
-
for (const id in this.buckets) {
|
|
197
|
-
const bucket = this.buckets[id];
|
|
198
|
-
this.queryPadding = Math.max(this.queryPadding, painter.style.getLayer(id).queryRadius(bucket));
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
if (data.imageAtlas) {
|
|
202
|
-
this.imageAtlas = data.imageAtlas;
|
|
203
|
-
}
|
|
204
|
-
if (data.glyphAtlasImage) {
|
|
205
|
-
this.glyphAtlasImage = data.glyphAtlasImage;
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
|
|
209
|
-
/**
|
|
210
|
-
* Release any data or WebGL resources referenced by this tile.
|
|
211
|
-
* @returns {undefined}
|
|
212
|
-
* @private
|
|
213
|
-
*/
|
|
214
|
-
unloadVectorData() {
|
|
215
|
-
for (const id in this.buckets) {
|
|
216
|
-
this.buckets[id].destroy();
|
|
217
|
-
}
|
|
218
|
-
this.buckets = {};
|
|
219
|
-
|
|
220
|
-
if (this.imageAtlasTexture) {
|
|
221
|
-
this.imageAtlasTexture.destroy();
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
if (this.imageAtlas) {
|
|
225
|
-
this.imageAtlas = null;
|
|
226
|
-
}
|
|
227
|
-
|
|
228
|
-
if (this.glyphAtlasTexture) {
|
|
229
|
-
this.glyphAtlasTexture.destroy();
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
this.latestFeatureIndex = null;
|
|
233
|
-
this.state = 'unloaded';
|
|
234
|
-
}
|
|
235
|
-
|
|
236
|
-
getBucket(layer: StyleLayer) {
|
|
237
|
-
return this.buckets[layer.id];
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
upload(context: Context) {
|
|
241
|
-
for (const id in this.buckets) {
|
|
242
|
-
const bucket = this.buckets[id];
|
|
243
|
-
if (bucket.uploadPending()) {
|
|
244
|
-
bucket.upload(context);
|
|
245
|
-
}
|
|
246
|
-
}
|
|
247
|
-
|
|
248
|
-
const gl = context.gl;
|
|
249
|
-
if (this.imageAtlas && !this.imageAtlas.uploaded) {
|
|
250
|
-
this.imageAtlasTexture = new Texture(context, this.imageAtlas.image, gl.RGBA);
|
|
251
|
-
this.imageAtlas.uploaded = true;
|
|
252
|
-
}
|
|
253
|
-
|
|
254
|
-
if (this.glyphAtlasImage) {
|
|
255
|
-
this.glyphAtlasTexture = new Texture(context, this.glyphAtlasImage, gl.ALPHA);
|
|
256
|
-
this.glyphAtlasImage = null;
|
|
257
|
-
}
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
prepare(imageManager: ImageManager) {
|
|
261
|
-
if (this.imageAtlas) {
|
|
262
|
-
this.imageAtlas.patchUpdatedImages(imageManager, this.imageAtlasTexture);
|
|
263
|
-
}
|
|
264
|
-
}
|
|
265
|
-
|
|
266
|
-
/**
|
|
267
|
-
* @description Queries non-symbol features rendered for this tile.
|
|
268
|
-
* Symbol features are queried globally
|
|
269
|
-
* @param {*} layers ["全国地化2"]
|
|
270
|
-
* @param {*} serializedLayers ["全国地化2"]
|
|
271
|
-
* @param {*} sourceFeatureState deletedStates: {} state: {} stateChanges: {}
|
|
272
|
-
* @param {*} queryGeometry [{x: 6568.010860493857, y: 1130.695492456906}]
|
|
273
|
-
* @param {*} cameraQueryGeometry [{x: 6568.010860493857, y: 1130.695492456906}]
|
|
274
|
-
* @param {*} scale 1.4433593545325887
|
|
275
|
-
* @param {*} params {availableImages: [sprite-xx-11,...], layers: ["全国地化2"]}
|
|
276
|
-
* @param {*} transform
|
|
277
|
-
* @param {*} maxPitchScaleFactor 1
|
|
278
|
-
* @param {*} pixelPosMatrix [4 * 4 vectors matrix]
|
|
279
|
-
*/
|
|
280
|
-
queryRenderedFeatures(layers: {[_: string]: StyleLayer},
|
|
281
|
-
serializedLayers: {[string]: Object},
|
|
282
|
-
sourceFeatureState: SourceFeatureState,
|
|
283
|
-
queryGeometry: Array<Point>,
|
|
284
|
-
cameraQueryGeometry: Array<Point>,
|
|
285
|
-
scale: number,
|
|
286
|
-
params: { filter: FilterSpecification, layers: Array<string>, availableImages: Array<string> },
|
|
287
|
-
transform: Transform,
|
|
288
|
-
maxPitchScaleFactor: number,
|
|
289
|
-
pixelPosMatrix: Float32Array): {[_: string]: Array<{ featureIndex: number, feature: GeoJSONFeature }>} {
|
|
290
|
-
if (!this.latestFeatureIndex || !this.latestFeatureIndex.rawTileData)
|
|
291
|
-
return {};
|
|
292
|
-
|
|
293
|
-
return this.latestFeatureIndex.query({
|
|
294
|
-
queryGeometry,
|
|
295
|
-
cameraQueryGeometry,
|
|
296
|
-
scale,
|
|
297
|
-
tileSize: this.tileSize,
|
|
298
|
-
pixelPosMatrix,
|
|
299
|
-
transform,
|
|
300
|
-
params,
|
|
301
|
-
queryPadding: this.queryPadding * maxPitchScaleFactor
|
|
302
|
-
}, layers, serializedLayers, sourceFeatureState);
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
querySourceFeatures(result: Array<GeoJSONFeature>, params: any) {
|
|
306
|
-
const featureIndex = this.latestFeatureIndex;
|
|
307
|
-
if (!featureIndex || !featureIndex.rawTileData) return;
|
|
308
|
-
|
|
309
|
-
const vtLayers = featureIndex.loadVTLayers();
|
|
310
|
-
|
|
311
|
-
const sourceLayer = params ? params.sourceLayer : '';
|
|
312
|
-
const layer = vtLayers._geojsonTileLayer || vtLayers[sourceLayer];
|
|
313
|
-
|
|
314
|
-
if (!layer) return;
|
|
315
|
-
|
|
316
|
-
const filter = featureFilter(params && params.filter);
|
|
317
|
-
const {z, x, y} = this.tileID.canonical;
|
|
318
|
-
const coord = {z, x, y};
|
|
319
|
-
|
|
320
|
-
for (let i = 0; i < layer.length; i++) {
|
|
321
|
-
const feature = layer.feature(i);
|
|
322
|
-
if (filter.filter(new EvaluationParameters(this.tileID.overscaledZ), feature)) {
|
|
323
|
-
const id = featureIndex.getId(feature, sourceLayer);
|
|
324
|
-
const geojsonFeature = new GeoJSONFeature(feature, z, x, y, id);
|
|
325
|
-
(geojsonFeature: any).tile = coord;
|
|
326
|
-
result.push(geojsonFeature);
|
|
327
|
-
}
|
|
328
|
-
}
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
hasData() {
|
|
332
|
-
return this.state === 'loaded' || this.state === 'reloading' || this.state === 'expired';
|
|
333
|
-
}
|
|
334
|
-
|
|
335
|
-
patternsLoaded() {
|
|
336
|
-
return this.imageAtlas && !!Object.keys(this.imageAtlas.patternPositions).length;
|
|
337
|
-
}
|
|
338
|
-
|
|
339
|
-
setExpiryData(data: any) {
|
|
340
|
-
const prior = this.expirationTime;
|
|
341
|
-
|
|
342
|
-
if (data.cacheControl) {
|
|
343
|
-
const parsedCC = parseCacheControl(data.cacheControl);
|
|
344
|
-
if (parsedCC['max-age']) this.expirationTime = Date.now() + parsedCC['max-age'] * 1000;
|
|
345
|
-
} else if (data.expires) {
|
|
346
|
-
this.expirationTime = new Date(data.expires).getTime();
|
|
347
|
-
}
|
|
348
|
-
|
|
349
|
-
if (this.expirationTime) {
|
|
350
|
-
const now = Date.now();
|
|
351
|
-
let isExpired = false;
|
|
352
|
-
|
|
353
|
-
if (this.expirationTime > now) {
|
|
354
|
-
isExpired = false;
|
|
355
|
-
} else if (!prior) {
|
|
356
|
-
isExpired = true;
|
|
357
|
-
} else if (this.expirationTime < prior) {
|
|
358
|
-
// Expiring date is going backwards:
|
|
359
|
-
// fall back to exponential backoff
|
|
360
|
-
isExpired = true;
|
|
361
|
-
|
|
362
|
-
} else {
|
|
363
|
-
const delta = this.expirationTime - prior;
|
|
364
|
-
|
|
365
|
-
if (!delta) {
|
|
366
|
-
// Server is serving the same expired resource over and over: fall
|
|
367
|
-
// back to exponential backoff.
|
|
368
|
-
isExpired = true;
|
|
369
|
-
|
|
370
|
-
} else {
|
|
371
|
-
// Assume that either the client or the server clock is wrong and
|
|
372
|
-
// try to interpolate a valid expiration date (from the client POV)
|
|
373
|
-
// observing a minimum timeout.
|
|
374
|
-
this.expirationTime = now + Math.max(delta, CLOCK_SKEW_RETRY_TIMEOUT);
|
|
375
|
-
|
|
376
|
-
}
|
|
377
|
-
}
|
|
378
|
-
|
|
379
|
-
if (isExpired) {
|
|
380
|
-
this.expiredRequestCount++;
|
|
381
|
-
this.state = 'expired';
|
|
382
|
-
} else {
|
|
383
|
-
this.expiredRequestCount = 0;
|
|
384
|
-
}
|
|
385
|
-
}
|
|
386
|
-
}
|
|
387
|
-
|
|
388
|
-
getExpiryTimeout() {
|
|
389
|
-
if (this.expirationTime) {
|
|
390
|
-
if (this.expiredRequestCount) {
|
|
391
|
-
return 1000 * (1 << Math.min(this.expiredRequestCount - 1, 31));
|
|
392
|
-
} else {
|
|
393
|
-
// Max value for `setTimeout` implementations is a 32 bit integer; cap this accordingly
|
|
394
|
-
return Math.min(this.expirationTime - new Date().getTime(), Math.pow(2, 31) - 1);
|
|
395
|
-
}
|
|
396
|
-
}
|
|
397
|
-
}
|
|
398
|
-
|
|
399
|
-
setFeatureState(states: LayerFeatureStates, painter: any) {
|
|
400
|
-
if (!this.latestFeatureIndex ||
|
|
401
|
-
!this.latestFeatureIndex.rawTileData ||
|
|
402
|
-
Object.keys(states).length === 0) {
|
|
403
|
-
return;
|
|
404
|
-
}
|
|
405
|
-
|
|
406
|
-
const vtLayers = this.latestFeatureIndex.loadVTLayers();
|
|
407
|
-
|
|
408
|
-
for (const id in this.buckets) {
|
|
409
|
-
if (!painter.style.hasLayer(id)) continue;
|
|
410
|
-
|
|
411
|
-
const bucket = this.buckets[id];
|
|
412
|
-
// Buckets are grouped by common source-layer
|
|
413
|
-
const sourceLayerId = bucket.layers[0]['sourceLayer'] || '_geojsonTileLayer';
|
|
414
|
-
const sourceLayer = vtLayers[sourceLayerId];
|
|
415
|
-
const sourceLayerStates = states[sourceLayerId];
|
|
416
|
-
if (!sourceLayer || !sourceLayerStates || Object.keys(sourceLayerStates).length === 0) continue;
|
|
417
|
-
|
|
418
|
-
bucket.update(sourceLayerStates, sourceLayer, this.imageAtlas && this.imageAtlas.patternPositions || {});
|
|
419
|
-
const layer = painter && painter.style && painter.style.getLayer(id);
|
|
420
|
-
if (layer && layer.paint) {
|
|
421
|
-
this.queryPadding = Math.max(this.queryPadding, layer.queryRadius(bucket));
|
|
422
|
-
}
|
|
423
|
-
}
|
|
424
|
-
}
|
|
425
|
-
|
|
426
|
-
holdingForFade(): boolean {
|
|
427
|
-
return this.symbolFadeHoldUntil !== undefined;
|
|
428
|
-
}
|
|
429
|
-
|
|
430
|
-
symbolFadeFinished(): boolean {
|
|
431
|
-
return !this.symbolFadeHoldUntil || this.symbolFadeHoldUntil < browser.now();
|
|
432
|
-
}
|
|
433
|
-
|
|
434
|
-
clearFadeHold() {
|
|
435
|
-
this.symbolFadeHoldUntil = undefined;
|
|
436
|
-
}
|
|
437
|
-
|
|
438
|
-
setHoldDuration(duration: number) {
|
|
439
|
-
this.symbolFadeHoldUntil = browser.now() + duration;
|
|
440
|
-
}
|
|
441
|
-
|
|
442
|
-
setDependencies(namespace: string, dependencies: Array<string>) {
|
|
443
|
-
const index = {};
|
|
444
|
-
for (const dep of dependencies) {
|
|
445
|
-
index[dep] = true;
|
|
446
|
-
}
|
|
447
|
-
this.dependencies[namespace] = index;
|
|
448
|
-
}
|
|
449
|
-
|
|
450
|
-
hasDependency(namespaces: Array<string>, keys: Array<string>) {
|
|
451
|
-
for (const namespace of namespaces) {
|
|
452
|
-
const dependencies = this.dependencies[namespace];
|
|
453
|
-
if (dependencies) {
|
|
454
|
-
for (const key of keys) {
|
|
455
|
-
if (dependencies[key]) {
|
|
456
|
-
return true;
|
|
457
|
-
}
|
|
458
|
-
}
|
|
459
|
-
}
|
|
460
|
-
}
|
|
461
|
-
return false;
|
|
462
|
-
}
|
|
463
|
-
}
|
|
464
|
-
|
|
465
|
-
export default Tile;
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import LngLatBounds from '../geo/lng_lat_bounds';
|
|
4
|
-
import {mercatorXfromLng, mercatorYfromLat} from '../geo/mercator_coordinate';
|
|
5
|
-
|
|
6
|
-
import type {CanonicalTileID} from './tile_id';
|
|
7
|
-
|
|
8
|
-
class TileBounds {
|
|
9
|
-
bounds: LngLatBounds;
|
|
10
|
-
minzoom: number;
|
|
11
|
-
maxzoom: number;
|
|
12
|
-
|
|
13
|
-
constructor(bounds: [number, number, number, number], minzoom: ?number, maxzoom: ?number) {
|
|
14
|
-
this.bounds = LngLatBounds.convert(this.validateBounds(bounds));
|
|
15
|
-
this.minzoom = minzoom || 0;
|
|
16
|
-
this.maxzoom = maxzoom || 24;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
validateBounds(bounds: [number, number, number, number]) {
|
|
20
|
-
// make sure the bounds property contains valid longitude and latitudes
|
|
21
|
-
if (!Array.isArray(bounds) || bounds.length !== 4) return [-180, -90, 180, 90];
|
|
22
|
-
return [Math.max(-180, bounds[0]), Math.max(-90, bounds[1]), Math.min(180, bounds[2]), Math.min(90, bounds[3])];
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
contains(tileID: CanonicalTileID) {
|
|
26
|
-
const worldSize = Math.pow(2, tileID.z);
|
|
27
|
-
const level = {
|
|
28
|
-
minX: Math.floor(mercatorXfromLng(this.bounds.getWest()) * worldSize),
|
|
29
|
-
minY: Math.floor(mercatorYfromLat(this.bounds.getNorth()) * worldSize),
|
|
30
|
-
maxX: Math.ceil(mercatorXfromLng(this.bounds.getEast()) * worldSize),
|
|
31
|
-
maxY: Math.ceil(mercatorYfromLat(this.bounds.getSouth()) * worldSize)
|
|
32
|
-
};
|
|
33
|
-
const hit = tileID.x >= level.minX && tileID.x < level.maxX && tileID.y >= level.minY && tileID.y < level.maxY;
|
|
34
|
-
return hit;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
export default TileBounds;
|