@antv/l7-layers 2.9.20 → 2.9.22
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/es/Geometry/index.js +4 -5
- package/es/Geometry/models/billboard.js +23 -9
- package/es/Geometry/models/index.js +4 -5
- package/es/Geometry/models/plane.js +25 -13
- package/es/Geometry/models/sprite.js +11 -21
- package/es/Geometry/shaders/billboard_frag.glsl +13 -0
- package/es/Geometry/shaders/billboard_vert.glsl +50 -0
- package/es/Geometry/shaders/plane_frag.glsl +22 -0
- package/es/Geometry/shaders/plane_vert.glsl +53 -0
- package/es/Geometry/shaders/sprite_frag.glsl +21 -0
- package/es/Geometry/shaders/sprite_vert.glsl +28 -0
- package/es/canvas/index.js +4 -5
- package/es/canvas/models/canvas.js +6 -12
- package/es/canvas/models/index.js +2 -3
- package/es/citybuliding/building.js +4 -5
- package/es/citybuliding/models/build.js +19 -22
- package/es/citybuliding/shaders/build_frag.glsl +117 -0
- package/es/citybuliding/shaders/build_vert.glsl +54 -0
- package/es/core/BaseLayer.js +205 -157
- package/es/core/BaseModel.js +135 -76
- package/es/core/interface.d.ts +11 -1
- package/es/core/interface.js +15 -2
- package/es/core/schema.js +4 -2
- package/es/core/shape/Path.js +8 -3
- package/es/core/shape/extrude.js +9 -4
- package/es/core/triangulation.js +89 -17
- package/es/earth/index.js +11 -7
- package/es/earth/models/atmosphere.js +15 -7
- package/es/earth/models/base.js +19 -7
- package/es/earth/models/bloomsphere.js +15 -7
- package/es/earth/shaders/atmosphere_frag.glsl +17 -0
- package/es/earth/shaders/atmosphere_vert.glsl +26 -0
- package/es/earth/shaders/base_frag.glsl +13 -0
- package/es/earth/shaders/base_vert.glsl +52 -0
- package/es/earth/shaders/bloomsphere_frag.glsl +15 -0
- package/es/earth/shaders/bloomsphere_vert.glsl +20 -0
- package/es/earth/utils.js +28 -5
- package/es/heatmap/index.js +8 -7
- package/es/heatmap/models/grid.js +11 -5
- package/es/heatmap/models/grid3d.js +18 -7
- package/es/heatmap/models/heatmap.js +45 -44
- package/es/heatmap/models/hexagon.js +14 -6
- package/es/heatmap/models/index.js +5 -6
- package/es/heatmap/shaders/grid_vert.glsl +42 -0
- package/es/heatmap/shaders/heatmap_3d_frag.glsl +14 -0
- package/es/heatmap/shaders/heatmap_3d_vert.glsl +46 -0
- package/es/heatmap/shaders/heatmap_frag.glsl +47 -0
- package/es/heatmap/shaders/heatmap_framebuffer_frag.glsl +10 -0
- package/es/heatmap/shaders/heatmap_framebuffer_vert.glsl +35 -0
- package/es/heatmap/shaders/heatmap_vert.glsl +10 -0
- package/es/heatmap/shaders/hexagon_3d_frag.glsl +0 -0
- package/es/heatmap/shaders/hexagon_3d_vert.glsl +64 -0
- package/es/heatmap/shaders/hexagon_frag.glsl +12 -0
- package/es/heatmap/shaders/hexagon_vert.glsl +41 -0
- package/es/heatmap/triangulation.js +2 -2
- package/es/image/index.js +4 -5
- package/es/image/models/dataImage.js +21 -31
- package/es/image/models/image.js +19 -25
- package/es/image/models/index.js +3 -4
- package/es/image/shaders/dataImage_frag.glsl +38 -0
- package/es/image/shaders/image_frag.glsl +9 -0
- package/es/image/shaders/image_vert.glsl +17 -0
- package/es/index.d.ts +2 -2
- package/es/index.js +92 -30
- package/es/line/index.js +4 -5
- package/es/line/models/arc.js +38 -15
- package/es/line/models/arc_3d.js +33 -14
- package/es/line/models/earthArc_3d.js +33 -14
- package/es/line/models/great_circle.js +25 -13
- package/es/line/models/half.js +33 -12
- package/es/line/models/index.js +12 -13
- package/es/line/models/line.js +57 -17
- package/es/line/models/linearline.js +32 -14
- package/es/line/models/simpleLine.js +26 -11
- package/es/line/models/tile.js +28 -10
- package/es/line/models/wall.js +30 -13
- package/es/line/shaders/arc_chunks.vert.glsl +21 -0
- package/es/line/shaders/dash/arc_dash_frag.glsl +28 -0
- package/es/line/shaders/dash/arc_dash_vert.glsl +148 -0
- package/es/line/shaders/dash/line_dash_frag.glsl +31 -0
- package/es/line/shaders/dash/line_dash_vert.glsl +93 -0
- package/es/line/shaders/half/line_half_frag.glsl +53 -0
- package/es/line/shaders/half/line_half_vert.glsl +169 -0
- package/es/line/shaders/line_arc2d_vert.glsl +114 -0
- package/es/line/shaders/line_arc_3d_frag.glsl +103 -0
- package/es/line/shaders/line_arc_3d_vert.glsl +207 -0
- package/es/line/shaders/line_arc_frag.glsl +89 -0
- package/es/line/shaders/line_arc_great_circle_frag.glsl +101 -0
- package/es/line/shaders/line_arc_great_circle_vert.glsl +215 -0
- package/es/line/shaders/line_arc_vert.glsl +174 -0
- package/es/line/shaders/line_bezier_vert.glsl +85 -0
- package/es/line/shaders/line_frag.glsl +100 -0
- package/es/line/shaders/line_vert.glsl +192 -0
- package/es/line/shaders/linear/arc3d_linear_frag.glsl +47 -0
- package/es/line/shaders/linear/arc3d_linear_vert.glsl +207 -0
- package/es/line/shaders/linear/arc_linear_frag.glsl +38 -0
- package/es/line/shaders/linear/arc_linear_vert.glsl +138 -0
- package/es/line/shaders/linear/line_linear_frag.glsl +27 -0
- package/es/line/shaders/linearLine/line_linear_frag.glsl +20 -0
- package/es/line/shaders/linearLine/line_linear_vert.glsl +112 -0
- package/es/line/shaders/simple/simpleline_frag.glsl +10 -0
- package/es/line/shaders/simple/simpleline_linear_frag.glsl +11 -0
- package/es/line/shaders/simple/simpleline_vert.glsl +78 -0
- package/es/line/shaders/tile/line_tile_frag.glsl +79 -0
- package/es/line/shaders/tile/line_tile_vert.glsl +210 -0
- package/es/line/shaders/wall_frag.glsl +93 -0
- package/es/line/shaders/wall_vert.glsl +111 -0
- package/es/mask/index.js +4 -5
- package/es/mask/models/fill.js +11 -8
- package/es/mask/models/index.js +2 -3
- package/es/mask/shaders/mask_frag.glsl +7 -0
- package/es/mask/shaders/mask_vert.glsl +22 -0
- package/es/plugins/DataMappingPlugin.js +71 -34
- package/es/plugins/DataSourcePlugin.js +12 -10
- package/es/plugins/FeatureScalePlugin.js +44 -24
- package/es/plugins/LayerAnimateStylePlugin.js +6 -7
- package/es/plugins/LayerModelPlugin.js +16 -7
- package/es/plugins/LayerStylePlugin.js +7 -3
- package/es/plugins/LightingPlugin.js +21 -13
- package/es/plugins/MultiPassRendererPlugin.js +21 -8
- package/es/plugins/PixelPickingPlugin.js +33 -11
- package/es/plugins/RegisterStyleAttributePlugin.js +10 -3
- package/es/plugins/ShaderUniformPlugin.js +24 -10
- package/es/plugins/UpdateModelPlugin.js +7 -3
- package/es/plugins/UpdateStyleAttributePlugin.js +20 -7
- package/es/point/index.js +12 -6
- package/es/point/models/earthExtrude.js +30 -12
- package/es/point/models/earthFill.js +25 -13
- package/es/point/models/extrude.js +30 -12
- package/es/point/models/fill.js +50 -15
- package/es/point/models/fillmage.js +46 -17
- package/es/point/models/image.js +20 -12
- package/es/point/models/index.js +14 -14
- package/es/point/models/normal.js +15 -7
- package/es/point/models/radar.js +33 -13
- package/es/point/models/simplePoint.js +17 -9
- package/es/point/models/text.js +77 -30
- package/es/point/models/tile.js +33 -12
- package/es/point/shaders/animate/wave_frag.glsl +65 -0
- package/es/point/shaders/earth/extrude_frag.glsl +44 -0
- package/es/point/shaders/earth/extrude_vert.glsl +140 -0
- package/es/point/shaders/earth/fill_frag.glsl +86 -0
- package/es/point/shaders/earth/fill_vert.glsl +126 -0
- package/es/point/shaders/extrude/extrude_frag.glsl +44 -0
- package/es/point/shaders/extrude/extrude_vert.glsl +121 -0
- package/es/point/shaders/fill_frag.glsl +84 -0
- package/es/point/shaders/fill_vert.glsl +182 -0
- package/es/point/shaders/image/fillImage_frag.glsl +20 -0
- package/es/point/shaders/image/fillImage_vert.glsl +108 -0
- package/es/point/shaders/image_frag.glsl +39 -0
- package/es/point/shaders/image_vert.glsl +81 -0
- package/es/point/shaders/normal_frag.glsl +15 -0
- package/es/point/shaders/normal_vert.glsl +79 -0
- package/es/point/shaders/radar/radar_frag.glsl +64 -0
- package/es/point/shaders/radar/radar_vert.glsl +120 -0
- package/es/point/shaders/simplePoint_frag.glsl +53 -0
- package/es/point/shaders/simplePoint_vert.glsl +79 -0
- package/es/point/shaders/text_frag.glsl +48 -0
- package/es/point/shaders/text_vert.glsl +131 -0
- package/es/point/shaders/tile/fill_tile_frag.glsl +83 -0
- package/es/point/shaders/tile/fill_tile_vert.glsl +181 -0
- package/es/point/shape/extrude.js +8 -3
- package/es/polygon/index.js +6 -5
- package/es/polygon/models/extrude.js +40 -31
- package/es/polygon/models/fill.js +19 -8
- package/es/polygon/models/index.js +14 -14
- package/es/polygon/models/ocean.js +25 -33
- package/es/polygon/models/tile.js +13 -7
- package/es/polygon/models/water.js +21 -25
- package/es/polygon/shaders/extrude/polygon_extrude_frag.glsl +44 -0
- package/es/polygon/shaders/extrude/polygon_extrude_picklight_frag.glsl +44 -0
- package/es/polygon/shaders/extrude/polygon_extrude_picklight_vert.glsl +85 -0
- package/es/polygon/shaders/extrude/polygon_extrude_vert.glsl +90 -0
- package/es/polygon/shaders/extrude/polygon_extrudetex_frag.glsl +48 -0
- package/es/polygon/shaders/extrude/polygon_extrudetex_vert.glsl +93 -0
- package/es/polygon/shaders/polygon_frag.glsl +12 -0
- package/es/polygon/shaders/polygon_linear_frag.glsl +22 -0
- package/es/polygon/shaders/polygon_linear_vert.glsl +74 -0
- package/es/polygon/shaders/polygon_vert.glsl +66 -0
- package/es/polygon/shaders/tile/polygon_tile_frag.glsl +12 -0
- package/es/polygon/shaders/tile/polygon_tile_vert.glsl +82 -0
- package/es/polygon/shaders/water/polygon_ocean_frag.glsl +248 -0
- package/es/polygon/shaders/water/polygon_ocean_vert.glsl +52 -0
- package/es/polygon/shaders/water/polygon_water_frag.glsl +73 -0
- package/es/polygon/shaders/water/polygon_water_vert.glsl +55 -0
- package/es/raster/buffers/triangulation.js +2 -2
- package/es/raster/index.js +7 -6
- package/es/raster/models/index.js +3 -4
- package/es/raster/models/raster.js +15 -25
- package/es/raster/raster.js +9 -13
- package/es/raster/shaders/raster_2d_frag.glsl +28 -0
- package/es/raster/shaders/raster_2d_vert.glsl +18 -0
- package/es/raster/shaders/raster_frag.glsl +9 -0
- package/es/raster/shaders/raster_vert.glsl +44 -0
- package/es/tile/interface.js +1 -2
- package/es/tile/manager/tileConfigManager.js +6 -8
- package/es/tile/manager/tileLayerManager.js +19 -30
- package/es/tile/manager/tilePickerManager.js +14 -14
- package/es/tile/models/tileModel.js +6 -6
- package/es/tile/tileFactory/base.js +26 -32
- package/es/tile/tileFactory/index.js +6 -7
- package/es/tile/tileFactory/line.js +3 -9
- package/es/tile/tileFactory/point.js +3 -9
- package/es/tile/tileFactory/polygon.js +3 -9
- package/es/tile/tileFactory/raster.js +4 -10
- package/es/tile/tileFactory/rasterData.js +5 -11
- package/es/tile/tileFactory/rasterDataLayer.js +4 -5
- package/es/tile/tileFactory/vectorLayer.js +8 -9
- package/es/tile/tileLayer/baseTileLayer.js +67 -39
- package/es/tile/tmsTileLayer.js +5 -4
- package/es/tile/utils.js +5 -3
- package/es/utils/blend.js +1 -2
- package/es/utils/collision-index.js +36 -21
- package/es/utils/dataMappingStyle.js +71 -15
- package/es/utils/extrude_polyline.js +90 -48
- package/es/utils/grid-index.js +7 -21
- package/es/utils/layerData.js +41 -17
- package/es/utils/multiPassRender.js +21 -5
- package/es/utils/polylineNormal.js +40 -20
- package/es/utils/simpleLine.js +4 -6
- package/es/utils/symbol-layout.js +49 -10
- package/es/utils/updateShape.js +6 -3
- package/es/wind/index.js +5 -6
- package/es/wind/models/index.js +2 -3
- package/es/wind/models/utils.js +50 -26
- package/es/wind/models/wind.js +15 -18
- package/es/wind/models/windRender.js +89 -78
- package/es/wind/models/windShader.d.ts +6 -6
- package/es/wind/models/windShader.js +12 -7
- package/es/wind/shaders/wind_frag.glsl +9 -0
- package/es/wind/shaders/wind_vert.glsl +17 -0
- package/lib/Geometry/index.js +77 -115
- package/lib/Geometry/models/billboard.js +181 -218
- package/lib/Geometry/models/index.js +34 -19
- package/lib/Geometry/models/plane.js +278 -394
- package/lib/Geometry/models/sprite.js +189 -294
- package/lib/Geometry/shaders/billboard_frag.glsl +13 -0
- package/lib/Geometry/shaders/billboard_vert.glsl +50 -0
- package/lib/Geometry/shaders/plane_frag.glsl +22 -0
- package/lib/Geometry/shaders/plane_vert.glsl +53 -0
- package/lib/Geometry/shaders/sprite_frag.glsl +21 -0
- package/lib/Geometry/shaders/sprite_vert.glsl +28 -0
- package/lib/canvas/index.js +66 -102
- package/lib/canvas/models/canvas.js +140 -210
- package/lib/canvas/models/index.js +30 -13
- package/lib/citybuliding/building.js +63 -99
- package/lib/citybuliding/models/build.js +146 -196
- package/lib/citybuliding/shaders/build_frag.glsl +117 -0
- package/lib/citybuliding/shaders/build_vert.glsl +54 -0
- package/lib/core/BaseLayer.js +807 -1245
- package/lib/core/BaseModel.js +275 -375
- package/lib/core/interface.js +52 -20
- package/lib/core/schema.js +39 -18
- package/lib/core/shape/Path.js +78 -60
- package/lib/core/shape/extrude.js +90 -127
- package/lib/core/triangulation.js +191 -304
- package/lib/earth/index.js +62 -96
- package/lib/earth/models/atmosphere.js +112 -139
- package/lib/earth/models/base.js +150 -198
- package/lib/earth/models/bloomsphere.js +112 -139
- package/lib/earth/shaders/atmosphere_frag.glsl +17 -0
- package/lib/earth/shaders/atmosphere_vert.glsl +26 -0
- package/lib/earth/shaders/base_frag.glsl +13 -0
- package/lib/earth/shaders/base_vert.glsl +52 -0
- package/lib/earth/shaders/bloomsphere_frag.glsl +15 -0
- package/lib/earth/shaders/bloomsphere_vert.glsl +20 -0
- package/lib/earth/utils.js +89 -85
- package/lib/heatmap/index.js +92 -148
- package/lib/heatmap/models/grid.js +91 -113
- package/lib/heatmap/models/grid3d.js +123 -145
- package/lib/heatmap/models/heatmap.js +338 -470
- package/lib/heatmap/models/hexagon.js +92 -114
- package/lib/heatmap/models/index.js +37 -23
- package/lib/heatmap/shaders/grid_vert.glsl +42 -0
- package/lib/heatmap/shaders/heatmap_3d_frag.glsl +14 -0
- package/lib/heatmap/shaders/heatmap_3d_vert.glsl +46 -0
- package/lib/heatmap/shaders/heatmap_frag.glsl +47 -0
- package/lib/heatmap/shaders/heatmap_framebuffer_frag.glsl +10 -0
- package/lib/heatmap/shaders/heatmap_framebuffer_vert.glsl +35 -0
- package/lib/heatmap/shaders/heatmap_vert.glsl +10 -0
- package/lib/heatmap/shaders/hexagon_3d_frag.glsl +0 -0
- package/lib/heatmap/shaders/hexagon_3d_vert.glsl +64 -0
- package/lib/heatmap/shaders/hexagon_frag.glsl +12 -0
- package/lib/heatmap/shaders/hexagon_vert.glsl +41 -0
- package/lib/heatmap/triangulation.js +46 -30
- package/lib/image/index.js +74 -112
- package/lib/image/models/dataImage.js +173 -241
- package/lib/image/models/image.js +123 -177
- package/lib/image/models/index.js +32 -16
- package/lib/image/shaders/dataImage_frag.glsl +38 -0
- package/lib/image/shaders/image_frag.glsl +9 -0
- package/lib/image/shaders/image_vert.glsl +17 -0
- package/lib/index.js +96 -193
- package/lib/line/index.js +83 -128
- package/lib/line/models/arc.js +237 -328
- package/lib/line/models/arc_3d.js +228 -314
- package/lib/line/models/earthArc_3d.js +228 -316
- package/lib/line/models/great_circle.js +200 -279
- package/lib/line/models/half.js +201 -266
- package/lib/line/models/index.js +50 -43
- package/lib/line/models/line.js +299 -386
- package/lib/line/models/linearline.js +203 -258
- package/lib/line/models/simpleLine.js +175 -225
- package/lib/line/models/tile.js +237 -330
- package/lib/line/models/wall.js +235 -310
- package/lib/line/shaders/arc_chunks.vert.glsl +21 -0
- package/lib/line/shaders/dash/arc_dash_frag.glsl +28 -0
- package/lib/line/shaders/dash/arc_dash_vert.glsl +148 -0
- package/lib/line/shaders/dash/line_dash_frag.glsl +31 -0
- package/lib/line/shaders/dash/line_dash_vert.glsl +93 -0
- package/lib/line/shaders/half/line_half_frag.glsl +53 -0
- package/lib/line/shaders/half/line_half_vert.glsl +169 -0
- package/lib/line/shaders/line_arc2d_vert.glsl +114 -0
- package/lib/line/shaders/line_arc_3d_frag.glsl +103 -0
- package/lib/line/shaders/line_arc_3d_vert.glsl +207 -0
- package/lib/line/shaders/line_arc_frag.glsl +89 -0
- package/lib/line/shaders/line_arc_great_circle_frag.glsl +101 -0
- package/lib/line/shaders/line_arc_great_circle_vert.glsl +215 -0
- package/lib/line/shaders/line_arc_vert.glsl +174 -0
- package/lib/line/shaders/line_bezier_vert.glsl +85 -0
- package/lib/line/shaders/line_frag.glsl +100 -0
- package/lib/line/shaders/line_vert.glsl +192 -0
- package/lib/line/shaders/linear/arc3d_linear_frag.glsl +47 -0
- package/lib/line/shaders/linear/arc3d_linear_vert.glsl +207 -0
- package/lib/line/shaders/linear/arc_linear_frag.glsl +38 -0
- package/lib/line/shaders/linear/arc_linear_vert.glsl +138 -0
- package/lib/line/shaders/linear/line_linear_frag.glsl +27 -0
- package/lib/line/shaders/linearLine/line_linear_frag.glsl +20 -0
- package/lib/line/shaders/linearLine/line_linear_vert.glsl +112 -0
- package/lib/line/shaders/simple/simpleline_frag.glsl +10 -0
- package/lib/line/shaders/simple/simpleline_linear_frag.glsl +11 -0
- package/lib/line/shaders/simple/simpleline_vert.glsl +78 -0
- package/lib/line/shaders/tile/line_tile_frag.glsl +79 -0
- package/lib/line/shaders/tile/line_tile_vert.glsl +210 -0
- package/lib/line/shaders/wall_frag.glsl +93 -0
- package/lib/line/shaders/wall_vert.glsl +111 -0
- package/lib/mask/index.js +59 -93
- package/lib/mask/models/fill.js +82 -132
- package/lib/mask/models/index.js +30 -13
- package/lib/mask/shaders/mask_frag.glsl +7 -0
- package/lib/mask/shaders/mask_vert.glsl +22 -0
- package/lib/plugins/DataMappingPlugin.js +222 -304
- package/lib/plugins/DataSourcePlugin.js +87 -100
- package/lib/plugins/FeatureScalePlugin.js +239 -310
- package/lib/plugins/LayerAnimateStylePlugin.js +55 -61
- package/lib/plugins/LayerModelPlugin.js +72 -70
- package/lib/plugins/LayerStylePlugin.js +51 -44
- package/lib/plugins/LightingPlugin.js +68 -72
- package/lib/plugins/MultiPassRendererPlugin.js +65 -77
- package/lib/plugins/PixelPickingPlugin.js +109 -128
- package/lib/plugins/RegisterStyleAttributePlugin.js +110 -103
- package/lib/plugins/ShaderUniformPlugin.js +98 -103
- package/lib/plugins/UpdateModelPlugin.js +47 -36
- package/lib/plugins/UpdateStyleAttributePlugin.js +75 -80
- package/lib/point/index.js +147 -216
- package/lib/point/models/earthExtrude.js +201 -262
- package/lib/point/models/earthFill.js +202 -276
- package/lib/point/models/extrude.js +203 -282
- package/lib/point/models/fill.js +273 -369
- package/lib/point/models/fillmage.js +250 -327
- package/lib/point/models/image.js +163 -226
- package/lib/point/models/index.js +52 -46
- package/lib/point/models/normal.js +134 -176
- package/lib/point/models/radar.js +212 -286
- package/lib/point/models/simplePoint.js +142 -187
- package/lib/point/models/text.js +385 -559
- package/lib/point/models/tile.js +223 -294
- package/lib/point/shaders/animate/wave_frag.glsl +65 -0
- package/lib/point/shaders/earth/extrude_frag.glsl +44 -0
- package/lib/point/shaders/earth/extrude_vert.glsl +140 -0
- package/lib/point/shaders/earth/fill_frag.glsl +86 -0
- package/lib/point/shaders/earth/fill_vert.glsl +126 -0
- package/lib/point/shaders/extrude/extrude_frag.glsl +44 -0
- package/lib/point/shaders/extrude/extrude_vert.glsl +121 -0
- package/lib/point/shaders/fill_frag.glsl +84 -0
- package/lib/point/shaders/fill_vert.glsl +182 -0
- package/lib/point/shaders/image/fillImage_frag.glsl +20 -0
- package/lib/point/shaders/image/fillImage_vert.glsl +108 -0
- package/lib/point/shaders/image_frag.glsl +39 -0
- package/lib/point/shaders/image_vert.glsl +81 -0
- package/lib/point/shaders/normal_frag.glsl +15 -0
- package/lib/point/shaders/normal_vert.glsl +79 -0
- package/lib/point/shaders/radar/radar_frag.glsl +64 -0
- package/lib/point/shaders/radar/radar_vert.glsl +120 -0
- package/lib/point/shaders/simplePoint_frag.glsl +53 -0
- package/lib/point/shaders/simplePoint_vert.glsl +79 -0
- package/lib/point/shaders/text_frag.glsl +48 -0
- package/lib/point/shaders/text_vert.glsl +131 -0
- package/lib/point/shaders/tile/fill_tile_frag.glsl +83 -0
- package/lib/point/shaders/tile/fill_tile_vert.glsl +181 -0
- package/lib/point/shape/extrude.js +51 -51
- package/lib/polygon/index.js +100 -149
- package/lib/polygon/models/extrude.js +222 -303
- package/lib/polygon/models/fill.js +153 -205
- package/lib/polygon/models/index.js +52 -46
- package/lib/polygon/models/ocean.js +172 -251
- package/lib/polygon/models/tile.js +100 -139
- package/lib/polygon/models/water.js +152 -227
- package/lib/polygon/shaders/extrude/polygon_extrude_frag.glsl +44 -0
- package/lib/polygon/shaders/extrude/polygon_extrude_picklight_frag.glsl +44 -0
- package/lib/polygon/shaders/extrude/polygon_extrude_picklight_vert.glsl +85 -0
- package/lib/polygon/shaders/extrude/polygon_extrude_vert.glsl +90 -0
- package/lib/polygon/shaders/extrude/polygon_extrudetex_frag.glsl +48 -0
- package/lib/polygon/shaders/extrude/polygon_extrudetex_vert.glsl +93 -0
- package/lib/polygon/shaders/polygon_frag.glsl +12 -0
- package/lib/polygon/shaders/polygon_linear_frag.glsl +22 -0
- package/lib/polygon/shaders/polygon_linear_vert.glsl +74 -0
- package/lib/polygon/shaders/polygon_vert.glsl +66 -0
- package/lib/polygon/shaders/tile/polygon_tile_frag.glsl +12 -0
- package/lib/polygon/shaders/tile/polygon_tile_vert.glsl +82 -0
- package/lib/polygon/shaders/water/polygon_ocean_frag.glsl +248 -0
- package/lib/polygon/shaders/water/polygon_ocean_vert.glsl +52 -0
- package/lib/polygon/shaders/water/polygon_water_frag.glsl +73 -0
- package/lib/polygon/shaders/water/polygon_water_vert.glsl +55 -0
- package/lib/raster/buffers/triangulation.js +39 -26
- package/lib/raster/index.js +73 -111
- package/lib/raster/models/index.js +33 -17
- package/lib/raster/models/raster.js +134 -187
- package/lib/raster/raster.js +132 -189
- package/lib/raster/shaders/raster_2d_frag.glsl +28 -0
- package/lib/raster/shaders/raster_2d_vert.glsl +18 -0
- package/lib/raster/shaders/raster_frag.glsl +9 -0
- package/lib/raster/shaders/raster_vert.glsl +44 -0
- package/lib/tile/interface.js +17 -2
- package/lib/tile/manager/tileConfigManager.js +86 -126
- package/lib/tile/manager/tileLayerManager.js +227 -312
- package/lib/tile/manager/tilePickerManager.js +123 -187
- package/lib/tile/models/tileModel.js +51 -70
- package/lib/tile/tileFactory/base.js +292 -403
- package/lib/tile/tileFactory/index.js +48 -51
- package/lib/tile/tileFactory/line.js +50 -71
- package/lib/tile/tileFactory/point.js +50 -71
- package/lib/tile/tileFactory/polygon.js +50 -71
- package/lib/tile/tileFactory/raster.js +54 -72
- package/lib/tile/tileFactory/rasterData.js +76 -94
- package/lib/tile/tileFactory/rasterDataLayer.js +62 -98
- package/lib/tile/tileFactory/vectorLayer.js +95 -148
- package/lib/tile/tileLayer/baseTileLayer.js +220 -380
- package/lib/tile/tmsTileLayer.js +67 -109
- package/lib/tile/utils.js +86 -101
- package/lib/utils/blend.js +79 -60
- package/lib/utils/collision-index.js +63 -83
- package/lib/utils/dataMappingStyle.js +59 -56
- package/lib/utils/extrude_polyline.js +397 -554
- package/lib/utils/grid-index.js +111 -168
- package/lib/utils/layerData.js +88 -95
- package/lib/utils/multiPassRender.js +38 -31
- package/lib/utils/polylineNormal.js +86 -118
- package/lib/utils/simpleLine.js +85 -101
- package/lib/utils/symbol-layout.js +109 -173
- package/lib/utils/updateShape.js +40 -11
- package/lib/wind/index.js +71 -110
- package/lib/wind/models/index.js +30 -13
- package/lib/wind/models/utils.js +89 -104
- package/lib/wind/models/wind.js +224 -332
- package/lib/wind/models/windRender.js +215 -293
- package/lib/wind/models/windShader.js +181 -17
- package/lib/wind/shaders/wind_frag.glsl +9 -0
- package/lib/wind/shaders/wind_vert.glsl +17 -0
- package/package.json +11 -9
- package/es/Geometry/index.js.map +0 -1
- package/es/Geometry/models/billboard.js.map +0 -1
- package/es/Geometry/models/index.js.map +0 -1
- package/es/Geometry/models/plane.js.map +0 -1
- package/es/Geometry/models/sprite.js.map +0 -1
- package/es/canvas/index.js.map +0 -1
- package/es/canvas/models/canvas.js.map +0 -1
- package/es/canvas/models/index.js.map +0 -1
- package/es/citybuliding/building.js.map +0 -1
- package/es/citybuliding/models/build.js.map +0 -1
- package/es/core/BaseLayer.js.map +0 -1
- package/es/core/BaseModel.js.map +0 -1
- package/es/core/interface.js.map +0 -1
- package/es/core/schema.js.map +0 -1
- package/es/core/shape/Path.js.map +0 -1
- package/es/core/shape/extrude.js.map +0 -1
- package/es/core/triangulation.js.map +0 -1
- package/es/earth/index.js.map +0 -1
- package/es/earth/models/atmosphere.js.map +0 -1
- package/es/earth/models/base.js.map +0 -1
- package/es/earth/models/bloomsphere.js.map +0 -1
- package/es/earth/utils.js.map +0 -1
- package/es/glsl.d.js +0 -2
- package/es/glsl.d.js.map +0 -1
- package/es/heatmap/index.js.map +0 -1
- package/es/heatmap/models/grid.js.map +0 -1
- package/es/heatmap/models/grid3d.js.map +0 -1
- package/es/heatmap/models/heatmap.js.map +0 -1
- package/es/heatmap/models/hexagon.js.map +0 -1
- package/es/heatmap/models/index.js.map +0 -1
- package/es/heatmap/triangulation.js.map +0 -1
- package/es/image/index.js.map +0 -1
- package/es/image/models/dataImage.js.map +0 -1
- package/es/image/models/image.js.map +0 -1
- package/es/image/models/index.js.map +0 -1
- package/es/index.js.map +0 -1
- package/es/line/index.js.map +0 -1
- package/es/line/models/arc.js.map +0 -1
- package/es/line/models/arc_3d.js.map +0 -1
- package/es/line/models/earthArc_3d.js.map +0 -1
- package/es/line/models/great_circle.js.map +0 -1
- package/es/line/models/half.js.map +0 -1
- package/es/line/models/index.js.map +0 -1
- package/es/line/models/line.js.map +0 -1
- package/es/line/models/linearline.js.map +0 -1
- package/es/line/models/simpleLine.js.map +0 -1
- package/es/line/models/tile.js.map +0 -1
- package/es/line/models/wall.js.map +0 -1
- package/es/mask/index.js.map +0 -1
- package/es/mask/models/fill.js.map +0 -1
- package/es/mask/models/index.js.map +0 -1
- package/es/plugins/DataMappingPlugin.js.map +0 -1
- package/es/plugins/DataSourcePlugin.js.map +0 -1
- package/es/plugins/FeatureScalePlugin.js.map +0 -1
- package/es/plugins/LayerAnimateStylePlugin.js.map +0 -1
- package/es/plugins/LayerModelPlugin.js.map +0 -1
- package/es/plugins/LayerStylePlugin.js.map +0 -1
- package/es/plugins/LightingPlugin.js.map +0 -1
- package/es/plugins/MultiPassRendererPlugin.js.map +0 -1
- package/es/plugins/PixelPickingPlugin.js.map +0 -1
- package/es/plugins/RegisterStyleAttributePlugin.js.map +0 -1
- package/es/plugins/ShaderUniformPlugin.js.map +0 -1
- package/es/plugins/UpdateModelPlugin.js.map +0 -1
- package/es/plugins/UpdateStyleAttributePlugin.js.map +0 -1
- package/es/point/index.js.map +0 -1
- package/es/point/models/earthExtrude.js.map +0 -1
- package/es/point/models/earthFill.js.map +0 -1
- package/es/point/models/extrude.js.map +0 -1
- package/es/point/models/fill.js.map +0 -1
- package/es/point/models/fillmage.js.map +0 -1
- package/es/point/models/image.js.map +0 -1
- package/es/point/models/index.js.map +0 -1
- package/es/point/models/normal.js.map +0 -1
- package/es/point/models/radar.js.map +0 -1
- package/es/point/models/simplePoint.js.map +0 -1
- package/es/point/models/text.js.map +0 -1
- package/es/point/models/tile.js.map +0 -1
- package/es/point/shape/extrude.js.map +0 -1
- package/es/polygon/index.js.map +0 -1
- package/es/polygon/models/extrude.js.map +0 -1
- package/es/polygon/models/fill.js.map +0 -1
- package/es/polygon/models/index.js.map +0 -1
- package/es/polygon/models/ocean.js.map +0 -1
- package/es/polygon/models/tile.js.map +0 -1
- package/es/polygon/models/water.js.map +0 -1
- package/es/raster/buffers/triangulation.js.map +0 -1
- package/es/raster/index.js.map +0 -1
- package/es/raster/models/index.js.map +0 -1
- package/es/raster/models/raster.js.map +0 -1
- package/es/raster/raster.js.map +0 -1
- package/es/tile/interface.js.map +0 -1
- package/es/tile/manager/tileConfigManager.js.map +0 -1
- package/es/tile/manager/tileLayerManager.js.map +0 -1
- package/es/tile/manager/tilePickerManager.js.map +0 -1
- package/es/tile/models/tileModel.js.map +0 -1
- package/es/tile/tileFactory/base.js.map +0 -1
- package/es/tile/tileFactory/index.js.map +0 -1
- package/es/tile/tileFactory/line.js.map +0 -1
- package/es/tile/tileFactory/point.js.map +0 -1
- package/es/tile/tileFactory/polygon.js.map +0 -1
- package/es/tile/tileFactory/raster.js.map +0 -1
- package/es/tile/tileFactory/rasterData.js.map +0 -1
- package/es/tile/tileFactory/rasterDataLayer.js.map +0 -1
- package/es/tile/tileFactory/vectorLayer.js.map +0 -1
- package/es/tile/tileLayer/baseTileLayer.js.map +0 -1
- package/es/tile/tmsTileLayer.js.map +0 -1
- package/es/tile/utils.js.map +0 -1
- package/es/utils/blend.js.map +0 -1
- package/es/utils/collision-index.js.map +0 -1
- package/es/utils/dataMappingStyle.js.map +0 -1
- package/es/utils/extrude_polyline.js.map +0 -1
- package/es/utils/grid-index.js.map +0 -1
- package/es/utils/layerData.js.map +0 -1
- package/es/utils/multiPassRender.js.map +0 -1
- package/es/utils/polylineNormal.js.map +0 -1
- package/es/utils/simpleLine.js.map +0 -1
- package/es/utils/symbol-layout.js.map +0 -1
- package/es/utils/updateShape.js.map +0 -1
- package/es/wind/index.js.map +0 -1
- package/es/wind/models/index.js.map +0 -1
- package/es/wind/models/utils.js.map +0 -1
- package/es/wind/models/wind.js.map +0 -1
- package/es/wind/models/windRender.js.map +0 -1
- package/es/wind/models/windShader.js.map +0 -1
- package/lib/Geometry/index.js.map +0 -1
- package/lib/Geometry/models/billboard.js.map +0 -1
- package/lib/Geometry/models/index.js.map +0 -1
- package/lib/Geometry/models/plane.js.map +0 -1
- package/lib/Geometry/models/sprite.js.map +0 -1
- package/lib/canvas/index.js.map +0 -1
- package/lib/canvas/models/canvas.js.map +0 -1
- package/lib/canvas/models/index.js.map +0 -1
- package/lib/citybuliding/building.js.map +0 -1
- package/lib/citybuliding/models/build.js.map +0 -1
- package/lib/core/BaseLayer.js.map +0 -1
- package/lib/core/BaseModel.js.map +0 -1
- package/lib/core/interface.js.map +0 -1
- package/lib/core/schema.js.map +0 -1
- package/lib/core/shape/Path.js.map +0 -1
- package/lib/core/shape/extrude.js.map +0 -1
- package/lib/core/triangulation.js.map +0 -1
- package/lib/earth/index.js.map +0 -1
- package/lib/earth/models/atmosphere.js.map +0 -1
- package/lib/earth/models/base.js.map +0 -1
- package/lib/earth/models/bloomsphere.js.map +0 -1
- package/lib/earth/utils.js.map +0 -1
- package/lib/glsl.d.js +0 -2
- package/lib/glsl.d.js.map +0 -1
- package/lib/heatmap/index.js.map +0 -1
- package/lib/heatmap/models/grid.js.map +0 -1
- package/lib/heatmap/models/grid3d.js.map +0 -1
- package/lib/heatmap/models/heatmap.js.map +0 -1
- package/lib/heatmap/models/hexagon.js.map +0 -1
- package/lib/heatmap/models/index.js.map +0 -1
- package/lib/heatmap/triangulation.js.map +0 -1
- package/lib/image/index.js.map +0 -1
- package/lib/image/models/dataImage.js.map +0 -1
- package/lib/image/models/image.js.map +0 -1
- package/lib/image/models/index.js.map +0 -1
- package/lib/index.js.map +0 -1
- package/lib/line/index.js.map +0 -1
- package/lib/line/models/arc.js.map +0 -1
- package/lib/line/models/arc_3d.js.map +0 -1
- package/lib/line/models/earthArc_3d.js.map +0 -1
- package/lib/line/models/great_circle.js.map +0 -1
- package/lib/line/models/half.js.map +0 -1
- package/lib/line/models/index.js.map +0 -1
- package/lib/line/models/line.js.map +0 -1
- package/lib/line/models/linearline.js.map +0 -1
- package/lib/line/models/simpleLine.js.map +0 -1
- package/lib/line/models/tile.js.map +0 -1
- package/lib/line/models/wall.js.map +0 -1
- package/lib/mask/index.js.map +0 -1
- package/lib/mask/models/fill.js.map +0 -1
- package/lib/mask/models/index.js.map +0 -1
- package/lib/plugins/DataMappingPlugin.js.map +0 -1
- package/lib/plugins/DataSourcePlugin.js.map +0 -1
- package/lib/plugins/FeatureScalePlugin.js.map +0 -1
- package/lib/plugins/LayerAnimateStylePlugin.js.map +0 -1
- package/lib/plugins/LayerModelPlugin.js.map +0 -1
- package/lib/plugins/LayerStylePlugin.js.map +0 -1
- package/lib/plugins/LightingPlugin.js.map +0 -1
- package/lib/plugins/MultiPassRendererPlugin.js.map +0 -1
- package/lib/plugins/PixelPickingPlugin.js.map +0 -1
- package/lib/plugins/RegisterStyleAttributePlugin.js.map +0 -1
- package/lib/plugins/ShaderUniformPlugin.js.map +0 -1
- package/lib/plugins/UpdateModelPlugin.js.map +0 -1
- package/lib/plugins/UpdateStyleAttributePlugin.js.map +0 -1
- package/lib/point/index.js.map +0 -1
- package/lib/point/models/earthExtrude.js.map +0 -1
- package/lib/point/models/earthFill.js.map +0 -1
- package/lib/point/models/extrude.js.map +0 -1
- package/lib/point/models/fill.js.map +0 -1
- package/lib/point/models/fillmage.js.map +0 -1
- package/lib/point/models/image.js.map +0 -1
- package/lib/point/models/index.js.map +0 -1
- package/lib/point/models/normal.js.map +0 -1
- package/lib/point/models/radar.js.map +0 -1
- package/lib/point/models/simplePoint.js.map +0 -1
- package/lib/point/models/text.js.map +0 -1
- package/lib/point/models/tile.js.map +0 -1
- package/lib/point/shape/extrude.js.map +0 -1
- package/lib/polygon/index.js.map +0 -1
- package/lib/polygon/models/extrude.js.map +0 -1
- package/lib/polygon/models/fill.js.map +0 -1
- package/lib/polygon/models/index.js.map +0 -1
- package/lib/polygon/models/ocean.js.map +0 -1
- package/lib/polygon/models/tile.js.map +0 -1
- package/lib/polygon/models/water.js.map +0 -1
- package/lib/raster/buffers/triangulation.js.map +0 -1
- package/lib/raster/index.js.map +0 -1
- package/lib/raster/models/index.js.map +0 -1
- package/lib/raster/models/raster.js.map +0 -1
- package/lib/raster/raster.js.map +0 -1
- package/lib/tile/interface.js.map +0 -1
- package/lib/tile/manager/tileConfigManager.js.map +0 -1
- package/lib/tile/manager/tileLayerManager.js.map +0 -1
- package/lib/tile/manager/tilePickerManager.js.map +0 -1
- package/lib/tile/models/tileModel.js.map +0 -1
- package/lib/tile/tileFactory/base.js.map +0 -1
- package/lib/tile/tileFactory/index.js.map +0 -1
- package/lib/tile/tileFactory/line.js.map +0 -1
- package/lib/tile/tileFactory/point.js.map +0 -1
- package/lib/tile/tileFactory/polygon.js.map +0 -1
- package/lib/tile/tileFactory/raster.js.map +0 -1
- package/lib/tile/tileFactory/rasterData.js.map +0 -1
- package/lib/tile/tileFactory/rasterDataLayer.js.map +0 -1
- package/lib/tile/tileFactory/vectorLayer.js.map +0 -1
- package/lib/tile/tileLayer/baseTileLayer.js.map +0 -1
- package/lib/tile/tmsTileLayer.js.map +0 -1
- package/lib/tile/utils.js.map +0 -1
- package/lib/utils/blend.js.map +0 -1
- package/lib/utils/collision-index.js.map +0 -1
- package/lib/utils/dataMappingStyle.js.map +0 -1
- package/lib/utils/extrude_polyline.js.map +0 -1
- package/lib/utils/grid-index.js.map +0 -1
- package/lib/utils/layerData.js.map +0 -1
- package/lib/utils/multiPassRender.js.map +0 -1
- package/lib/utils/polylineNormal.js.map +0 -1
- package/lib/utils/simpleLine.js.map +0 -1
- package/lib/utils/symbol-layout.js.map +0 -1
- package/lib/utils/updateShape.js.map +0 -1
- package/lib/wind/index.js.map +0 -1
- package/lib/wind/models/index.js.map +0 -1
- package/lib/wind/models/utils.js.map +0 -1
- package/lib/wind/models/wind.js.map +0 -1
- package/lib/wind/models/windRender.js.map +0 -1
- package/lib/wind/models/windShader.js.map +0 -1
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
attribute vec4 a_Color;
|
|
2
|
+
attribute vec3 a_Position;
|
|
3
|
+
attribute vec3 a_Extrude;
|
|
4
|
+
attribute float a_Size;
|
|
5
|
+
attribute float a_Shape;
|
|
6
|
+
|
|
7
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
8
|
+
|
|
9
|
+
uniform mat4 u_ModelMatrix;
|
|
10
|
+
uniform mat4 u_Mvp;
|
|
11
|
+
uniform float u_meter2coord;
|
|
12
|
+
uniform float u_meteryScale;
|
|
13
|
+
uniform float u_isMeter;
|
|
14
|
+
|
|
15
|
+
varying vec4 v_data;
|
|
16
|
+
varying vec4 v_color;
|
|
17
|
+
varying float v_radius;
|
|
18
|
+
|
|
19
|
+
uniform float u_opacity : 1;
|
|
20
|
+
uniform float u_stroke_opacity : 1;
|
|
21
|
+
uniform float u_stroke_width : 2;
|
|
22
|
+
uniform vec4 u_stroke_color : [0.0, 0.0, 0.0, 0.0];
|
|
23
|
+
uniform vec2 u_offsets;
|
|
24
|
+
|
|
25
|
+
uniform float u_blur : 0.0;
|
|
26
|
+
uniform float u_raisingHeight: 0.0;
|
|
27
|
+
|
|
28
|
+
#pragma include "styleMapping"
|
|
29
|
+
#pragma include "styleMappingCalOpacity"
|
|
30
|
+
#pragma include "styleMappingCalStrokeOpacity"
|
|
31
|
+
#pragma include "styleMappingCalStrokeWidth"
|
|
32
|
+
|
|
33
|
+
#pragma include "projection"
|
|
34
|
+
#pragma include "picking"
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
void main() {
|
|
38
|
+
vec3 extrude = a_Extrude;
|
|
39
|
+
float shape_type = a_Shape;
|
|
40
|
+
/*
|
|
41
|
+
* setPickingSize 设置拾取大小
|
|
42
|
+
* u_meter2coord 在等面积大小的时候设置单位
|
|
43
|
+
*/
|
|
44
|
+
float newSize = setPickingSize(a_Size) * u_meter2coord;
|
|
45
|
+
// float newSize = setPickingSize(a_Size) * 0.00001038445708445579;
|
|
46
|
+
|
|
47
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
48
|
+
styleMappingMat = mat4(
|
|
49
|
+
0.0, 0.0, 0.0, 0.0, // opacity - strokeOpacity - strokeWidth - empty
|
|
50
|
+
0.0, 0.0, 0.0, 0.0, // strokeR - strokeG - strokeB - strokeA
|
|
51
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1]
|
|
52
|
+
0.0, 0.0, 0.0, 0.0
|
|
53
|
+
);
|
|
54
|
+
|
|
55
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
56
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
57
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
58
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
59
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
60
|
+
float id = a_vertexId; // 第n个顶点
|
|
61
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
62
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
63
|
+
|
|
64
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
65
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
66
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
67
|
+
|
|
68
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
69
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
70
|
+
textureOffset = opacityAndOffset.g;
|
|
71
|
+
|
|
72
|
+
vec2 strokeOpacityAndOffset = calStrokeOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
73
|
+
styleMappingMat[0][1] = strokeOpacityAndOffset.r;
|
|
74
|
+
textureOffset = strokeOpacityAndOffset.g;
|
|
75
|
+
|
|
76
|
+
vec2 strokeWidthAndOffset = calStrokeWidthAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
77
|
+
styleMappingMat[0][2] = strokeWidthAndOffset.r;
|
|
78
|
+
textureOffset = strokeWidthAndOffset.g;
|
|
79
|
+
|
|
80
|
+
vec4 textrueStroke = vec4(-1.0, -1.0, -1.0, -1.0);
|
|
81
|
+
if(hasStroke()) {
|
|
82
|
+
vec2 valueRPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
83
|
+
styleMappingMat[1][0] = pos2value(valueRPos, columnWidth, rowHeight); // R
|
|
84
|
+
textureOffset += 1.0;
|
|
85
|
+
|
|
86
|
+
vec2 valueGPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
87
|
+
styleMappingMat[1][1] = pos2value(valueGPos, columnWidth, rowHeight); // G
|
|
88
|
+
textureOffset += 1.0;
|
|
89
|
+
|
|
90
|
+
vec2 valueBPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
91
|
+
styleMappingMat[1][2] = pos2value(valueBPos, columnWidth, rowHeight); // B
|
|
92
|
+
textureOffset += 1.0;
|
|
93
|
+
|
|
94
|
+
vec2 valueAPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
95
|
+
styleMappingMat[1][3] = pos2value(valueAPos, columnWidth, rowHeight); // A
|
|
96
|
+
textureOffset += 1.0;
|
|
97
|
+
} else {
|
|
98
|
+
if(u_stroke_color == vec4(0.0)) {
|
|
99
|
+
styleMappingMat[1][0] = v_color.r;
|
|
100
|
+
styleMappingMat[1][1] = v_color.g;
|
|
101
|
+
styleMappingMat[1][2] = v_color.b;
|
|
102
|
+
styleMappingMat[1][3] = v_color.a;
|
|
103
|
+
} else {
|
|
104
|
+
styleMappingMat[1][0] = u_stroke_color.r;
|
|
105
|
+
styleMappingMat[1][1] = u_stroke_color.g;
|
|
106
|
+
styleMappingMat[1][2] = u_stroke_color.b;
|
|
107
|
+
styleMappingMat[1][3] = u_stroke_color.a;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
vec2 textrueOffsets = vec2(0.0, 0.0);
|
|
112
|
+
if(hasOffsets()) {
|
|
113
|
+
vec2 valueXPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
114
|
+
textrueOffsets.r = pos2value(valueXPos, columnWidth, rowHeight); // x
|
|
115
|
+
textureOffset += 1.0;
|
|
116
|
+
|
|
117
|
+
vec2 valueYPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
118
|
+
textrueOffsets.g = pos2value(valueYPos, columnWidth, rowHeight); // x
|
|
119
|
+
textureOffset += 1.0;
|
|
120
|
+
} else {
|
|
121
|
+
textrueOffsets = u_offsets;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
// cal style mapping
|
|
125
|
+
|
|
126
|
+
// unpack color(vec2)
|
|
127
|
+
v_color = a_Color;
|
|
128
|
+
|
|
129
|
+
// radius(16-bit)
|
|
130
|
+
v_radius = newSize;
|
|
131
|
+
|
|
132
|
+
// TODO: billboard
|
|
133
|
+
// anti-alias
|
|
134
|
+
// float antialiased_blur = -max(u_blur, antialiasblur);
|
|
135
|
+
float antialiasblur = -max(2.0 / u_DevicePixelRatio / newSize, u_blur);
|
|
136
|
+
|
|
137
|
+
vec2 offset = (extrude.xy * (newSize + u_stroke_width) + textrueOffsets);
|
|
138
|
+
vec3 aPosition = a_Position;
|
|
139
|
+
if(u_isMeter < 1.0) {
|
|
140
|
+
// 不以米为实际单位
|
|
141
|
+
offset = project_pixel(offset);
|
|
142
|
+
} else {
|
|
143
|
+
// 以米为实际单位
|
|
144
|
+
if(newSize * pow(2.0, u_Zoom) < 48.0) {
|
|
145
|
+
antialiasblur = max(antialiasblur, -0.05);
|
|
146
|
+
} else if(newSize * pow(2.0, u_Zoom) < 128.0) {
|
|
147
|
+
antialiasblur = max(antialiasblur, -0.6/pow(u_Zoom, 2.0));
|
|
148
|
+
} else {
|
|
149
|
+
antialiasblur = max(antialiasblur, -0.8/pow(u_Zoom, 2.0));
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
153
|
+
aPosition.x += offset.x / u_meteryScale;
|
|
154
|
+
aPosition.y += offset.y;
|
|
155
|
+
offset = vec2(0.0);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
// TODP: /abs(extrude.x) 是为了兼容地球模式
|
|
160
|
+
v_data = vec4(extrude.x/abs(extrude.x), extrude.y/abs(extrude.y), antialiasblur,shape_type);
|
|
161
|
+
|
|
162
|
+
|
|
163
|
+
// vec4 project_pos = project_position(vec4(a_Position.xy, 0.0, 1.0));
|
|
164
|
+
vec4 project_pos = project_position(vec4(aPosition.xy, 0.0, 1.0));
|
|
165
|
+
// gl_Position = project_common_position_to_clipspace(vec4(project_pos.xy + offset, project_pixel(setPickingOrder(0.0)), 1.0));
|
|
166
|
+
|
|
167
|
+
float raiseHeight = u_raisingHeight;
|
|
168
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
169
|
+
float mapboxZoomScale = 4.0/pow(2.0, 21.0 - u_Zoom);
|
|
170
|
+
raiseHeight = u_raisingHeight * mapboxZoomScale;
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
174
|
+
gl_Position = u_Mvp * vec4(project_pos.xy + offset, raiseHeight, 1.0);
|
|
175
|
+
} else {
|
|
176
|
+
gl_Position = project_common_position_to_clipspace(vec4(project_pos.xy + offset, u_raisingHeight, 1.0));
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
// gl_Position = project_common_position_to_clipspace(vec4(project_pos.xy + offset, 0.0, 1.0));
|
|
180
|
+
|
|
181
|
+
setPickingColor(a_PickingColor);
|
|
182
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
uniform sampler2D u_texture;
|
|
2
|
+
uniform vec2 u_textSize;
|
|
3
|
+
|
|
4
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
5
|
+
|
|
6
|
+
#pragma include "sdf_2d"
|
|
7
|
+
#pragma include "picking"
|
|
8
|
+
varying vec2 v_uv; // 本身的 uv 坐标
|
|
9
|
+
varying vec2 v_Iconuv;
|
|
10
|
+
|
|
11
|
+
void main() {
|
|
12
|
+
|
|
13
|
+
float opacity = styleMappingMat[0][0];
|
|
14
|
+
|
|
15
|
+
vec2 pos = v_Iconuv / u_textSize + v_uv / u_textSize * 64.;
|
|
16
|
+
gl_FragColor = texture2D(u_texture, pos);
|
|
17
|
+
gl_FragColor.a *= opacity;
|
|
18
|
+
|
|
19
|
+
gl_FragColor = filterColor(gl_FragColor);
|
|
20
|
+
}
|
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
attribute vec4 a_Color;
|
|
2
|
+
attribute vec3 a_Position;
|
|
3
|
+
attribute vec3 a_Extrude;
|
|
4
|
+
attribute float a_Size;
|
|
5
|
+
attribute vec2 a_Uv;
|
|
6
|
+
attribute float a_Rotate;
|
|
7
|
+
|
|
8
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
9
|
+
|
|
10
|
+
uniform mat4 u_ModelMatrix;
|
|
11
|
+
uniform mat4 u_Mvp;
|
|
12
|
+
uniform mat2 u_RotateMatrix;
|
|
13
|
+
uniform float u_isMeter;
|
|
14
|
+
|
|
15
|
+
varying vec2 v_uv; // 本身的 uv 坐标
|
|
16
|
+
varying vec2 v_Iconuv; // icon 贴图的 uv 坐标
|
|
17
|
+
|
|
18
|
+
uniform float u_opacity : 1;
|
|
19
|
+
uniform vec2 u_offsets;
|
|
20
|
+
|
|
21
|
+
#pragma include "styleMapping"
|
|
22
|
+
#pragma include "styleMappingCalOpacity"
|
|
23
|
+
|
|
24
|
+
#pragma include "projection"
|
|
25
|
+
#pragma include "picking"
|
|
26
|
+
|
|
27
|
+
void main() {
|
|
28
|
+
vec3 extrude = a_Extrude;
|
|
29
|
+
|
|
30
|
+
v_uv = (a_Extrude.xy + 1.0)/2.0;
|
|
31
|
+
v_uv.y = 1.0 - v_uv.y;
|
|
32
|
+
v_Iconuv = a_Uv;
|
|
33
|
+
|
|
34
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
35
|
+
styleMappingMat = mat4(
|
|
36
|
+
0.0, 0.0, 0.0, 0.0, // opacity - empty - empty - empty
|
|
37
|
+
0.0, 0.0, 0.0, 0.0, // empty - empty - empty - empty
|
|
38
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1]
|
|
39
|
+
0.0, 0.0, 0.0, 0.0
|
|
40
|
+
);
|
|
41
|
+
|
|
42
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
43
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
44
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
45
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
46
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
47
|
+
float id = a_vertexId; // 第n个顶点
|
|
48
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
49
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
50
|
+
|
|
51
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
52
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
53
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
54
|
+
|
|
55
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
56
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
57
|
+
textureOffset = opacityAndOffset.g;
|
|
58
|
+
|
|
59
|
+
vec2 textrueOffsets = vec2(0.0, 0.0);
|
|
60
|
+
if(hasOffsets()) {
|
|
61
|
+
vec2 valueXPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
62
|
+
textrueOffsets.r = pos2value(valueXPos, columnWidth, rowHeight); // x
|
|
63
|
+
textureOffset += 1.0;
|
|
64
|
+
|
|
65
|
+
vec2 valueYPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
66
|
+
textrueOffsets.g = pos2value(valueYPos, columnWidth, rowHeight); // x
|
|
67
|
+
textureOffset += 1.0;
|
|
68
|
+
} else {
|
|
69
|
+
textrueOffsets = u_offsets;
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
// cal style mapping
|
|
73
|
+
|
|
74
|
+
highp float angle_sin = sin(a_Rotate);
|
|
75
|
+
highp float angle_cos = cos(a_Rotate);
|
|
76
|
+
mat2 rotation_matrix = mat2(angle_cos, -1.0 * angle_sin, angle_sin, angle_cos);
|
|
77
|
+
|
|
78
|
+
// vec2 offset = (u_RotateMatrix * extrude.xy * (a_Size) + textrueOffsets);
|
|
79
|
+
vec2 offset = (rotation_matrix * u_RotateMatrix * extrude.xy * (a_Size) + textrueOffsets);
|
|
80
|
+
vec3 aPosition = a_Position;
|
|
81
|
+
if(u_isMeter < 1.0) {
|
|
82
|
+
// 不以米为实际单位
|
|
83
|
+
offset = project_pixel(offset);
|
|
84
|
+
} else {
|
|
85
|
+
// 以米为实际单位
|
|
86
|
+
|
|
87
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
88
|
+
aPosition.xy += offset;
|
|
89
|
+
offset.x = 0.0;
|
|
90
|
+
offset.y = 0.0;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
|
|
95
|
+
// vec4 project_pos = project_position(vec4(a_Position.xy, 0.0, 1.0));
|
|
96
|
+
vec4 project_pos = project_position(vec4(aPosition.xy, 0.0, 1.0));
|
|
97
|
+
// gl_Position = project_common_position_to_clipspace(vec4(project_pos.xy + offset, project_pixel(setPickingOrder(0.0)), 1.0));
|
|
98
|
+
|
|
99
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
100
|
+
gl_Position = u_Mvp * vec4(project_pos.xy + offset, 0.0, 1.0);
|
|
101
|
+
} else {
|
|
102
|
+
gl_Position = project_common_position_to_clipspace(vec4(project_pos.xy + offset, project_pixel(setPickingOrder(0.0)), 1.0));
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// gl_Position = project_common_position_to_clipspace(vec4(project_pos.xy + offset, 0.0, 1.0));
|
|
106
|
+
|
|
107
|
+
setPickingColor(a_PickingColor);
|
|
108
|
+
}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
|
|
2
|
+
uniform sampler2D u_texture;
|
|
3
|
+
varying vec4 v_color;
|
|
4
|
+
varying vec2 v_uv;
|
|
5
|
+
uniform vec2 u_textSize;
|
|
6
|
+
uniform float u_opacity : 1;
|
|
7
|
+
|
|
8
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
9
|
+
|
|
10
|
+
#pragma include "picking"
|
|
11
|
+
|
|
12
|
+
void main(){
|
|
13
|
+
float opacity = styleMappingMat[0][0];
|
|
14
|
+
float size = styleMappingMat[1][0];
|
|
15
|
+
vec2 pos = v_uv / u_textSize + gl_PointCoord / u_textSize * 64.;
|
|
16
|
+
vec4 textureColor;
|
|
17
|
+
|
|
18
|
+
// Y = 0.299R + 0.587G + 0.114B // 亮度提取
|
|
19
|
+
|
|
20
|
+
textureColor = texture2D(u_texture, pos);
|
|
21
|
+
|
|
22
|
+
// Tip: 去除边缘部分 mipmap 导致的混合变暗
|
|
23
|
+
float fragmengTocenter = distance(vec2(0.5), gl_PointCoord);
|
|
24
|
+
if(fragmengTocenter >= 0.5) {
|
|
25
|
+
float luma = 0.299 * textureColor.r + 0.587 * textureColor.g + 0.114 * textureColor.b;
|
|
26
|
+
textureColor.a *= luma;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
|
|
31
|
+
if(all(lessThan(v_color, vec4(1.0+0.00001))) && all(greaterThan(v_color, vec4(1.0-0.00001))) || v_color==vec4(1.0)){
|
|
32
|
+
gl_FragColor= textureColor;
|
|
33
|
+
}else {
|
|
34
|
+
gl_FragColor= step(0.01, textureColor.z) * v_color;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
gl_FragColor.a = gl_FragColor.a * opacity;
|
|
38
|
+
gl_FragColor = filterColor(gl_FragColor);
|
|
39
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
precision highp float;
|
|
2
|
+
attribute vec3 a_Position;
|
|
3
|
+
attribute vec4 a_Color;
|
|
4
|
+
attribute vec2 a_Uv;
|
|
5
|
+
attribute float a_Size;
|
|
6
|
+
varying vec4 v_color;
|
|
7
|
+
varying vec2 v_uv;
|
|
8
|
+
uniform mat4 u_ModelMatrix;
|
|
9
|
+
uniform mat4 u_Mvp;
|
|
10
|
+
uniform vec2 u_offsets;
|
|
11
|
+
|
|
12
|
+
uniform float u_opacity : 1;
|
|
13
|
+
|
|
14
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
15
|
+
|
|
16
|
+
#pragma include "styleMapping"
|
|
17
|
+
#pragma include "styleMappingCalOpacity"
|
|
18
|
+
|
|
19
|
+
#pragma include "projection"
|
|
20
|
+
#pragma include "picking"
|
|
21
|
+
|
|
22
|
+
void main() {
|
|
23
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
24
|
+
styleMappingMat = mat4(
|
|
25
|
+
0.0, 0.0, 0.0, 0.0, // opacity - strokeOpacity - strokeWidth - empty
|
|
26
|
+
0.0, 0.0, 0.0, 0.0, // strokeR - strokeG - strokeB - strokeA
|
|
27
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1]
|
|
28
|
+
0.0, 0.0, 0.0, 0.0
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
32
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
33
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
34
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
35
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
36
|
+
float id = a_vertexId; // 第n个顶点
|
|
37
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
38
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
39
|
+
|
|
40
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
41
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
42
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
43
|
+
|
|
44
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
45
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
46
|
+
textureOffset = opacityAndOffset.g;
|
|
47
|
+
|
|
48
|
+
styleMappingMat[1][0] = a_Size;
|
|
49
|
+
|
|
50
|
+
vec2 textrueOffsets = vec2(0.0, 0.0);
|
|
51
|
+
if(hasOffsets()) {
|
|
52
|
+
vec2 valueXPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
53
|
+
textrueOffsets.r = pos2value(valueXPos, columnWidth, rowHeight); // x
|
|
54
|
+
textureOffset += 1.0;
|
|
55
|
+
|
|
56
|
+
vec2 valueYPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
57
|
+
textrueOffsets.g = pos2value(valueYPos, columnWidth, rowHeight); // x
|
|
58
|
+
textureOffset += 1.0;
|
|
59
|
+
} else {
|
|
60
|
+
textrueOffsets = u_offsets;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
64
|
+
v_color = a_Color;
|
|
65
|
+
v_uv = a_Uv;
|
|
66
|
+
vec4 project_pos = project_position(vec4(a_Position, 1.0));
|
|
67
|
+
|
|
68
|
+
// vec2 offset = project_pixel(u_offsets);
|
|
69
|
+
vec2 offset = project_pixel(textrueOffsets);
|
|
70
|
+
|
|
71
|
+
// gl_Position = project_common_position_to_clipspace(vec4(vec2(project_pos.xy + offset),project_pos.z, 1.0));
|
|
72
|
+
|
|
73
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
74
|
+
gl_Position = u_Mvp * vec4(vec2(project_pos.xy + offset),project_pos.z, 1.0);
|
|
75
|
+
} else {
|
|
76
|
+
gl_Position = project_common_position_to_clipspace(vec4(vec2(project_pos.xy + offset),project_pos.z, 1.0));
|
|
77
|
+
}
|
|
78
|
+
gl_PointSize = a_Size * 2.0 * u_DevicePixelRatio;
|
|
79
|
+
|
|
80
|
+
setPickingColor(a_PickingColor);
|
|
81
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
|
|
2
|
+
uniform float u_opacity : 1;
|
|
3
|
+
uniform vec2 u_offsets;
|
|
4
|
+
varying vec4 v_color;
|
|
5
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
6
|
+
|
|
7
|
+
#pragma include "picking"
|
|
8
|
+
void main() {
|
|
9
|
+
float opacity = styleMappingMat[0][0];
|
|
10
|
+
|
|
11
|
+
gl_FragColor = v_color;
|
|
12
|
+
// gl_FragColor.a =gl_FragColor.a * u_opacity;
|
|
13
|
+
gl_FragColor.a =gl_FragColor.a * opacity;
|
|
14
|
+
gl_FragColor = filterColor(gl_FragColor);
|
|
15
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
|
|
2
|
+
attribute vec3 a_Position;
|
|
3
|
+
uniform mat4 u_ModelMatrix;
|
|
4
|
+
uniform mat4 u_Mvp;
|
|
5
|
+
attribute float a_Size;
|
|
6
|
+
attribute vec4 a_Color;
|
|
7
|
+
varying vec4 v_color;
|
|
8
|
+
|
|
9
|
+
uniform float u_opacity : 1;
|
|
10
|
+
uniform vec2 u_offsets;
|
|
11
|
+
|
|
12
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
13
|
+
|
|
14
|
+
#pragma include "styleMapping"
|
|
15
|
+
#pragma include "styleMappingCalOpacity"
|
|
16
|
+
|
|
17
|
+
#pragma include "projection"
|
|
18
|
+
#pragma include "picking"
|
|
19
|
+
#pragma include "project"
|
|
20
|
+
void main() {
|
|
21
|
+
v_color = a_Color;
|
|
22
|
+
|
|
23
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
24
|
+
styleMappingMat = mat4(
|
|
25
|
+
0.0, 0.0, 0.0, 0.0, // opacity - strokeOpacity - strokeWidth - empty
|
|
26
|
+
0.0, 0.0, 0.0, 0.0, // strokeR - strokeG - strokeB - strokeA
|
|
27
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1]
|
|
28
|
+
0.0, 0.0, 0.0, 0.0
|
|
29
|
+
);
|
|
30
|
+
|
|
31
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
32
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
33
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
34
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
35
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
36
|
+
float id = a_vertexId; // 第n个顶点
|
|
37
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
38
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
39
|
+
|
|
40
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
41
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
42
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
43
|
+
|
|
44
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
45
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
46
|
+
textureOffset = opacityAndOffset.g;
|
|
47
|
+
|
|
48
|
+
vec2 textrueOffsets = vec2(0.0, 0.0);
|
|
49
|
+
if(hasOffsets()) {
|
|
50
|
+
vec2 valueXPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
51
|
+
textrueOffsets.r = pos2value(valueXPos, columnWidth, rowHeight); // x
|
|
52
|
+
textureOffset += 1.0;
|
|
53
|
+
|
|
54
|
+
vec2 valueYPos = nextPos(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset);
|
|
55
|
+
textrueOffsets.g = pos2value(valueYPos, columnWidth, rowHeight); // x
|
|
56
|
+
textureOffset += 1.0;
|
|
57
|
+
} else {
|
|
58
|
+
textrueOffsets = u_offsets;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// cal style mapping
|
|
62
|
+
|
|
63
|
+
// vec2 offset = project_pixel(u_offsets);
|
|
64
|
+
vec2 offset = project_pixel(textrueOffsets);
|
|
65
|
+
// vec4 project_pos = project_position(vec4(a_Position, 1.0)) + vec4(a_Size / 2.,-a_Size /2.,0.,0.);
|
|
66
|
+
// gl_Position = project_common_position_to_clipspace(vec4(vec2(project_pos.xy+offset),project_pos.z,project_pos.w));\
|
|
67
|
+
//
|
|
68
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
69
|
+
// vec2 offset = project_pixel((u_offsets));
|
|
70
|
+
gl_Position = u_Mvp * vec4(a_Position.xy + offset, a_Position.z, 1.0);
|
|
71
|
+
} else { // else
|
|
72
|
+
// vec2 offset = project_pixel(u_offsets);
|
|
73
|
+
vec4 project_pos = project_position(vec4(a_Position, 1.0)) + vec4(a_Size / 2.,-a_Size /2.,0.,0.);
|
|
74
|
+
gl_Position = project_common_position_to_clipspace(vec4(vec2(project_pos.xy+offset),project_pos.z,project_pos.w));
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
gl_PointSize = a_Size * 2.0 * u_DevicePixelRatio;
|
|
78
|
+
setPickingColor(a_PickingColor);
|
|
79
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
|
|
2
|
+
uniform float u_additive;
|
|
3
|
+
|
|
4
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
5
|
+
|
|
6
|
+
varying vec4 v_data;
|
|
7
|
+
varying vec4 v_color;
|
|
8
|
+
varying float v_radius;
|
|
9
|
+
|
|
10
|
+
#pragma include "sdf_2d"
|
|
11
|
+
#pragma include "picking"
|
|
12
|
+
|
|
13
|
+
void main() {
|
|
14
|
+
int shape = int(floor(v_data.w + 0.5));
|
|
15
|
+
|
|
16
|
+
vec4 textrueStroke = vec4(
|
|
17
|
+
styleMappingMat[1][0],
|
|
18
|
+
styleMappingMat[1][1],
|
|
19
|
+
styleMappingMat[1][2],
|
|
20
|
+
styleMappingMat[1][3]
|
|
21
|
+
);
|
|
22
|
+
|
|
23
|
+
float opacity = styleMappingMat[0][0];
|
|
24
|
+
|
|
25
|
+
lowp float antialiasblur = v_data.z;
|
|
26
|
+
float r = v_radius / (v_radius);
|
|
27
|
+
|
|
28
|
+
float outer_df = sdCircle(v_data.xy, 1.0);
|
|
29
|
+
float inner_df = sdCircle(v_data.xy, r);
|
|
30
|
+
|
|
31
|
+
float opacity_t = smoothstep(0.0, antialiasblur, outer_df);
|
|
32
|
+
|
|
33
|
+
gl_FragColor = vec4(v_color.rgb, v_color.a * opacity);
|
|
34
|
+
|
|
35
|
+
if(u_additive > 0.0) {
|
|
36
|
+
gl_FragColor *= opacity_t;
|
|
37
|
+
} else {
|
|
38
|
+
gl_FragColor.a *= opacity_t;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
if(gl_FragColor.a > 0.0) {
|
|
42
|
+
gl_FragColor = filterColor(gl_FragColor);
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
vec2 extrude = styleMappingMat[2].ba;
|
|
46
|
+
vec2 dir = normalize(extrude);
|
|
47
|
+
vec2 baseDir = vec2(1.0, 0.0);
|
|
48
|
+
float pi = 3.14159265359;
|
|
49
|
+
// full circle
|
|
50
|
+
// float rades = dot(dir, baseDir);
|
|
51
|
+
// float flag = sign(dir.y);
|
|
52
|
+
// float radar_v = (flag - 1.0) * -0.5 + flag * acos(rades)/pi/2.0;
|
|
53
|
+
|
|
54
|
+
// half circle
|
|
55
|
+
float flag = sign(dir.y);
|
|
56
|
+
float rades = dot(dir, baseDir);
|
|
57
|
+
float radar_v = (flag - 1.0) * -0.5 * acos(rades)/pi;
|
|
58
|
+
// simple AA
|
|
59
|
+
if(radar_v > 0.99) {
|
|
60
|
+
radar_v = 1.0 - (radar_v - 0.99)/0.01;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
gl_FragColor.a *= radar_v;
|
|
64
|
+
}
|