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