@antv/l7-layers 2.9.19 → 2.9.22-alpha.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/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.d.ts +1 -0
- package/es/core/triangulation.js +123 -24
- 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.d.ts +15 -0
- package/es/utils/extrude_polyline.js +225 -51
- 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 +208 -295
- 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 +405 -428
- 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
|
@@ -47,24 +47,12 @@ function getArrayUnique(matrix) {
|
|
|
47
47
|
return matrix;
|
|
48
48
|
}
|
|
49
49
|
|
|
50
|
-
var ExtrudePolyline = function () {
|
|
50
|
+
var ExtrudePolyline = /*#__PURE__*/function () {
|
|
51
51
|
function ExtrudePolyline() {
|
|
52
52
|
var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
53
53
|
|
|
54
54
|
_classCallCheck(this, ExtrudePolyline);
|
|
55
55
|
|
|
56
|
-
_defineProperty(this, "complex", void 0);
|
|
57
|
-
|
|
58
|
-
_defineProperty(this, "join", void 0);
|
|
59
|
-
|
|
60
|
-
_defineProperty(this, "cap", void 0);
|
|
61
|
-
|
|
62
|
-
_defineProperty(this, "miterLimit", void 0);
|
|
63
|
-
|
|
64
|
-
_defineProperty(this, "thickness", void 0);
|
|
65
|
-
|
|
66
|
-
_defineProperty(this, "normal", void 0);
|
|
67
|
-
|
|
68
56
|
_defineProperty(this, "lastFlip", -1);
|
|
69
57
|
|
|
70
58
|
_defineProperty(this, "miter", vec2.fromValues(0, 0));
|
|
@@ -92,8 +80,8 @@ var ExtrudePolyline = function () {
|
|
|
92
80
|
}
|
|
93
81
|
|
|
94
82
|
_createClass(ExtrudePolyline, [{
|
|
95
|
-
key: "
|
|
96
|
-
value: function
|
|
83
|
+
key: "simpleExtrude",
|
|
84
|
+
value: function simpleExtrude(points) {
|
|
97
85
|
var complex = this.complex;
|
|
98
86
|
|
|
99
87
|
if (points.length <= 1) {
|
|
@@ -107,24 +95,115 @@ var ExtrudePolyline = function () {
|
|
|
107
95
|
var total = points.length;
|
|
108
96
|
var count = complex.startIndex;
|
|
109
97
|
|
|
98
|
+
for (var i = 1; i < total; i++) {
|
|
99
|
+
var last = points[i - 1];
|
|
100
|
+
var cur = points[i];
|
|
101
|
+
var next = i < points.length - 1 ? points[i + 1] : null;
|
|
102
|
+
var amt = this.simpleSegment(complex, count, last, cur, next);
|
|
103
|
+
count += amt;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
if (this.dash) {
|
|
107
|
+
for (var _i = 0; _i < complex.positions.length / 6; _i++) {
|
|
108
|
+
complex.positions[_i * 6 + 5] = this.totalDistance;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
complex.startIndex = complex.positions.length / 6;
|
|
113
|
+
return complex;
|
|
114
|
+
}
|
|
115
|
+
}, {
|
|
116
|
+
key: "simpleExtrude_gaode2",
|
|
117
|
+
value: function simpleExtrude_gaode2(points, originPoints) {
|
|
118
|
+
var complex = this.complex;
|
|
119
|
+
|
|
120
|
+
if (points.length <= 1) {
|
|
121
|
+
return complex;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
this.lastFlip = -1;
|
|
125
|
+
this.started = false;
|
|
126
|
+
this.normal = null;
|
|
127
|
+
this.totalDistance = 0; // 去除数组里重复的点
|
|
128
|
+
// points = getArrayUnique(points);
|
|
129
|
+
|
|
130
|
+
var total = points.length;
|
|
131
|
+
var count = complex.startIndex;
|
|
132
|
+
|
|
110
133
|
for (var i = 1; i < total; i++) {
|
|
111
134
|
var _originPoints$, _originPoints$i$, _originPoints$2;
|
|
112
135
|
|
|
113
136
|
var last = points[i - 1];
|
|
114
|
-
last.push((_originPoints$ = originPoints[i - 1][2]) !== null && _originPoints$ !== void 0 ? _originPoints$ : 0);
|
|
137
|
+
last.push((_originPoints$ = originPoints[i - 1][2]) !== null && _originPoints$ !== void 0 ? _originPoints$ : 0); // @ts-ignore
|
|
138
|
+
|
|
115
139
|
var originLast = originPoints[i - 1];
|
|
116
140
|
var cur = points[i];
|
|
117
|
-
cur.push((_originPoints$i$ = originPoints[i][2]) !== null && _originPoints$i$ !== void 0 ? _originPoints$i$ : 0);
|
|
141
|
+
cur.push((_originPoints$i$ = originPoints[i][2]) !== null && _originPoints$i$ !== void 0 ? _originPoints$i$ : 0); // @ts-ignore
|
|
142
|
+
|
|
118
143
|
var originCur = originPoints[i];
|
|
119
144
|
var next = i < points.length - 1 ? [].concat(_toConsumableArray(points[i + 1]), [(_originPoints$2 = originPoints[i + 1][2]) !== null && _originPoints$2 !== void 0 ? _originPoints$2 : 0]) : null;
|
|
120
145
|
var originNext = i < originPoints.length - 1 ? originPoints[i + 1] : null;
|
|
121
|
-
var amt = this.
|
|
146
|
+
var amt = this.simpleSegment(complex, count, // @ts-ignore
|
|
147
|
+
last, // @ts-ignore
|
|
148
|
+
cur, // @ts-ignore
|
|
149
|
+
next, // @ts-ignore
|
|
150
|
+
originLast, originCur, // @ts-ignore
|
|
151
|
+
originNext);
|
|
122
152
|
count += amt;
|
|
123
153
|
}
|
|
124
154
|
|
|
125
155
|
if (this.dash) {
|
|
126
|
-
for (var
|
|
127
|
-
complex.positions[
|
|
156
|
+
for (var _i2 = 0; _i2 < complex.positions.length / 6; _i2++) {
|
|
157
|
+
complex.positions[_i2 * 6 + 5] = this.totalDistance;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
complex.startIndex = complex.positions.length / 6;
|
|
162
|
+
return complex;
|
|
163
|
+
}
|
|
164
|
+
}, {
|
|
165
|
+
key: "extrude_gaode2",
|
|
166
|
+
value: function extrude_gaode2(points, originPoints) {
|
|
167
|
+
var complex = this.complex;
|
|
168
|
+
|
|
169
|
+
if (points.length <= 1) {
|
|
170
|
+
return complex;
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
this.lastFlip = -1;
|
|
174
|
+
this.started = false;
|
|
175
|
+
this.normal = null;
|
|
176
|
+
this.totalDistance = 0; // 去除数组里重复的点
|
|
177
|
+
// points = getArrayUnique(points);
|
|
178
|
+
|
|
179
|
+
var total = points.length;
|
|
180
|
+
var count = complex.startIndex;
|
|
181
|
+
|
|
182
|
+
for (var i = 1; i < total; i++) {
|
|
183
|
+
var _originPoints$3, _originPoints$i$2, _originPoints$4;
|
|
184
|
+
|
|
185
|
+
var last = points[i - 1];
|
|
186
|
+
last.push((_originPoints$3 = originPoints[i - 1][2]) !== null && _originPoints$3 !== void 0 ? _originPoints$3 : 0); // @ts-ignore
|
|
187
|
+
|
|
188
|
+
var originLast = originPoints[i - 1];
|
|
189
|
+
var cur = points[i];
|
|
190
|
+
cur.push((_originPoints$i$2 = originPoints[i][2]) !== null && _originPoints$i$2 !== void 0 ? _originPoints$i$2 : 0); // @ts-ignore
|
|
191
|
+
|
|
192
|
+
var originCur = originPoints[i];
|
|
193
|
+
var next = i < points.length - 1 ? [].concat(_toConsumableArray(points[i + 1]), [(_originPoints$4 = originPoints[i + 1][2]) !== null && _originPoints$4 !== void 0 ? _originPoints$4 : 0]) : null;
|
|
194
|
+
var originNext = i < originPoints.length - 1 ? originPoints[i + 1] : null;
|
|
195
|
+
var amt = this.segment_gaode2(complex, count, // @ts-ignore
|
|
196
|
+
last, // @ts-ignore
|
|
197
|
+
cur, // @ts-ignore
|
|
198
|
+
next, // @ts-ignore
|
|
199
|
+
originLast, originCur, // @ts-ignore
|
|
200
|
+
originNext);
|
|
201
|
+
count += amt;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
if (this.dash) {
|
|
205
|
+
for (var _i3 = 0; _i3 < complex.positions.length / 6; _i3++) {
|
|
206
|
+
complex.positions[_i3 * 6 + 5] = this.totalDistance;
|
|
128
207
|
}
|
|
129
208
|
}
|
|
130
209
|
|
|
@@ -143,7 +222,9 @@ var ExtrudePolyline = function () {
|
|
|
143
222
|
this.lastFlip = -1;
|
|
144
223
|
this.started = false;
|
|
145
224
|
this.normal = null;
|
|
146
|
-
this.totalDistance = 0;
|
|
225
|
+
this.totalDistance = 0; // 去除数组里重复的点
|
|
226
|
+
// points = getArrayUnique(points);
|
|
227
|
+
|
|
147
228
|
var total = points.length;
|
|
148
229
|
var count = complex.startIndex;
|
|
149
230
|
|
|
@@ -156,14 +237,78 @@ var ExtrudePolyline = function () {
|
|
|
156
237
|
}
|
|
157
238
|
|
|
158
239
|
if (this.dash) {
|
|
159
|
-
for (var
|
|
160
|
-
complex.positions[
|
|
240
|
+
for (var _i4 = 0; _i4 < complex.positions.length / 6; _i4++) {
|
|
241
|
+
complex.positions[_i4 * 6 + 5] = this.totalDistance;
|
|
161
242
|
}
|
|
162
243
|
}
|
|
163
244
|
|
|
164
245
|
complex.startIndex = complex.positions.length / 6;
|
|
165
246
|
return complex;
|
|
166
247
|
}
|
|
248
|
+
}, {
|
|
249
|
+
key: "simpleSegment",
|
|
250
|
+
value: function simpleSegment(complex, index, last, cur, next) {
|
|
251
|
+
var count = 0;
|
|
252
|
+
var indices = complex.indices;
|
|
253
|
+
var positions = complex.positions;
|
|
254
|
+
var normals = complex.normals;
|
|
255
|
+
var flatCur = aProjectFlat([cur[0], cur[1]]);
|
|
256
|
+
var flatLast = aProjectFlat([last[0], last[1]]); // @ts-ignore
|
|
257
|
+
|
|
258
|
+
direction(lineA, flatCur, flatLast);
|
|
259
|
+
var segmentDistance = 0;
|
|
260
|
+
|
|
261
|
+
if (this.dash) {
|
|
262
|
+
// @ts-ignore
|
|
263
|
+
segmentDistance = this.lineSegmentDistance(flatCur, flatLast);
|
|
264
|
+
this.totalDistance += segmentDistance;
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
if (!this.normal) {
|
|
268
|
+
this.normal = vec2.create();
|
|
269
|
+
computeNormal(this.normal, lineA);
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
if (!this.started) {
|
|
273
|
+
this.started = true;
|
|
274
|
+
this.extrusions(positions, normals, last, this.normal, this.thickness, this.totalDistance - segmentDistance);
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
indices.push(index + 0, index + 1, index + 2);
|
|
278
|
+
|
|
279
|
+
if (!next) {
|
|
280
|
+
computeNormal(this.normal, lineA);
|
|
281
|
+
this.extrusions(positions, normals, cur, this.normal, this.thickness, this.totalDistance);
|
|
282
|
+
indices.push.apply(indices, _toConsumableArray(this.lastFlip === 1 ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]));
|
|
283
|
+
count += 2;
|
|
284
|
+
} else {
|
|
285
|
+
var flatNext = aProjectFlat([next[0], next[1]]);
|
|
286
|
+
|
|
287
|
+
if (isPointEqual(flatCur, flatNext)) {
|
|
288
|
+
vec2.add(flatNext, flatCur, vec2.normalize(flatNext, vec2.subtract(flatNext, flatCur, flatLast)));
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
direction(lineB, flatNext, flatCur); // stores tangent & miter
|
|
292
|
+
|
|
293
|
+
var _computeMiter = computeMiter(tangent, vec2.create(), lineA, lineB, this.thickness),
|
|
294
|
+
_computeMiter2 = _slicedToArray(_computeMiter, 2),
|
|
295
|
+
miterLen = _computeMiter2[0],
|
|
296
|
+
miter = _computeMiter2[1]; // normal(tmp, lineA)
|
|
297
|
+
// get orientation
|
|
298
|
+
|
|
299
|
+
|
|
300
|
+
var flip = vec2.dot(tangent, this.normal) < 0 ? -1 : 1;
|
|
301
|
+
this.extrusions(positions, normals, cur, miter, miterLen, this.totalDistance);
|
|
302
|
+
indices.push.apply(indices, _toConsumableArray(this.lastFlip === 1 ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]));
|
|
303
|
+
flip = -1; // the miter is now the normal for our next join
|
|
304
|
+
|
|
305
|
+
vec2.copy(this.normal, miter);
|
|
306
|
+
count += 2;
|
|
307
|
+
this.lastFlip = flip;
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
return count;
|
|
311
|
+
}
|
|
167
312
|
}, {
|
|
168
313
|
key: "segment_gaode2",
|
|
169
314
|
value: function segment_gaode2(complex, index, last, cur, next, originLast, originCur, originNext) {
|
|
@@ -174,11 +319,13 @@ var ExtrudePolyline = function () {
|
|
|
174
319
|
var capSquare = this.cap === 'square';
|
|
175
320
|
var joinBevel = this.join === 'bevel';
|
|
176
321
|
var flatCur = aProjectFlat([originCur[0], originCur[1]]);
|
|
177
|
-
var flatLast = aProjectFlat([originLast[0], originLast[1]]);
|
|
322
|
+
var flatLast = aProjectFlat([originLast[0], originLast[1]]); // @ts-ignore
|
|
323
|
+
|
|
178
324
|
direction(lineA, cur, last);
|
|
179
325
|
var segmentDistance = 0;
|
|
180
326
|
|
|
181
327
|
if (this.dash) {
|
|
328
|
+
// @ts-ignore
|
|
182
329
|
segmentDistance = this.lineSegmentDistance(flatCur, flatLast);
|
|
183
330
|
this.totalDistance += segmentDistance;
|
|
184
331
|
}
|
|
@@ -189,9 +336,10 @@ var ExtrudePolyline = function () {
|
|
|
189
336
|
}
|
|
190
337
|
|
|
191
338
|
if (!this.started) {
|
|
192
|
-
this.started = true;
|
|
339
|
+
this.started = true; // if the end cap is type square, we can just push the verts out a bit
|
|
193
340
|
|
|
194
341
|
if (capSquare) {
|
|
342
|
+
// vec2.scaleAndAdd(capEnd, last, lineA, -this.thickness);
|
|
195
343
|
var out1 = vec2.create();
|
|
196
344
|
var out2 = vec2.create();
|
|
197
345
|
vec2.add(out1, this.normal, lineA);
|
|
@@ -234,16 +382,24 @@ var ExtrudePolyline = function () {
|
|
|
234
382
|
indices.push.apply(indices, _toConsumableArray(this.lastFlip === 1 ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]));
|
|
235
383
|
count += 2;
|
|
236
384
|
} else {
|
|
385
|
+
// @ts-ignore
|
|
237
386
|
if (isPointEqual(cur, next)) {
|
|
238
|
-
vec2.add(
|
|
239
|
-
|
|
387
|
+
vec2.add( // @ts-ignore
|
|
388
|
+
next, // @ts-ignore
|
|
389
|
+
cur, vec2.normalize( // @ts-ignore
|
|
390
|
+
next, // @ts-ignore
|
|
391
|
+
vec2.subtract(next, cur, last)));
|
|
392
|
+
} // @ts-ignore
|
|
240
393
|
|
|
241
|
-
direction(lineB, next, cur);
|
|
242
394
|
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
395
|
+
direction(lineB, next, cur); // stores tangent & miter
|
|
396
|
+
|
|
397
|
+
var _computeMiter3 = computeMiter(tangent, vec2.create(), lineA, lineB, this.thickness),
|
|
398
|
+
_computeMiter4 = _slicedToArray(_computeMiter3, 2),
|
|
399
|
+
miterLen = _computeMiter4[0],
|
|
400
|
+
miter = _computeMiter4[1]; // normal(tmp, lineA)
|
|
401
|
+
// get orientation
|
|
402
|
+
|
|
247
403
|
|
|
248
404
|
var flip = vec2.dot(tangent, this.normal) < 0 ? -1 : 1;
|
|
249
405
|
var bevel = joinBevel;
|
|
@@ -264,10 +420,12 @@ var ExtrudePolyline = function () {
|
|
|
264
420
|
positions.push(cur[0], cur[1], cur[2] | 0, this.totalDistance, this.thickness * flip, cur[2] | 0);
|
|
265
421
|
this.complex.indexes.push(this.currentIndex);
|
|
266
422
|
this.currentIndex++;
|
|
267
|
-
indices.push.apply(indices, _toConsumableArray(this.lastFlip !== -flip ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]));
|
|
423
|
+
indices.push.apply(indices, _toConsumableArray(this.lastFlip !== -flip ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3])); // now add the bevel triangle
|
|
424
|
+
|
|
268
425
|
indices.push(index + 2, index + 3, index + 4);
|
|
269
426
|
computeNormal(tmp, lineB);
|
|
270
|
-
vec2.copy(this.normal, tmp);
|
|
427
|
+
vec2.copy(this.normal, tmp); // store normal for next round
|
|
428
|
+
|
|
271
429
|
normals.push(this.normal[0], this.normal[1], 0);
|
|
272
430
|
positions.push(cur[0], cur[1], cur[2] | 0, this.totalDistance, -this.thickness * flip, cur[2] | 0);
|
|
273
431
|
this.complex.indexes.push(this.currentIndex);
|
|
@@ -276,7 +434,8 @@ var ExtrudePolyline = function () {
|
|
|
276
434
|
} else {
|
|
277
435
|
this.extrusions(positions, normals, cur, miter, miterLen, this.totalDistance);
|
|
278
436
|
indices.push.apply(indices, _toConsumableArray(this.lastFlip === 1 ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]));
|
|
279
|
-
flip = -1;
|
|
437
|
+
flip = -1; // the miter is now the normal for our next join
|
|
438
|
+
|
|
280
439
|
vec2.copy(this.normal, miter);
|
|
281
440
|
count += 2;
|
|
282
441
|
}
|
|
@@ -296,11 +455,13 @@ var ExtrudePolyline = function () {
|
|
|
296
455
|
var capSquare = this.cap === 'square';
|
|
297
456
|
var joinBevel = this.join === 'bevel';
|
|
298
457
|
var flatCur = aProjectFlat([cur[0], cur[1]]);
|
|
299
|
-
var flatLast = aProjectFlat([last[0], last[1]]);
|
|
458
|
+
var flatLast = aProjectFlat([last[0], last[1]]); // @ts-ignore
|
|
459
|
+
|
|
300
460
|
direction(lineA, flatCur, flatLast);
|
|
301
461
|
var segmentDistance = 0;
|
|
302
462
|
|
|
303
463
|
if (this.dash) {
|
|
464
|
+
// @ts-ignore
|
|
304
465
|
segmentDistance = this.lineSegmentDistance(flatCur, flatLast);
|
|
305
466
|
this.totalDistance += segmentDistance;
|
|
306
467
|
}
|
|
@@ -311,9 +472,10 @@ var ExtrudePolyline = function () {
|
|
|
311
472
|
}
|
|
312
473
|
|
|
313
474
|
if (!this.started) {
|
|
314
|
-
this.started = true;
|
|
475
|
+
this.started = true; // if the end cap is type square, we can just push the verts out a bit
|
|
315
476
|
|
|
316
477
|
if (capSquare) {
|
|
478
|
+
// vec2.scaleAndAdd(capEnd, last, lineA, -this.thickness);
|
|
317
479
|
var out1 = vec2.create();
|
|
318
480
|
var out2 = vec2.create();
|
|
319
481
|
vec2.add(out1, this.normal, lineA);
|
|
@@ -324,7 +486,8 @@ var ExtrudePolyline = function () {
|
|
|
324
486
|
this.complex.indexes.push(this.currentIndex);
|
|
325
487
|
positions.push(last[0], last[1], last[2] | 0, this.totalDistance - segmentDistance, this.thickness, last[2] | 0);
|
|
326
488
|
this.complex.indexes.push(this.currentIndex);
|
|
327
|
-
this.currentIndex++;
|
|
489
|
+
this.currentIndex++; // this.extrusions(positions, normals, last, out, this.thickness);
|
|
490
|
+
// last = capEnd;
|
|
328
491
|
} else {
|
|
329
492
|
this.extrusions(positions, normals, last, this.normal, this.thickness, this.totalDistance - segmentDistance);
|
|
330
493
|
}
|
|
@@ -336,12 +499,15 @@ var ExtrudePolyline = function () {
|
|
|
336
499
|
computeNormal(this.normal, lineA);
|
|
337
500
|
|
|
338
501
|
if (capSquare) {
|
|
502
|
+
// vec2.scaleAndAdd(capEnd, cur, lineA, this.thickness);
|
|
503
|
+
// cur = capEnd;
|
|
339
504
|
var _out3 = vec2.create();
|
|
340
505
|
|
|
341
506
|
var _out4 = vec2.create();
|
|
342
507
|
|
|
343
508
|
vec2.sub(_out4, lineA, this.normal);
|
|
344
|
-
vec2.add(_out3, lineA, this.normal);
|
|
509
|
+
vec2.add(_out3, lineA, this.normal); // this.extrusions(positions, normals, cur, out, this.thickness);
|
|
510
|
+
|
|
345
511
|
normals.push(_out4[0], _out4[1], 0);
|
|
346
512
|
normals.push(_out3[0], _out3[1], 0);
|
|
347
513
|
positions.push(cur[0], cur[1], cur[2] | 0, this.totalDistance, this.thickness, cur[2] | 0);
|
|
@@ -351,7 +517,8 @@ var ExtrudePolyline = function () {
|
|
|
351
517
|
this.currentIndex++;
|
|
352
518
|
} else {
|
|
353
519
|
this.extrusions(positions, normals, cur, this.normal, this.thickness, this.totalDistance);
|
|
354
|
-
}
|
|
520
|
+
} // this.extrusions(positions, normals, cur, this.normal, this.thickness);
|
|
521
|
+
|
|
355
522
|
|
|
356
523
|
indices.push.apply(indices, _toConsumableArray(this.lastFlip === 1 ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]));
|
|
357
524
|
count += 2;
|
|
@@ -362,12 +529,14 @@ var ExtrudePolyline = function () {
|
|
|
362
529
|
vec2.add(flatNext, flatCur, vec2.normalize(flatNext, vec2.subtract(flatNext, flatCur, flatLast)));
|
|
363
530
|
}
|
|
364
531
|
|
|
365
|
-
direction(lineB, flatNext, flatCur);
|
|
532
|
+
direction(lineB, flatNext, flatCur); // stores tangent & miter
|
|
533
|
+
|
|
534
|
+
var _computeMiter5 = computeMiter(tangent, vec2.create(), lineA, lineB, this.thickness),
|
|
535
|
+
_computeMiter6 = _slicedToArray(_computeMiter5, 2),
|
|
536
|
+
miterLen = _computeMiter6[0],
|
|
537
|
+
miter = _computeMiter6[1]; // normal(tmp, lineA)
|
|
538
|
+
// get orientation
|
|
366
539
|
|
|
367
|
-
var _computeMiter3 = computeMiter(tangent, vec2.create(), lineA, lineB, this.thickness),
|
|
368
|
-
_computeMiter4 = _slicedToArray(_computeMiter3, 2),
|
|
369
|
-
miterLen = _computeMiter4[0],
|
|
370
|
-
miter = _computeMiter4[1];
|
|
371
540
|
|
|
372
541
|
var flip = vec2.dot(tangent, this.normal) < 0 ? -1 : 1;
|
|
373
542
|
var bevel = joinBevel;
|
|
@@ -388,10 +557,12 @@ var ExtrudePolyline = function () {
|
|
|
388
557
|
positions.push(cur[0], cur[1], cur[2] | 0, this.totalDistance, this.thickness * flip, cur[2] | 0);
|
|
389
558
|
this.complex.indexes.push(this.currentIndex);
|
|
390
559
|
this.currentIndex++;
|
|
391
|
-
indices.push.apply(indices, _toConsumableArray(this.lastFlip !== -flip ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]));
|
|
560
|
+
indices.push.apply(indices, _toConsumableArray(this.lastFlip !== -flip ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3])); // now add the bevel triangle
|
|
561
|
+
|
|
392
562
|
indices.push(index + 2, index + 3, index + 4);
|
|
393
563
|
computeNormal(tmp, lineB);
|
|
394
|
-
vec2.copy(this.normal, tmp);
|
|
564
|
+
vec2.copy(this.normal, tmp); // store normal for next round
|
|
565
|
+
|
|
395
566
|
normals.push(this.normal[0], this.normal[1], 0);
|
|
396
567
|
positions.push(cur[0], cur[1], cur[2] | 0, this.totalDistance, -this.thickness * flip, cur[2] | 0);
|
|
397
568
|
this.complex.indexes.push(this.currentIndex);
|
|
@@ -400,7 +571,8 @@ var ExtrudePolyline = function () {
|
|
|
400
571
|
} else {
|
|
401
572
|
this.extrusions(positions, normals, cur, miter, miterLen, this.totalDistance);
|
|
402
573
|
indices.push.apply(indices, _toConsumableArray(this.lastFlip === 1 ? [index, index + 2, index + 3] : [index + 2, index + 1, index + 3]));
|
|
403
|
-
flip = -1;
|
|
574
|
+
flip = -1; // the miter is now the normal for our next join
|
|
575
|
+
|
|
404
576
|
vec2.copy(this.normal, miter);
|
|
405
577
|
count += 2;
|
|
406
578
|
}
|
|
@@ -412,7 +584,10 @@ var ExtrudePolyline = function () {
|
|
|
412
584
|
}
|
|
413
585
|
}, {
|
|
414
586
|
key: "extrusions",
|
|
415
|
-
value: function extrusions(positions, normals, point,
|
|
587
|
+
value: function extrusions(positions, normals, point, // 顶点
|
|
588
|
+
normal, // 法向量
|
|
589
|
+
thickness, // 高度
|
|
590
|
+
distanceRadio) {
|
|
416
591
|
normals.push(normal[0], normal[1], 0);
|
|
417
592
|
normals.push(normal[0], normal[1], 0);
|
|
418
593
|
positions.push(point[0], point[1], point[2] | 0, distanceRadio, -thickness, point[2] | 0);
|
|
@@ -433,5 +608,4 @@ var ExtrudePolyline = function () {
|
|
|
433
608
|
return ExtrudePolyline;
|
|
434
609
|
}();
|
|
435
610
|
|
|
436
|
-
export { ExtrudePolyline as default };
|
|
437
|
-
//# sourceMappingURL=extrude_polyline.js.map
|
|
611
|
+
export { ExtrudePolyline as default };
|
package/es/utils/grid-index.js
CHANGED
|
@@ -8,30 +8,16 @@ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o =
|
|
|
8
8
|
|
|
9
9
|
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
10
10
|
|
|
11
|
-
|
|
11
|
+
/**
|
|
12
|
+
* 网格索引,相比 @mapbox/grid-index,在简单计算碰撞检测结果时效率更高
|
|
13
|
+
* @see https://zhuanlan.zhihu.com/p/74373214
|
|
14
|
+
*/
|
|
15
|
+
var GridIndex = /*#__PURE__*/function () {
|
|
12
16
|
function GridIndex(width, height, cellSize) {
|
|
13
17
|
_classCallCheck(this, GridIndex);
|
|
14
18
|
|
|
15
19
|
_defineProperty(this, "boxCells", []);
|
|
16
20
|
|
|
17
|
-
_defineProperty(this, "xCellCount", void 0);
|
|
18
|
-
|
|
19
|
-
_defineProperty(this, "yCellCount", void 0);
|
|
20
|
-
|
|
21
|
-
_defineProperty(this, "boxKeys", void 0);
|
|
22
|
-
|
|
23
|
-
_defineProperty(this, "bboxes", void 0);
|
|
24
|
-
|
|
25
|
-
_defineProperty(this, "width", void 0);
|
|
26
|
-
|
|
27
|
-
_defineProperty(this, "height", void 0);
|
|
28
|
-
|
|
29
|
-
_defineProperty(this, "xScale", void 0);
|
|
30
|
-
|
|
31
|
-
_defineProperty(this, "yScale", void 0);
|
|
32
|
-
|
|
33
|
-
_defineProperty(this, "boxUid", void 0);
|
|
34
|
-
|
|
35
21
|
var boxCells = this.boxCells;
|
|
36
22
|
this.xCellCount = Math.ceil(width / cellSize);
|
|
37
23
|
this.yCellCount = Math.ceil(height / cellSize);
|
|
@@ -84,6 +70,7 @@ var GridIndex = function () {
|
|
|
84
70
|
var result = [];
|
|
85
71
|
|
|
86
72
|
if (x1 <= 0 && y1 <= 0 && this.width <= x2 && this.height <= y2) {
|
|
73
|
+
// 这一步是高效的关键,后续精确碰撞检测结果在计算文本可见性时并不需要
|
|
87
74
|
if (hitTest) {
|
|
88
75
|
return true;
|
|
89
76
|
}
|
|
@@ -189,5 +176,4 @@ var GridIndex = function () {
|
|
|
189
176
|
return GridIndex;
|
|
190
177
|
}();
|
|
191
178
|
|
|
192
|
-
export default GridIndex;
|
|
193
|
-
//# sourceMappingURL=grid-index.js.map
|
|
179
|
+
export default GridIndex;
|
package/es/utils/layerData.js
CHANGED
|
@@ -12,21 +12,34 @@ function getArrowPoints(p1, p2) {
|
|
|
12
12
|
function adjustData2Amap2Coordinates(mappedData, mapService) {
|
|
13
13
|
var _this = this;
|
|
14
14
|
|
|
15
|
+
// 根据地图的类型判断是否需要对点位数据进行处理, 若是高德2.0则需要对坐标进行相对偏移
|
|
15
16
|
if (mappedData.length > 0 && mapService.version === Version['GAODE2.x']) {
|
|
16
17
|
if (typeof mappedData[0].coordinates[0] === 'number') {
|
|
17
|
-
|
|
18
|
+
// 单个的点数据
|
|
19
|
+
// @ts-ignore
|
|
20
|
+
mappedData // TODO: 避免经纬度被重复计算导致坐标位置偏移
|
|
21
|
+
.filter(function (d) {
|
|
18
22
|
return !d.originCoordinates;
|
|
19
23
|
}).map(function (d) {
|
|
20
|
-
d.version = Version['GAODE2.x'];
|
|
21
|
-
|
|
24
|
+
d.version = Version['GAODE2.x']; // @ts-ignore
|
|
25
|
+
|
|
26
|
+
d.originCoordinates = cloneDeep(d.coordinates); // 为了兼容高德1.x 需要保存一份原始的经纬度坐标数据(许多上层逻辑依赖经纬度数据)
|
|
27
|
+
// @ts-ignore
|
|
28
|
+
|
|
22
29
|
d.coordinates = _this.mapService.lngLatToCoord(d.coordinates);
|
|
23
30
|
});
|
|
24
31
|
} else {
|
|
25
|
-
|
|
32
|
+
// 连续的线、面数据
|
|
33
|
+
// @ts-ignore
|
|
34
|
+
mappedData // TODO: 避免经纬度被重复计算导致坐标位置偏移
|
|
35
|
+
.filter(function (d) {
|
|
26
36
|
return !d.originCoordinates;
|
|
27
37
|
}).map(function (d) {
|
|
28
|
-
d.version = Version['GAODE2.x'];
|
|
29
|
-
|
|
38
|
+
d.version = Version['GAODE2.x']; // @ts-ignore
|
|
39
|
+
|
|
40
|
+
d.originCoordinates = cloneDeep(d.coordinates); // 为了兼容高德1.x 需要保存一份原始的经纬度坐标数据(许多上层逻辑依赖经纬度数据)
|
|
41
|
+
// @ts-ignore
|
|
42
|
+
|
|
30
43
|
d.coordinates = _this.mapService.lngLatToCoords(d.coordinates);
|
|
31
44
|
});
|
|
32
45
|
}
|
|
@@ -50,20 +63,27 @@ function unProjectCoordinates(coordinates, mapService) {
|
|
|
50
63
|
}
|
|
51
64
|
|
|
52
65
|
if (coordinates[0] && coordinates[0][0] instanceof Array) {
|
|
66
|
+
// @ts-ignore
|
|
53
67
|
var coords = [];
|
|
54
68
|
coordinates.map(function (coord) {
|
|
69
|
+
// @ts-ignore
|
|
55
70
|
var c1 = [];
|
|
56
71
|
coord.map(function (co) {
|
|
57
72
|
c1.push(mapService.simpleMapCoord.unproject(co));
|
|
58
|
-
});
|
|
73
|
+
}); // @ts-ignore
|
|
74
|
+
|
|
59
75
|
coords.push(c1);
|
|
60
|
-
});
|
|
76
|
+
}); // @ts-ignore
|
|
77
|
+
|
|
61
78
|
return coords;
|
|
62
79
|
} else {
|
|
63
|
-
|
|
80
|
+
// @ts-ignore
|
|
81
|
+
var _coords = []; // @ts-ignore
|
|
82
|
+
|
|
64
83
|
coordinates.map(function (coord) {
|
|
65
84
|
_coords.push(mapService.simpleMapCoord.unproject(coord));
|
|
66
|
-
});
|
|
85
|
+
}); // @ts-ignore
|
|
86
|
+
|
|
67
87
|
return _coords;
|
|
68
88
|
}
|
|
69
89
|
}
|
|
@@ -83,6 +103,7 @@ function applyAttributeMapping(attribute, record, minimumColor) {
|
|
|
83
103
|
var field = _ref.field;
|
|
84
104
|
|
|
85
105
|
if (record.hasOwnProperty(field) || ((_attribute$scale2 = attribute.scale) === null || _attribute$scale2 === void 0 ? void 0 : _attribute$scale2.type) === 'variable') {
|
|
106
|
+
// TODO:多字段,常量
|
|
86
107
|
params.push(record[field]);
|
|
87
108
|
}
|
|
88
109
|
});
|
|
@@ -111,15 +132,16 @@ function mapping(attributes, data, fontService, mapService, minimumColor, layer)
|
|
|
111
132
|
return attribute.scale !== undefined;
|
|
112
133
|
}).forEach(function (attribute) {
|
|
113
134
|
var values = applyAttributeMapping(attribute, record, minimumColor);
|
|
114
|
-
attribute.needRemapping = false;
|
|
135
|
+
attribute.needRemapping = false; // TODO: 支持每个属性配置 postprocess
|
|
115
136
|
|
|
116
137
|
if (attribute.name === 'color') {
|
|
117
138
|
values = values.map(function (c) {
|
|
118
139
|
return rgb2arr(c);
|
|
119
140
|
});
|
|
120
|
-
}
|
|
141
|
+
} // @ts-ignore
|
|
142
|
+
|
|
121
143
|
|
|
122
|
-
encodeRecord[attribute.name] = Array.isArray(values) && values.length === 1 ? values[0] : values;
|
|
144
|
+
encodeRecord[attribute.name] = Array.isArray(values) && values.length === 1 ? values[0] : values; // 增加对 layer/text/iconfont unicode 映射的解析
|
|
123
145
|
|
|
124
146
|
if (attribute.name === 'shape') {
|
|
125
147
|
encodeRecord.shape = fontService.getIconFontKey(encodeRecord[attribute.name]);
|
|
@@ -127,14 +149,17 @@ function mapping(attributes, data, fontService, mapService, minimumColor, layer)
|
|
|
127
149
|
});
|
|
128
150
|
|
|
129
151
|
if (encodeRecord.shape === 'line' && arrow.enable) {
|
|
152
|
+
// 只有在线图层且支持配置箭头的时候进行插入顶点的处理
|
|
130
153
|
var coords = encodeRecord.coordinates;
|
|
131
154
|
var arrowPoint = getArrowPoints(coords[0], coords[1]);
|
|
132
155
|
encodeRecord.coordinates.splice(1, 0, arrowPoint, arrowPoint);
|
|
133
156
|
}
|
|
134
157
|
|
|
135
158
|
return encodeRecord;
|
|
136
|
-
});
|
|
137
|
-
|
|
159
|
+
}); // 调整数据兼容 Amap2.0
|
|
160
|
+
|
|
161
|
+
adjustData2Amap2Coordinates(mappedData, mapService); // 调整数据兼容 SimpleCoordinates
|
|
162
|
+
|
|
138
163
|
adjustData2SimpleCoordinates(mappedData, mapService);
|
|
139
164
|
return mappedData;
|
|
140
165
|
}
|
|
@@ -148,5 +173,4 @@ export function calculateData(layer, fontService, mapService, styleAttributeServ
|
|
|
148
173
|
var mappedEncodeData = mapping(attributes, filterData, fontService, mapService, bottomColor, layer);
|
|
149
174
|
source.destroy();
|
|
150
175
|
return mappedEncodeData;
|
|
151
|
-
}
|
|
152
|
-
//# sourceMappingURL=layerData.js.map
|
|
176
|
+
}
|
|
@@ -1,4 +1,8 @@
|
|
|
1
1
|
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* 'blurH' -> ['blurH', {}]
|
|
5
|
+
*/
|
|
2
6
|
export function normalizePasses(passes) {
|
|
3
7
|
return passes.map(function (pass) {
|
|
4
8
|
if (typeof pass === 'string') {
|
|
@@ -8,18 +12,30 @@ export function normalizePasses(passes) {
|
|
|
8
12
|
return pass;
|
|
9
13
|
});
|
|
10
14
|
}
|
|
15
|
+
/**
|
|
16
|
+
* 默认添加 ClearPass、RenderPass
|
|
17
|
+
* 以及 PostProcessing 中的最后一个 CopyPass
|
|
18
|
+
*/
|
|
19
|
+
|
|
11
20
|
export function createMultiPassRenderer(layer, passes, postProcessingPassFactory, normalPassFactory) {
|
|
12
21
|
var multiPassRenderer = layer.multiPassRenderer;
|
|
13
22
|
|
|
14
23
|
var _layer$getLayerConfig = layer.getLayerConfig(),
|
|
15
24
|
enablePicking = _layer$getLayerConfig.enablePicking,
|
|
16
|
-
enableTAA = _layer$getLayerConfig.enableTAA;
|
|
25
|
+
enableTAA = _layer$getLayerConfig.enableTAA; // picking pass if enabled
|
|
26
|
+
// if (enablePicking) {
|
|
27
|
+
// multiPassRenderer.add(normalPassFactory('pixelPicking'));
|
|
28
|
+
// }
|
|
29
|
+
// use TAA pass if enabled instead of render pass
|
|
30
|
+
|
|
17
31
|
|
|
18
32
|
if (enableTAA) {
|
|
19
33
|
multiPassRenderer.add(normalPassFactory('taa'));
|
|
20
34
|
} else {
|
|
35
|
+
// render all layers in this pass
|
|
21
36
|
multiPassRenderer.add(normalPassFactory('render'));
|
|
22
|
-
}
|
|
37
|
+
} // post processing
|
|
38
|
+
|
|
23
39
|
|
|
24
40
|
normalizePasses(passes).forEach(function (pass) {
|
|
25
41
|
var _pass = _slicedToArray(pass, 2),
|
|
@@ -27,8 +43,8 @@ export function createMultiPassRenderer(layer, passes, postProcessingPassFactory
|
|
|
27
43
|
initializationOptions = _pass[1];
|
|
28
44
|
|
|
29
45
|
multiPassRenderer.add(postProcessingPassFactory(passName), initializationOptions);
|
|
30
|
-
});
|
|
46
|
+
}); // 末尾为固定的 CopyPass
|
|
47
|
+
|
|
31
48
|
multiPassRenderer.add(postProcessingPassFactory('copy'));
|
|
32
49
|
return multiPassRenderer;
|
|
33
|
-
}
|
|
34
|
-
//# sourceMappingURL=multiPassRender.js.map
|
|
50
|
+
}
|