@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
package/src/render/draw_fill.js
DELETED
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import Color from '../style-spec/util/color';
|
|
4
|
-
import DepthMode from '../gl/depth_mode';
|
|
5
|
-
import CullFaceMode from '../gl/cull_face_mode';
|
|
6
|
-
import {
|
|
7
|
-
fillUniformValues,
|
|
8
|
-
fillPatternUniformValues,
|
|
9
|
-
fillOutlineUniformValues,
|
|
10
|
-
fillOutlinePatternUniformValues
|
|
11
|
-
} from './program/fill_program';
|
|
12
|
-
|
|
13
|
-
import type Painter from './painter';
|
|
14
|
-
import type SourceCache from '../source/source_cache';
|
|
15
|
-
import type FillStyleLayer from '../style/style_layer/fill_style_layer';
|
|
16
|
-
import type FillBucket from '../data/bucket/fill_bucket';
|
|
17
|
-
import type {OverscaledTileID} from '../source/tile_id';
|
|
18
|
-
|
|
19
|
-
export default drawFill;
|
|
20
|
-
|
|
21
|
-
function drawFill(painter: Painter, sourceCache: SourceCache, layer: FillStyleLayer, coords: Array<OverscaledTileID>) {
|
|
22
|
-
const color = layer.paint.get('fill-color');
|
|
23
|
-
const opacity = layer.paint.get('fill-opacity');
|
|
24
|
-
|
|
25
|
-
// console.log('drawFill', painter, sourceCache, layer, coords);
|
|
26
|
-
|
|
27
|
-
if (opacity.constantOr(1) === 0) {
|
|
28
|
-
return;
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
const colorMode = painter.colorModeForRenderPass();
|
|
32
|
-
|
|
33
|
-
const pattern = layer.paint.get('fill-pattern');
|
|
34
|
-
const pass = painter.opaquePassEnabledForLayer() &&
|
|
35
|
-
(!pattern.constantOr((1: any)) &&
|
|
36
|
-
color.constantOr(Color.transparent).a === 1 &&
|
|
37
|
-
opacity.constantOr(0) === 1) ? 'opaque' : 'translucent';
|
|
38
|
-
|
|
39
|
-
// Draw fill
|
|
40
|
-
if (painter.renderPass === pass) {
|
|
41
|
-
const depthMode = painter.depthModeForSublayer(
|
|
42
|
-
1, painter.renderPass === 'opaque' ? DepthMode.ReadWrite : DepthMode.ReadOnly);
|
|
43
|
-
drawFillTiles(painter, sourceCache, layer, coords, depthMode, colorMode, false);
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
// Draw stroke
|
|
47
|
-
if (painter.renderPass === 'translucent' && layer.paint.get('fill-antialias')) {
|
|
48
|
-
|
|
49
|
-
// If we defined a different color for the fill outline, we are
|
|
50
|
-
// going to ignore the bits in 0x07 and just care about the global
|
|
51
|
-
// clipping mask.
|
|
52
|
-
// Otherwise, we only want to drawFill the antialiased parts that are
|
|
53
|
-
// *outside* the current shape. This is important in case the fill
|
|
54
|
-
// or stroke color is translucent. If we wouldn't clip to outside
|
|
55
|
-
// the current shape, some pixels from the outline stroke overlapped
|
|
56
|
-
// the (non-antialiased) fill.
|
|
57
|
-
const depthMode = painter.depthModeForSublayer(
|
|
58
|
-
layer.getPaintProperty('fill-outline-color') ? 2 : 0, DepthMode.ReadOnly);
|
|
59
|
-
drawFillTiles(painter, sourceCache, layer, coords, depthMode, colorMode, true);
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
function drawFillTiles(painter, sourceCache, layer, coords, depthMode, colorMode, isOutline) {
|
|
64
|
-
const gl = painter.context.gl;
|
|
65
|
-
|
|
66
|
-
const patternProperty = layer.paint.get('fill-pattern');
|
|
67
|
-
const image = patternProperty && patternProperty.constantOr((1: any));
|
|
68
|
-
const crossfade = layer.getCrossfadeParameters();
|
|
69
|
-
let drawMode, programName, uniformValues, indexBuffer, segments;
|
|
70
|
-
|
|
71
|
-
if (!isOutline) {
|
|
72
|
-
programName = image ? 'fillPattern' : 'fill';
|
|
73
|
-
drawMode = gl.TRIANGLES;
|
|
74
|
-
} else {
|
|
75
|
-
programName = image && !layer.getPaintProperty('fill-outline-color') ? 'fillOutlinePattern' : 'fillOutline';
|
|
76
|
-
drawMode = gl.LINES;
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
for (const coord of coords) {
|
|
80
|
-
const tile = sourceCache.getTile(coord);
|
|
81
|
-
if (image && !tile.patternsLoaded()) continue;
|
|
82
|
-
|
|
83
|
-
const bucket: ?FillBucket = (tile.getBucket(layer): any);
|
|
84
|
-
if (!bucket) continue;
|
|
85
|
-
|
|
86
|
-
const programConfiguration = bucket.programConfigurations.get(layer.id);
|
|
87
|
-
const program = painter.useProgram(programName, programConfiguration);
|
|
88
|
-
|
|
89
|
-
if (image) {
|
|
90
|
-
painter.context.activeTexture.set(gl.TEXTURE0);
|
|
91
|
-
tile.imageAtlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);
|
|
92
|
-
programConfiguration.updatePaintBuffers(crossfade);
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
const constantPattern = patternProperty.constantOr(null);
|
|
96
|
-
if (constantPattern && tile.imageAtlas) {
|
|
97
|
-
const atlas = tile.imageAtlas;
|
|
98
|
-
const posTo = atlas.patternPositions[constantPattern.to.toString()];
|
|
99
|
-
const posFrom = atlas.patternPositions[constantPattern.from.toString()];
|
|
100
|
-
if (posTo && posFrom) programConfiguration.setConstantPatternPositions(posTo, posFrom);
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
const tileMatrix = painter.translatePosMatrix(coord.posMatrix, tile,
|
|
104
|
-
layer.paint.get('fill-translate'), layer.paint.get('fill-translate-anchor'));
|
|
105
|
-
|
|
106
|
-
if (!isOutline) {
|
|
107
|
-
indexBuffer = bucket.indexBuffer;
|
|
108
|
-
segments = bucket.segments;
|
|
109
|
-
uniformValues = image ?
|
|
110
|
-
fillPatternUniformValues(tileMatrix, painter, crossfade, tile) :
|
|
111
|
-
fillUniformValues(tileMatrix);
|
|
112
|
-
} else {
|
|
113
|
-
indexBuffer = bucket.indexBuffer2;
|
|
114
|
-
segments = bucket.segments2;
|
|
115
|
-
const drawingBufferSize = [gl.drawingBufferWidth, gl.drawingBufferHeight];
|
|
116
|
-
uniformValues = (programName === 'fillOutlinePattern' && image) ?
|
|
117
|
-
fillOutlinePatternUniformValues(tileMatrix, painter, crossfade, tile, drawingBufferSize) :
|
|
118
|
-
fillOutlineUniformValues(tileMatrix, drawingBufferSize);
|
|
119
|
-
}
|
|
120
|
-
|
|
121
|
-
program.draw(painter.context, drawMode, depthMode,
|
|
122
|
-
painter.stencilModeForClipping(coord), colorMode, CullFaceMode.disabled, uniformValues,
|
|
123
|
-
layer.id, bucket.layoutVertexBuffer, indexBuffer, segments,
|
|
124
|
-
layer.paint, painter.transform.zoom, programConfiguration);
|
|
125
|
-
}
|
|
126
|
-
}
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import DepthMode from '../gl/depth_mode';
|
|
4
|
-
import StencilMode from '../gl/stencil_mode';
|
|
5
|
-
import ColorMode from '../gl/color_mode';
|
|
6
|
-
import CullFaceMode from '../gl/cull_face_mode';
|
|
7
|
-
import {
|
|
8
|
-
fillExtrusionUniformValues,
|
|
9
|
-
fillExtrusionPatternUniformValues,
|
|
10
|
-
} from './program/fill_extrusion_program';
|
|
11
|
-
|
|
12
|
-
import type Painter from './painter';
|
|
13
|
-
import type SourceCache from '../source/source_cache';
|
|
14
|
-
import type FillExtrusionStyleLayer from '../style/style_layer/fill_extrusion_style_layer';
|
|
15
|
-
import type FillExtrusionBucket from '../data/bucket/fill_extrusion_bucket';
|
|
16
|
-
import type {OverscaledTileID} from '../source/tile_id';
|
|
17
|
-
|
|
18
|
-
export default draw;
|
|
19
|
-
|
|
20
|
-
function draw(painter: Painter, source: SourceCache, layer: FillExtrusionStyleLayer, coords: Array<OverscaledTileID>) {
|
|
21
|
-
const opacity = layer.paint.get('fill-extrusion-opacity');
|
|
22
|
-
if (opacity === 0) {
|
|
23
|
-
return;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
if (painter.renderPass === 'translucent') {
|
|
27
|
-
const depthMode = new DepthMode(painter.context.gl.LEQUAL, DepthMode.ReadWrite, painter.depthRangeFor3D);
|
|
28
|
-
|
|
29
|
-
if (opacity === 1 && !layer.paint.get('fill-extrusion-pattern').constantOr((1: any))) {
|
|
30
|
-
const colorMode = painter.colorModeForRenderPass();
|
|
31
|
-
drawExtrusionTiles(painter, source, layer, coords, depthMode, StencilMode.disabled, colorMode);
|
|
32
|
-
|
|
33
|
-
} else {
|
|
34
|
-
// Draw transparent buildings in two passes so that only the closest surface is drawn.
|
|
35
|
-
// First draw all the extrusions into only the depth buffer. No colors are drawn.
|
|
36
|
-
drawExtrusionTiles(painter, source, layer, coords, depthMode,
|
|
37
|
-
StencilMode.disabled,
|
|
38
|
-
ColorMode.disabled);
|
|
39
|
-
|
|
40
|
-
// Then draw all the extrusions a second type, only coloring fragments if they have the
|
|
41
|
-
// same depth value as the closest fragment in the previous pass. Use the stencil buffer
|
|
42
|
-
// to prevent the second draw in cases where we have coincident polygons.
|
|
43
|
-
drawExtrusionTiles(painter, source, layer, coords, depthMode,
|
|
44
|
-
painter.stencilModeFor3D(),
|
|
45
|
-
painter.colorModeForRenderPass());
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
function drawExtrusionTiles(painter, source, layer, coords, depthMode, stencilMode, colorMode) {
|
|
51
|
-
const context = painter.context;
|
|
52
|
-
const gl = context.gl;
|
|
53
|
-
const patternProperty = layer.paint.get('fill-extrusion-pattern');
|
|
54
|
-
const image = patternProperty.constantOr((1: any));
|
|
55
|
-
const crossfade = layer.getCrossfadeParameters();
|
|
56
|
-
const opacity = layer.paint.get('fill-extrusion-opacity');
|
|
57
|
-
|
|
58
|
-
for (const coord of coords) {
|
|
59
|
-
const tile = source.getTile(coord);
|
|
60
|
-
const bucket: ?FillExtrusionBucket = (tile.getBucket(layer): any);
|
|
61
|
-
if (!bucket) continue;
|
|
62
|
-
|
|
63
|
-
const programConfiguration = bucket.programConfigurations.get(layer.id);
|
|
64
|
-
const program = painter.useProgram(image ? 'fillExtrusionPattern' : 'fillExtrusion', programConfiguration);
|
|
65
|
-
|
|
66
|
-
if (image) {
|
|
67
|
-
painter.context.activeTexture.set(gl.TEXTURE0);
|
|
68
|
-
tile.imageAtlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);
|
|
69
|
-
programConfiguration.updatePaintBuffers(crossfade);
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
const constantPattern = patternProperty.constantOr(null);
|
|
73
|
-
if (constantPattern && tile.imageAtlas) {
|
|
74
|
-
const atlas = tile.imageAtlas;
|
|
75
|
-
const posTo = atlas.patternPositions[constantPattern.to.toString()];
|
|
76
|
-
const posFrom = atlas.patternPositions[constantPattern.from.toString()];
|
|
77
|
-
if (posTo && posFrom) programConfiguration.setConstantPatternPositions(posTo, posFrom);
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
const matrix = painter.translatePosMatrix(
|
|
81
|
-
coord.posMatrix,
|
|
82
|
-
tile,
|
|
83
|
-
layer.paint.get('fill-extrusion-translate'),
|
|
84
|
-
layer.paint.get('fill-extrusion-translate-anchor'));
|
|
85
|
-
|
|
86
|
-
const shouldUseVerticalGradient = layer.paint.get('fill-extrusion-vertical-gradient');
|
|
87
|
-
const uniformValues = image ?
|
|
88
|
-
fillExtrusionPatternUniformValues(matrix, painter, shouldUseVerticalGradient, opacity, coord, crossfade, tile) :
|
|
89
|
-
fillExtrusionUniformValues(matrix, painter, shouldUseVerticalGradient, opacity);
|
|
90
|
-
|
|
91
|
-
program.draw(context, context.gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.backCCW,
|
|
92
|
-
uniformValues, layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer,
|
|
93
|
-
bucket.segments, layer.paint, painter.transform.zoom,
|
|
94
|
-
programConfiguration);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
@@ -1,140 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import Texture from './texture';
|
|
4
|
-
import Color from '../style-spec/util/color';
|
|
5
|
-
import DepthMode from '../gl/depth_mode';
|
|
6
|
-
import StencilMode from '../gl/stencil_mode';
|
|
7
|
-
import ColorMode from '../gl/color_mode';
|
|
8
|
-
import CullFaceMode from '../gl/cull_face_mode';
|
|
9
|
-
import {
|
|
10
|
-
heatmapUniformValues,
|
|
11
|
-
heatmapTextureUniformValues
|
|
12
|
-
} from './program/heatmap_program';
|
|
13
|
-
|
|
14
|
-
import type Painter from './painter';
|
|
15
|
-
import type SourceCache from '../source/source_cache';
|
|
16
|
-
import type HeatmapStyleLayer from '../style/style_layer/heatmap_style_layer';
|
|
17
|
-
import type HeatmapBucket from '../data/bucket/heatmap_bucket';
|
|
18
|
-
import type {OverscaledTileID} from '../source/tile_id';
|
|
19
|
-
|
|
20
|
-
export default drawHeatmap;
|
|
21
|
-
|
|
22
|
-
function drawHeatmap(painter: Painter, sourceCache: SourceCache, layer: HeatmapStyleLayer, coords: Array<OverscaledTileID>) {
|
|
23
|
-
if (layer.paint.get('heatmap-opacity') === 0) {
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
if (painter.renderPass === 'offscreen') {
|
|
28
|
-
const context = painter.context;
|
|
29
|
-
const gl = context.gl;
|
|
30
|
-
|
|
31
|
-
// Allow kernels to be drawn across boundaries, so that
|
|
32
|
-
// large kernels are not clipped to tiles
|
|
33
|
-
const stencilMode = StencilMode.disabled;
|
|
34
|
-
// Turn on additive blending for kernels, which is a key aspect of kernel density estimation formula
|
|
35
|
-
const colorMode = new ColorMode([gl.ONE, gl.ONE], Color.transparent, [true, true, true, true]);
|
|
36
|
-
|
|
37
|
-
bindFramebuffer(context, painter, layer);
|
|
38
|
-
|
|
39
|
-
context.clear({color: Color.transparent});
|
|
40
|
-
|
|
41
|
-
for (let i = 0; i < coords.length; i++) {
|
|
42
|
-
const coord = coords[i];
|
|
43
|
-
|
|
44
|
-
// Skip tiles that have uncovered parents to avoid flickering; we don't need
|
|
45
|
-
// to use complex tile masking here because the change between zoom levels is subtle,
|
|
46
|
-
// so it's fine to simply render the parent until all its 4 children are loaded
|
|
47
|
-
if (sourceCache.hasRenderableParent(coord)) continue;
|
|
48
|
-
|
|
49
|
-
const tile = sourceCache.getTile(coord);
|
|
50
|
-
const bucket: ?HeatmapBucket = (tile.getBucket(layer): any);
|
|
51
|
-
if (!bucket) continue;
|
|
52
|
-
|
|
53
|
-
const programConfiguration = bucket.programConfigurations.get(layer.id);
|
|
54
|
-
const program = painter.useProgram('heatmap', programConfiguration);
|
|
55
|
-
const {zoom} = painter.transform;
|
|
56
|
-
|
|
57
|
-
program.draw(context, gl.TRIANGLES, DepthMode.disabled, stencilMode, colorMode, CullFaceMode.disabled,
|
|
58
|
-
heatmapUniformValues(coord.posMatrix,
|
|
59
|
-
tile, zoom, layer.paint.get('heatmap-intensity')),
|
|
60
|
-
layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer,
|
|
61
|
-
bucket.segments, layer.paint, painter.transform.zoom,
|
|
62
|
-
programConfiguration);
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
context.viewport.set([0, 0, painter.width, painter.height]);
|
|
66
|
-
|
|
67
|
-
} else if (painter.renderPass === 'translucent') {
|
|
68
|
-
painter.context.setColorMode(painter.colorModeForRenderPass());
|
|
69
|
-
renderTextureToMap(painter, layer);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
function bindFramebuffer(context, painter, layer) {
|
|
74
|
-
const gl = context.gl;
|
|
75
|
-
context.activeTexture.set(gl.TEXTURE1);
|
|
76
|
-
|
|
77
|
-
// Use a 4x downscaled screen texture for better performance
|
|
78
|
-
context.viewport.set([0, 0, painter.width / 4, painter.height / 4]);
|
|
79
|
-
|
|
80
|
-
let fbo = layer.heatmapFbo;
|
|
81
|
-
|
|
82
|
-
if (!fbo) {
|
|
83
|
-
const texture = gl.createTexture();
|
|
84
|
-
gl.bindTexture(gl.TEXTURE_2D, texture);
|
|
85
|
-
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);
|
|
86
|
-
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);
|
|
87
|
-
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.LINEAR);
|
|
88
|
-
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.LINEAR);
|
|
89
|
-
|
|
90
|
-
fbo = layer.heatmapFbo = context.createFramebuffer(painter.width / 4, painter.height / 4, false);
|
|
91
|
-
|
|
92
|
-
bindTextureToFramebuffer(context, painter, texture, fbo);
|
|
93
|
-
|
|
94
|
-
} else {
|
|
95
|
-
gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());
|
|
96
|
-
context.bindFramebuffer.set(fbo.framebuffer);
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
function bindTextureToFramebuffer(context, painter, texture, fbo) {
|
|
101
|
-
const gl = context.gl;
|
|
102
|
-
// Use the higher precision half-float texture where available (producing much smoother looking heatmaps);
|
|
103
|
-
gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, painter.width / 4, painter.height / 4, 0, gl.RGBA,
|
|
104
|
-
context.extTextureHalfFloat ? context.extTextureHalfFloat.HALF_FLOAT_OES : gl.UNSIGNED_BYTE, null);
|
|
105
|
-
|
|
106
|
-
fbo.colorAttachment.set(texture);
|
|
107
|
-
|
|
108
|
-
// If using half-float texture as a render target is not supported, fall back to a low precision texture
|
|
109
|
-
if (context.extTextureHalfFloat && gl.checkFramebufferStatus(gl.FRAMEBUFFER) !== gl.FRAMEBUFFER_COMPLETE) {
|
|
110
|
-
context.extTextureHalfFloat = null;
|
|
111
|
-
fbo.colorAttachment.setDirty();
|
|
112
|
-
bindTextureToFramebuffer(context, painter, texture, fbo);
|
|
113
|
-
}
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
function renderTextureToMap(painter, layer) {
|
|
117
|
-
const context = painter.context;
|
|
118
|
-
const gl = context.gl;
|
|
119
|
-
|
|
120
|
-
// Here we bind two different textures from which we'll sample in drawing
|
|
121
|
-
// heatmaps: the kernel texture, prepared in the offscreen pass, and a
|
|
122
|
-
// color ramp texture.
|
|
123
|
-
const fbo = layer.heatmapFbo;
|
|
124
|
-
if (!fbo) return;
|
|
125
|
-
context.activeTexture.set(gl.TEXTURE0);
|
|
126
|
-
gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());
|
|
127
|
-
|
|
128
|
-
context.activeTexture.set(gl.TEXTURE1);
|
|
129
|
-
let colorRampTexture = layer.colorRampTexture;
|
|
130
|
-
if (!colorRampTexture) {
|
|
131
|
-
colorRampTexture = layer.colorRampTexture = new Texture(context, layer.colorRamp, gl.RGBA);
|
|
132
|
-
}
|
|
133
|
-
colorRampTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);
|
|
134
|
-
|
|
135
|
-
painter.useProgram('heatmapTexture').draw(context, gl.TRIANGLES,
|
|
136
|
-
DepthMode.disabled, StencilMode.disabled, painter.colorModeForRenderPass(), CullFaceMode.disabled,
|
|
137
|
-
heatmapTextureUniformValues(painter, layer, 0, 1),
|
|
138
|
-
layer.id, painter.viewportBuffer, painter.quadTriangleIndexBuffer,
|
|
139
|
-
painter.viewportSegments, layer.paint, painter.transform.zoom);
|
|
140
|
-
}
|
|
@@ -1,108 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import Texture from './texture';
|
|
4
|
-
import StencilMode from '../gl/stencil_mode';
|
|
5
|
-
import DepthMode from '../gl/depth_mode';
|
|
6
|
-
import CullFaceMode from '../gl/cull_face_mode';
|
|
7
|
-
import {
|
|
8
|
-
hillshadeUniformValues,
|
|
9
|
-
hillshadeUniformPrepareValues
|
|
10
|
-
} from './program/hillshade_program';
|
|
11
|
-
|
|
12
|
-
import type Painter from './painter';
|
|
13
|
-
import type SourceCache from '../source/source_cache';
|
|
14
|
-
import type HillshadeStyleLayer from '../style/style_layer/hillshade_style_layer';
|
|
15
|
-
import type {OverscaledTileID} from '../source/tile_id';
|
|
16
|
-
|
|
17
|
-
export default drawHillshade;
|
|
18
|
-
|
|
19
|
-
function drawHillshade(painter: Painter, sourceCache: SourceCache, layer: HillshadeStyleLayer, tileIDs: Array<OverscaledTileID>) {
|
|
20
|
-
if (painter.renderPass !== 'offscreen' && painter.renderPass !== 'translucent') return;
|
|
21
|
-
|
|
22
|
-
const context = painter.context;
|
|
23
|
-
const sourceMaxZoom = sourceCache.getSource().maxzoom;
|
|
24
|
-
|
|
25
|
-
const depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);
|
|
26
|
-
const colorMode = painter.colorModeForRenderPass();
|
|
27
|
-
|
|
28
|
-
const [stencilModes, coords] = painter.renderPass === 'translucent' ?
|
|
29
|
-
painter.stencilConfigForOverlap(tileIDs) : [{}, tileIDs];
|
|
30
|
-
|
|
31
|
-
for (const coord of coords) {
|
|
32
|
-
const tile = sourceCache.getTile(coord);
|
|
33
|
-
if (tile.needsHillshadePrepare && painter.renderPass === 'offscreen') {
|
|
34
|
-
prepareHillshade(painter, tile, layer, sourceMaxZoom, depthMode, StencilMode.disabled, colorMode);
|
|
35
|
-
} else if (painter.renderPass === 'translucent') {
|
|
36
|
-
renderHillshade(painter, tile, layer, depthMode, stencilModes[coord.overscaledZ], colorMode);
|
|
37
|
-
}
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
context.viewport.set([0, 0, painter.width, painter.height]);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
function renderHillshade(painter, tile, layer, depthMode, stencilMode, colorMode) {
|
|
44
|
-
const context = painter.context;
|
|
45
|
-
const gl = context.gl;
|
|
46
|
-
const fbo = tile.fbo;
|
|
47
|
-
if (!fbo) return;
|
|
48
|
-
|
|
49
|
-
const program = painter.useProgram('hillshade');
|
|
50
|
-
|
|
51
|
-
context.activeTexture.set(gl.TEXTURE0);
|
|
52
|
-
gl.bindTexture(gl.TEXTURE_2D, fbo.colorAttachment.get());
|
|
53
|
-
|
|
54
|
-
const uniformValues = hillshadeUniformValues(painter, tile, layer);
|
|
55
|
-
|
|
56
|
-
program.draw(context, gl.TRIANGLES, depthMode, stencilMode, colorMode, CullFaceMode.disabled,
|
|
57
|
-
uniformValues, layer.id, painter.rasterBoundsBuffer,
|
|
58
|
-
painter.quadTriangleIndexBuffer, painter.rasterBoundsSegments);
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
// hillshade rendering is done in two steps. the prepare step first calculates the slope of the terrain in the x and y
|
|
62
|
-
// directions for each pixel, and saves those values to a framebuffer texture in the r and g channels.
|
|
63
|
-
function prepareHillshade(painter, tile, layer, sourceMaxZoom, depthMode, stencilMode, colorMode) {
|
|
64
|
-
const context = painter.context;
|
|
65
|
-
const gl = context.gl;
|
|
66
|
-
const dem = tile.dem;
|
|
67
|
-
if (dem && dem.data) {
|
|
68
|
-
const tileSize = dem.dim;
|
|
69
|
-
const textureStride = dem.stride;
|
|
70
|
-
|
|
71
|
-
const pixelData = dem.getPixels();
|
|
72
|
-
context.activeTexture.set(gl.TEXTURE1);
|
|
73
|
-
|
|
74
|
-
context.pixelStoreUnpackPremultiplyAlpha.set(false);
|
|
75
|
-
tile.demTexture = tile.demTexture || painter.getTileTexture(textureStride);
|
|
76
|
-
if (tile.demTexture) {
|
|
77
|
-
const demTexture = tile.demTexture;
|
|
78
|
-
demTexture.update(pixelData, {premultiply: false});
|
|
79
|
-
demTexture.bind(gl.NEAREST, gl.CLAMP_TO_EDGE);
|
|
80
|
-
} else {
|
|
81
|
-
tile.demTexture = new Texture(context, pixelData, gl.RGBA, {premultiply: false});
|
|
82
|
-
tile.demTexture.bind(gl.NEAREST, gl.CLAMP_TO_EDGE);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
context.activeTexture.set(gl.TEXTURE0);
|
|
86
|
-
|
|
87
|
-
let fbo = tile.fbo;
|
|
88
|
-
|
|
89
|
-
if (!fbo) {
|
|
90
|
-
const renderTexture = new Texture(context, {width: tileSize, height: tileSize, data: null}, gl.RGBA);
|
|
91
|
-
renderTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);
|
|
92
|
-
|
|
93
|
-
fbo = tile.fbo = context.createFramebuffer(tileSize, tileSize, true);
|
|
94
|
-
fbo.colorAttachment.set(renderTexture.texture);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
context.bindFramebuffer.set(fbo.framebuffer);
|
|
98
|
-
context.viewport.set([0, 0, tileSize, tileSize]);
|
|
99
|
-
|
|
100
|
-
painter.useProgram('hillshadePrepare').draw(context, gl.TRIANGLES,
|
|
101
|
-
depthMode, stencilMode, colorMode, CullFaceMode.disabled,
|
|
102
|
-
hillshadeUniformPrepareValues(tile.tileID, dem, sourceMaxZoom),
|
|
103
|
-
layer.id, painter.rasterBoundsBuffer,
|
|
104
|
-
painter.quadTriangleIndexBuffer, painter.rasterBoundsSegments);
|
|
105
|
-
|
|
106
|
-
tile.needsHillshadePrepare = false;
|
|
107
|
-
}
|
|
108
|
-
}
|
package/src/render/draw_line.js
DELETED
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import DepthMode from '../gl/depth_mode';
|
|
4
|
-
import CullFaceMode from '../gl/cull_face_mode';
|
|
5
|
-
import Texture from './texture';
|
|
6
|
-
import {
|
|
7
|
-
lineUniformValues,
|
|
8
|
-
linePatternUniformValues,
|
|
9
|
-
lineSDFUniformValues,
|
|
10
|
-
lineGradientUniformValues
|
|
11
|
-
} from './program/line_program';
|
|
12
|
-
|
|
13
|
-
import type Painter from './painter';
|
|
14
|
-
import type SourceCache from '../source/source_cache';
|
|
15
|
-
import type LineStyleLayer from '../style/style_layer/line_style_layer';
|
|
16
|
-
import type LineBucket from '../data/bucket/line_bucket';
|
|
17
|
-
import type {OverscaledTileID} from '../source/tile_id';
|
|
18
|
-
|
|
19
|
-
export default function drawLine(painter: Painter, sourceCache: SourceCache, layer: LineStyleLayer, coords: Array<OverscaledTileID>) {
|
|
20
|
-
if (painter.renderPass !== 'translucent') return;
|
|
21
|
-
|
|
22
|
-
const opacity = layer.paint.get('line-opacity');
|
|
23
|
-
const width = layer.paint.get('line-width');
|
|
24
|
-
if (opacity.constantOr(1) === 0 || width.constantOr(1) === 0) return;
|
|
25
|
-
|
|
26
|
-
const depthMode = painter.depthModeForSublayer(0, DepthMode.ReadOnly);
|
|
27
|
-
const colorMode = painter.colorModeForRenderPass();
|
|
28
|
-
|
|
29
|
-
const dasharray = layer.paint.get('line-dasharray');
|
|
30
|
-
const patternProperty = layer.paint.get('line-pattern');
|
|
31
|
-
const image = patternProperty.constantOr((1: any));
|
|
32
|
-
|
|
33
|
-
const gradient = layer.paint.get('line-gradient');
|
|
34
|
-
const crossfade = layer.getCrossfadeParameters();
|
|
35
|
-
|
|
36
|
-
const programId =
|
|
37
|
-
image ? 'linePattern' :
|
|
38
|
-
dasharray ? 'lineSDF' :
|
|
39
|
-
gradient ? 'lineGradient' : 'line';
|
|
40
|
-
|
|
41
|
-
const context = painter.context;
|
|
42
|
-
const gl = context.gl;
|
|
43
|
-
|
|
44
|
-
let firstTile = true;
|
|
45
|
-
|
|
46
|
-
if (gradient) {
|
|
47
|
-
context.activeTexture.set(gl.TEXTURE0);
|
|
48
|
-
|
|
49
|
-
let gradientTexture = layer.gradientTexture;
|
|
50
|
-
if (!layer.gradient) return;
|
|
51
|
-
if (!gradientTexture) gradientTexture = layer.gradientTexture = new Texture(context, layer.gradient, gl.RGBA);
|
|
52
|
-
gradientTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
for (const coord of coords) {
|
|
56
|
-
const tile = sourceCache.getTile(coord);
|
|
57
|
-
|
|
58
|
-
if (image && !tile.patternsLoaded()) continue;
|
|
59
|
-
|
|
60
|
-
const bucket: ?LineBucket = (tile.getBucket(layer): any);
|
|
61
|
-
if (!bucket) continue;
|
|
62
|
-
|
|
63
|
-
const programConfiguration = bucket.programConfigurations.get(layer.id);
|
|
64
|
-
const prevProgram = painter.context.program.get();
|
|
65
|
-
const program = painter.useProgram(programId, programConfiguration);
|
|
66
|
-
const programChanged = firstTile || program.program !== prevProgram;
|
|
67
|
-
|
|
68
|
-
const constantPattern = patternProperty.constantOr(null);
|
|
69
|
-
if (constantPattern && tile.imageAtlas) {
|
|
70
|
-
const atlas = tile.imageAtlas;
|
|
71
|
-
const posTo = atlas.patternPositions[constantPattern.to.toString()];
|
|
72
|
-
const posFrom = atlas.patternPositions[constantPattern.from.toString()];
|
|
73
|
-
if (posTo && posFrom) programConfiguration.setConstantPatternPositions(posTo, posFrom);
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
const uniformValues = image ? linePatternUniformValues(painter, tile, layer, crossfade) :
|
|
77
|
-
dasharray ? lineSDFUniformValues(painter, tile, layer, dasharray, crossfade) :
|
|
78
|
-
gradient ? lineGradientUniformValues(painter, tile, layer) :
|
|
79
|
-
lineUniformValues(painter, tile, layer);
|
|
80
|
-
|
|
81
|
-
if (image) {
|
|
82
|
-
context.activeTexture.set(gl.TEXTURE0);
|
|
83
|
-
tile.imageAtlasTexture.bind(gl.LINEAR, gl.CLAMP_TO_EDGE);
|
|
84
|
-
programConfiguration.updatePaintBuffers(crossfade);
|
|
85
|
-
} else if (dasharray && (programChanged || painter.lineAtlas.dirty)) {
|
|
86
|
-
context.activeTexture.set(gl.TEXTURE0);
|
|
87
|
-
painter.lineAtlas.bind(context);
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
program.draw(context, gl.TRIANGLES, depthMode,
|
|
91
|
-
painter.stencilModeForClipping(coord), colorMode, CullFaceMode.disabled, uniformValues,
|
|
92
|
-
layer.id, bucket.layoutVertexBuffer, bucket.indexBuffer, bucket.segments,
|
|
93
|
-
layer.paint, painter.transform.zoom, programConfiguration);
|
|
94
|
-
|
|
95
|
-
firstTile = false;
|
|
96
|
-
// once refactored so that bound texture state is managed, we'll also be able to remove this firstTile/programChanged logic
|
|
97
|
-
}
|
|
98
|
-
}
|