@antv/l7-layers 2.9.26-alpha.0 → 2.9.26-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/Geometry/index.d.ts +19 -0
- package/es/Geometry/index.js +106 -0
- package/es/Geometry/models/billboard.d.ts +26 -0
- package/es/Geometry/models/billboard.js +232 -0
- package/es/Geometry/models/index.d.ts +5 -0
- package/es/Geometry/models/index.js +9 -0
- package/es/Geometry/models/plane.d.ts +45 -0
- package/es/Geometry/models/plane.js +421 -0
- package/es/Geometry/models/sprite.d.ts +47 -0
- package/es/Geometry/models/sprite.js +304 -0
- 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.d.ts +19 -0
- package/es/canvas/index.js +91 -0
- package/es/canvas/models/canvas.d.ts +18 -0
- package/es/canvas/models/canvas.js +212 -0
- package/es/canvas/models/index.d.ts +5 -0
- package/es/canvas/models/index.js +5 -0
- package/es/citybuliding/building.d.ts +17 -0
- package/es/citybuliding/building.js +88 -0
- package/es/citybuliding/models/build.d.ts +22 -0
- package/es/citybuliding/models/build.js +188 -0
- package/es/citybuliding/shaders/build_frag.glsl +117 -0
- package/es/citybuliding/shaders/build_vert.glsl +54 -0
- package/es/core/BaseLayer.d.ts +208 -0
- package/es/core/BaseLayer.js +1409 -0
- package/es/core/BaseModel.d.ts +140 -0
- package/es/core/BaseModel.js +486 -0
- package/es/core/interface.d.ts +201 -0
- package/es/core/interface.js +30 -0
- package/es/core/schema.d.ts +27 -0
- package/es/core/schema.js +25 -0
- package/es/core/shape/Path.d.ts +39 -0
- package/es/core/shape/Path.js +62 -0
- package/es/core/shape/extrude.d.ts +17 -0
- package/es/core/shape/extrude.js +148 -0
- package/es/core/triangulation.d.ts +122 -0
- package/es/core/triangulation.js +491 -0
- package/es/earth/index.d.ts +17 -0
- package/es/earth/index.js +91 -0
- package/es/earth/models/atmosphere.d.ts +9 -0
- package/es/earth/models/atmosphere.js +138 -0
- package/es/earth/models/base.d.ts +16 -0
- package/es/earth/models/base.js +212 -0
- package/es/earth/models/bloomsphere.d.ts +9 -0
- package/es/earth/models/bloomsphere.js +138 -0
- 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.d.ts +26 -0
- package/es/earth/utils.js +104 -0
- package/es/heatmap/index.d.ts +21 -0
- package/es/heatmap/index.js +145 -0
- package/es/heatmap/models/grid.d.ts +8 -0
- package/es/heatmap/models/grid.js +108 -0
- package/es/heatmap/models/grid3d.d.ts +8 -0
- package/es/heatmap/models/grid3d.js +147 -0
- package/es/heatmap/models/heatmap.d.ts +24 -0
- package/es/heatmap/models/heatmap.js +464 -0
- package/es/heatmap/models/hexagon.d.ts +8 -0
- package/es/heatmap/models/hexagon.js +111 -0
- package/es/heatmap/models/index.d.ts +5 -0
- package/es/heatmap/models/index.js +12 -0
- 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.d.ts +5 -0
- package/es/heatmap/triangulation.js +38 -0
- package/es/image/index.d.ts +19 -0
- package/es/image/index.js +103 -0
- package/es/image/models/dataImage.d.ts +22 -0
- package/es/image/models/dataImage.js +225 -0
- package/es/image/models/image.d.ts +19 -0
- package/es/image/models/image.js +169 -0
- package/es/image/models/index.d.ts +5 -0
- package/es/image/models/index.js +7 -0
- 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 +16 -0
- package/es/index.js +106 -0
- package/es/line/index.d.ts +25 -0
- package/es/line/index.js +122 -0
- package/es/line/models/arc.d.ts +17 -0
- package/es/line/models/arc.js +356 -0
- package/es/line/models/arc_3d.d.ts +17 -0
- package/es/line/models/arc_3d.js +335 -0
- package/es/line/models/earthArc_3d.d.ts +17 -0
- package/es/line/models/earthArc_3d.js +338 -0
- package/es/line/models/great_circle.d.ts +12 -0
- package/es/line/models/great_circle.js +294 -0
- package/es/line/models/half.d.ts +18 -0
- package/es/line/models/half.js +282 -0
- package/es/line/models/index.d.ts +5 -0
- package/es/line/models/index.js +25 -0
- package/es/line/models/line.d.ts +21 -0
- package/es/line/models/line.js +442 -0
- package/es/line/models/linearline.d.ts +11 -0
- package/es/line/models/linearline.js +276 -0
- package/es/line/models/simpleLine.d.ts +14 -0
- package/es/line/models/simpleLine.js +233 -0
- package/es/line/models/tile.d.ts +11 -0
- package/es/line/models/tile.js +351 -0
- package/es/line/models/wall.d.ts +12 -0
- package/es/line/models/wall.js +329 -0
- 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 +176 -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 +79 -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.d.ts +18 -0
- package/es/mask/index.js +82 -0
- package/es/mask/models/fill.d.ts +11 -0
- package/es/mask/models/fill.js +121 -0
- package/es/mask/models/index.d.ts +5 -0
- package/es/mask/models/index.js +5 -0
- package/es/mask/shaders/mask_frag.glsl +7 -0
- package/es/mask/shaders/mask_vert.glsl +22 -0
- package/es/plugins/DataMappingPlugin.d.ts +18 -0
- package/es/plugins/DataMappingPlugin.js +345 -0
- package/es/plugins/DataSourcePlugin.d.ts +7 -0
- package/es/plugins/DataSourcePlugin.js +89 -0
- package/es/plugins/FeatureScalePlugin.d.ts +25 -0
- package/es/plugins/FeatureScalePlugin.js +324 -0
- package/es/plugins/LayerAnimateStylePlugin.d.ts +7 -0
- package/es/plugins/LayerAnimateStylePlugin.js +49 -0
- package/es/plugins/LayerModelPlugin.d.ts +10 -0
- package/es/plugins/LayerModelPlugin.js +71 -0
- package/es/plugins/LayerStylePlugin.d.ts +8 -0
- package/es/plugins/LayerStylePlugin.js +39 -0
- package/es/plugins/LightingPlugin.d.ts +36 -0
- package/es/plugins/LightingPlugin.js +110 -0
- package/es/plugins/MultiPassRendererPlugin.d.ts +24 -0
- package/es/plugins/MultiPassRendererPlugin.js +77 -0
- package/es/plugins/PixelPickingPlugin.d.ts +8 -0
- package/es/plugins/PixelPickingPlugin.js +146 -0
- package/es/plugins/RegisterStyleAttributePlugin.d.ts +11 -0
- package/es/plugins/RegisterStyleAttributePlugin.js +105 -0
- package/es/plugins/ShaderUniformPlugin.d.ts +17 -0
- package/es/plugins/ShaderUniformPlugin.js +107 -0
- package/es/plugins/UpdateModelPlugin.d.ts +8 -0
- package/es/plugins/UpdateModelPlugin.js +31 -0
- package/es/plugins/UpdateStyleAttributePlugin.d.ts +12 -0
- package/es/plugins/UpdateStyleAttributePlugin.js +87 -0
- package/es/point/index.d.ts +30 -0
- package/es/point/index.js +224 -0
- package/es/point/models/earthExtrude.d.ts +24 -0
- package/es/point/models/earthExtrude.js +279 -0
- package/es/point/models/earthFill.d.ts +11 -0
- package/es/point/models/earthFill.js +258 -0
- package/es/point/models/extrude.d.ts +24 -0
- package/es/point/models/extrude.js +298 -0
- package/es/point/models/fill.d.ts +40 -0
- package/es/point/models/fill.js +404 -0
- package/es/point/models/fillmage.d.ts +25 -0
- package/es/point/models/fillmage.js +367 -0
- package/es/point/models/image.d.ts +11 -0
- package/es/point/models/image.js +239 -0
- package/es/point/models/index.d.ts +5 -0
- package/es/point/models/index.js +28 -0
- package/es/point/models/normal.d.ts +17 -0
- package/es/point/models/normal.js +177 -0
- package/es/point/models/radar.d.ts +24 -0
- package/es/point/models/radar.js +297 -0
- package/es/point/models/simplePoint.d.ts +17 -0
- package/es/point/models/simplePoint.js +188 -0
- package/es/point/models/text.d.ts +57 -0
- package/es/point/models/text.js +622 -0
- package/es/point/models/tile.d.ts +22 -0
- package/es/point/models/tile.js +309 -0
- 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 +189 -0
- package/es/point/shaders/image/fillImage_frag.glsl +20 -0
- package/es/point/shaders/image/fillImage_vert.glsl +116 -0
- package/es/point/shaders/image_frag.glsl +39 -0
- package/es/point/shaders/image_vert.glsl +90 -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.d.ts +15 -0
- package/es/point/shape/extrude.js +63 -0
- package/es/polygon/index.d.ts +19 -0
- package/es/polygon/index.js +148 -0
- package/es/polygon/models/extrude.d.ts +28 -0
- package/es/polygon/models/extrude.js +306 -0
- package/es/polygon/models/fill.d.ts +17 -0
- package/es/polygon/models/fill.js +211 -0
- package/es/polygon/models/index.d.ts +5 -0
- package/es/polygon/models/index.js +28 -0
- package/es/polygon/models/ocean.d.ts +23 -0
- package/es/polygon/models/ocean.js +236 -0
- package/es/polygon/models/tile.d.ts +15 -0
- package/es/polygon/models/tile.js +133 -0
- package/es/polygon/models/water.d.ts +18 -0
- package/es/polygon/models/water.js +213 -0
- 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.d.ts +6 -0
- package/es/raster/buffers/triangulation.js +28 -0
- package/es/raster/index.d.ts +19 -0
- package/es/raster/index.js +106 -0
- package/es/raster/models/index.d.ts +5 -0
- package/es/raster/models/index.js +8 -0
- package/es/raster/models/raster.d.ts +21 -0
- package/es/raster/models/raster.js +167 -0
- package/es/raster/raster.d.ts +30 -0
- package/es/raster/raster.js +174 -0
- 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.d.ts +28 -0
- package/es/tile/interface.js +1 -0
- package/es/tile/manager/tileConfigManager.d.ts +17 -0
- package/es/tile/manager/tileConfigManager.js +121 -0
- package/es/tile/manager/tileLayerManager.d.ts +36 -0
- package/es/tile/manager/tileLayerManager.js +312 -0
- package/es/tile/manager/tilePickerManager.d.ts +21 -0
- package/es/tile/manager/tilePickerManager.js +190 -0
- package/es/tile/models/tileModel.d.ts +8 -0
- package/es/tile/models/tileModel.js +62 -0
- package/es/tile/tileFactory/base.d.ts +44 -0
- package/es/tile/tileFactory/base.js +444 -0
- package/es/tile/tileFactory/index.d.ts +5 -0
- package/es/tile/tileFactory/index.js +29 -0
- package/es/tile/tileFactory/line.d.ts +12 -0
- package/es/tile/tileFactory/line.js +59 -0
- package/es/tile/tileFactory/point.d.ts +12 -0
- package/es/tile/tileFactory/point.js +59 -0
- package/es/tile/tileFactory/polygon.d.ts +12 -0
- package/es/tile/tileFactory/polygon.js +59 -0
- package/es/tile/tileFactory/raster.d.ts +12 -0
- package/es/tile/tileFactory/raster.js +55 -0
- package/es/tile/tileFactory/rasterData.d.ts +12 -0
- package/es/tile/tileFactory/rasterData.js +80 -0
- package/es/tile/tileFactory/rasterDataLayer.d.ts +19 -0
- package/es/tile/tileFactory/rasterDataLayer.js +87 -0
- package/es/tile/tileFactory/vectorLayer.d.ts +29 -0
- package/es/tile/tileFactory/vectorLayer.js +161 -0
- package/es/tile/tileLayer/baseTileLayer.d.ts +47 -0
- package/es/tile/tileLayer/baseTileLayer.js +438 -0
- package/es/tile/tmsTileLayer.d.ts +7 -0
- package/es/tile/tmsTileLayer.js +101 -0
- package/es/tile/utils.d.ts +13 -0
- package/es/tile/utils.js +131 -0
- package/es/utils/blend.d.ts +2 -0
- package/es/utils/blend.js +54 -0
- package/es/utils/collision-index.d.ts +47 -0
- package/es/utils/collision-index.js +102 -0
- package/es/utils/dataMappingStyle.d.ts +31 -0
- package/es/utils/dataMappingStyle.js +147 -0
- package/es/utils/extrude_polyline.d.ts +67 -0
- package/es/utils/extrude_polyline.js +611 -0
- package/es/utils/grid-index.d.ts +28 -0
- package/es/utils/grid-index.js +179 -0
- package/es/utils/layerData.d.ts +2 -0
- package/es/utils/layerData.js +176 -0
- package/es/utils/multiPassRender.d.ts +16 -0
- package/es/utils/multiPassRender.js +50 -0
- package/es/utils/polylineNormal.d.ts +9 -0
- package/es/utils/polylineNormal.js +191 -0
- package/es/utils/simpleLine.d.ts +23 -0
- package/es/utils/simpleLine.js +103 -0
- package/es/utils/symbol-layout.d.ts +43 -0
- package/es/utils/symbol-layout.js +299 -0
- package/es/utils/updateShape.d.ts +2 -0
- package/es/utils/updateShape.js +20 -0
- package/es/wind/index.d.ts +20 -0
- package/es/wind/index.js +100 -0
- package/es/wind/models/index.d.ts +5 -0
- package/es/wind/models/index.js +5 -0
- package/es/wind/models/utils.d.ts +19 -0
- package/es/wind/models/utils.js +226 -0
- package/es/wind/models/wind.d.ts +33 -0
- package/es/wind/models/wind.js +331 -0
- package/es/wind/models/windRender.d.ts +104 -0
- package/es/wind/models/windRender.js +357 -0
- package/es/wind/models/windShader.d.ts +12 -0
- package/es/wind/models/windShader.js +12 -0
- package/es/wind/shaders/wind_frag.glsl +9 -0
- package/es/wind/shaders/wind_vert.glsl +17 -0
- package/lib/Geometry/index.js +119 -0
- package/lib/Geometry/models/billboard.js +246 -0
- package/lib/Geometry/models/index.js +22 -0
- package/lib/Geometry/models/plane.js +436 -0
- package/lib/Geometry/models/sprite.js +318 -0
- 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 +104 -0
- package/lib/canvas/models/canvas.js +221 -0
- package/lib/canvas/models/index.js +16 -0
- package/lib/citybuliding/building.js +101 -0
- package/lib/citybuliding/models/build.js +203 -0
- package/lib/citybuliding/shaders/build_frag.glsl +117 -0
- package/lib/citybuliding/shaders/build_vert.glsl +54 -0
- package/lib/core/BaseLayer.js +1408 -0
- package/lib/core/BaseModel.js +503 -0
- package/lib/core/interface.js +41 -0
- package/lib/core/schema.js +33 -0
- package/lib/core/shape/Path.js +88 -0
- package/lib/core/shape/extrude.js +180 -0
- package/lib/core/triangulation.js +555 -0
- package/lib/earth/index.js +107 -0
- package/lib/earth/models/atmosphere.js +152 -0
- package/lib/earth/models/base.js +222 -0
- package/lib/earth/models/bloomsphere.js +152 -0
- 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 +136 -0
- package/lib/heatmap/index.js +158 -0
- package/lib/heatmap/models/grid.js +122 -0
- package/lib/heatmap/models/grid3d.js +161 -0
- package/lib/heatmap/models/heatmap.js +487 -0
- package/lib/heatmap/models/hexagon.js +125 -0
- package/lib/heatmap/models/index.js +26 -0
- 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 +45 -0
- package/lib/image/index.js +116 -0
- package/lib/image/models/dataImage.js +240 -0
- package/lib/image/models/image.js +183 -0
- package/lib/image/models/index.js +19 -0
- 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 +266 -0
- package/lib/line/index.js +136 -0
- package/lib/line/models/arc.js +373 -0
- package/lib/line/models/arc_3d.js +353 -0
- package/lib/line/models/earthArc_3d.js +356 -0
- package/lib/line/models/great_circle.js +310 -0
- package/lib/line/models/half.js +299 -0
- package/lib/line/models/index.js +46 -0
- package/lib/line/models/line.js +459 -0
- package/lib/line/models/linearline.js +293 -0
- package/lib/line/models/simpleLine.js +248 -0
- package/lib/line/models/tile.js +368 -0
- package/lib/line/models/wall.js +345 -0
- 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 +176 -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 +79 -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 +95 -0
- package/lib/mask/models/fill.js +137 -0
- package/lib/mask/models/index.js +16 -0
- package/lib/mask/shaders/mask_frag.glsl +7 -0
- package/lib/mask/shaders/mask_vert.glsl +22 -0
- package/lib/plugins/DataMappingPlugin.js +360 -0
- package/lib/plugins/DataSourcePlugin.js +108 -0
- package/lib/plugins/FeatureScalePlugin.js +348 -0
- package/lib/plugins/LayerAnimateStylePlugin.js +64 -0
- package/lib/plugins/LayerModelPlugin.js +82 -0
- package/lib/plugins/LayerStylePlugin.js +50 -0
- package/lib/plugins/LightingPlugin.js +125 -0
- package/lib/plugins/MultiPassRendererPlugin.js +93 -0
- package/lib/plugins/PixelPickingPlugin.js +159 -0
- package/lib/plugins/RegisterStyleAttributePlugin.js +117 -0
- package/lib/plugins/ShaderUniformPlugin.js +120 -0
- package/lib/plugins/UpdateModelPlugin.js +42 -0
- package/lib/plugins/UpdateStyleAttributePlugin.js +98 -0
- package/lib/point/index.js +238 -0
- package/lib/point/models/earthExtrude.js +295 -0
- package/lib/point/models/earthFill.js +293 -0
- package/lib/point/models/extrude.js +315 -0
- package/lib/point/models/fill.js +420 -0
- package/lib/point/models/fillmage.js +383 -0
- package/lib/point/models/image.js +255 -0
- package/lib/point/models/index.js +50 -0
- package/lib/point/models/normal.js +194 -0
- package/lib/point/models/radar.js +314 -0
- package/lib/point/models/simplePoint.js +205 -0
- package/lib/point/models/text.js +637 -0
- package/lib/point/models/tile.js +325 -0
- 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 +189 -0
- package/lib/point/shaders/image/fillImage_frag.glsl +20 -0
- package/lib/point/shaders/image/fillImage_vert.glsl +116 -0
- package/lib/point/shaders/image_frag.glsl +39 -0
- package/lib/point/shaders/image_vert.glsl +90 -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 +78 -0
- package/lib/polygon/index.js +162 -0
- package/lib/polygon/models/extrude.js +322 -0
- package/lib/polygon/models/fill.js +226 -0
- package/lib/polygon/models/index.js +50 -0
- package/lib/polygon/models/ocean.js +252 -0
- package/lib/polygon/models/tile.js +147 -0
- package/lib/polygon/models/water.js +229 -0
- 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 +38 -0
- package/lib/raster/index.js +119 -0
- package/lib/raster/models/index.js +20 -0
- package/lib/raster/models/raster.js +182 -0
- package/lib/raster/raster.js +191 -0
- 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 +5 -0
- package/lib/tile/manager/tileConfigManager.js +133 -0
- package/lib/tile/manager/tileLayerManager.js +330 -0
- package/lib/tile/manager/tilePickerManager.js +201 -0
- package/lib/tile/models/tileModel.js +74 -0
- package/lib/tile/tileFactory/base.js +466 -0
- package/lib/tile/tileFactory/index.js +59 -0
- package/lib/tile/tileFactory/line.js +70 -0
- package/lib/tile/tileFactory/point.js +70 -0
- package/lib/tile/tileFactory/polygon.js +70 -0
- package/lib/tile/tileFactory/raster.js +68 -0
- package/lib/tile/tileFactory/rasterData.js +93 -0
- package/lib/tile/tileFactory/rasterDataLayer.js +100 -0
- package/lib/tile/tileFactory/vectorLayer.js +176 -0
- package/lib/tile/tileLayer/baseTileLayer.js +447 -0
- package/lib/tile/tmsTileLayer.js +117 -0
- package/lib/tile/utils.js +158 -0
- package/lib/utils/blend.js +65 -0
- package/lib/utils/collision-index.js +118 -0
- package/lib/utils/dataMappingStyle.js +151 -0
- package/lib/utils/extrude_polyline.js +653 -0
- package/lib/utils/grid-index.js +188 -0
- package/lib/utils/layerData.js +187 -0
- package/lib/utils/multiPassRender.js +61 -0
- package/lib/utils/polylineNormal.js +230 -0
- package/lib/utils/simpleLine.js +116 -0
- package/lib/utils/symbol-layout.js +308 -0
- package/lib/utils/updateShape.js +27 -0
- package/lib/wind/index.js +113 -0
- package/lib/wind/models/index.js +16 -0
- package/lib/wind/models/utils.js +253 -0
- package/lib/wind/models/wind.js +346 -0
- package/lib/wind/models/windRender.js +373 -0
- package/lib/wind/models/windShader.js +25 -0
- package/lib/wind/shaders/wind_frag.glsl +9 -0
- package/lib/wind/shaders/wind_vert.glsl +17 -0
- package/package.json +6 -6
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
uniform float u_opacity: 1.0;
|
|
2
|
+
uniform vec4 u_sourceColor;
|
|
3
|
+
uniform vec4 u_targetColor;
|
|
4
|
+
uniform float u_linearColor: 0;
|
|
5
|
+
|
|
6
|
+
uniform float u_topsurface: 1.0;
|
|
7
|
+
uniform float u_sidesurface: 1.0;
|
|
8
|
+
|
|
9
|
+
varying vec4 v_Color;
|
|
10
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
11
|
+
#pragma include "picking"
|
|
12
|
+
|
|
13
|
+
void main() {
|
|
14
|
+
float opacity = styleMappingMat[0][0];
|
|
15
|
+
float isSide = styleMappingMat[0][3];
|
|
16
|
+
float sidey = styleMappingMat[3][0];
|
|
17
|
+
float lightWeight = styleMappingMat[3][1];
|
|
18
|
+
|
|
19
|
+
if(isSide < 1.0) {
|
|
20
|
+
// side face
|
|
21
|
+
if(u_sidesurface < 1.0) {
|
|
22
|
+
discard;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
if(u_linearColor == 1.0) {
|
|
26
|
+
vec4 linearColor = mix(u_targetColor, u_sourceColor, sidey);
|
|
27
|
+
linearColor.rgb *= lightWeight;
|
|
28
|
+
gl_FragColor = linearColor;
|
|
29
|
+
} else {
|
|
30
|
+
gl_FragColor = v_Color;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
} else {
|
|
34
|
+
// top face
|
|
35
|
+
if(u_topsurface < 1.0) {
|
|
36
|
+
discard;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
gl_FragColor = v_Color;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
gl_FragColor.a *= opacity;
|
|
43
|
+
gl_FragColor = filterColor(gl_FragColor);
|
|
44
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
uniform float u_opacity: 1.0;
|
|
2
|
+
uniform vec4 u_sourceColor;
|
|
3
|
+
uniform vec4 u_targetColor;
|
|
4
|
+
uniform float u_linearColor: 0;
|
|
5
|
+
|
|
6
|
+
uniform float u_topsurface: 1.0;
|
|
7
|
+
uniform float u_sidesurface: 1.0;
|
|
8
|
+
|
|
9
|
+
varying vec4 v_Color;
|
|
10
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
11
|
+
#pragma include "picking"
|
|
12
|
+
|
|
13
|
+
void main() {
|
|
14
|
+
float opacity = styleMappingMat[0][0];
|
|
15
|
+
float isSide = styleMappingMat[0][3];
|
|
16
|
+
float sidey = styleMappingMat[3][0];
|
|
17
|
+
float lightWeight = styleMappingMat[3][1];
|
|
18
|
+
|
|
19
|
+
if(isSide < 1.0) {
|
|
20
|
+
// side face
|
|
21
|
+
if(u_sidesurface < 1.0) {
|
|
22
|
+
discard;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
if( u_linearColor == 1.0) {
|
|
26
|
+
// side use linear
|
|
27
|
+
vec4 linearColor = mix(u_targetColor, u_sourceColor, sidey);
|
|
28
|
+
linearColor.rgb *= lightWeight;
|
|
29
|
+
gl_FragColor = linearColor;
|
|
30
|
+
} else {
|
|
31
|
+
// side notuse linear
|
|
32
|
+
gl_FragColor = v_Color;
|
|
33
|
+
}
|
|
34
|
+
} else {
|
|
35
|
+
// top face
|
|
36
|
+
if(u_topsurface < 1.0) {
|
|
37
|
+
discard;
|
|
38
|
+
}
|
|
39
|
+
gl_FragColor = v_Color;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
gl_FragColor.a *= opacity;
|
|
43
|
+
gl_FragColor = filterColorAlpha(gl_FragColor, lightWeight);
|
|
44
|
+
}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
precision highp float;
|
|
2
|
+
|
|
3
|
+
#define ambientRatio 0.5
|
|
4
|
+
#define diffuseRatio 0.3
|
|
5
|
+
#define specularRatio 0.2
|
|
6
|
+
|
|
7
|
+
attribute vec4 a_Color;
|
|
8
|
+
attribute vec3 a_Position;
|
|
9
|
+
attribute vec3 a_Normal;
|
|
10
|
+
attribute float a_Size;
|
|
11
|
+
attribute vec3 a_uvs;
|
|
12
|
+
uniform mat4 u_ModelMatrix;
|
|
13
|
+
uniform mat4 u_Mvp;
|
|
14
|
+
|
|
15
|
+
varying vec4 v_Color;
|
|
16
|
+
uniform float u_heightfixed: 0.0; // 默认不固定
|
|
17
|
+
uniform float u_raisingHeight: 0.0;
|
|
18
|
+
uniform float u_opacity: 1.0;
|
|
19
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
20
|
+
|
|
21
|
+
#pragma include "styleMapping"
|
|
22
|
+
#pragma include "styleMappingCalOpacity"
|
|
23
|
+
|
|
24
|
+
#pragma include "projection"
|
|
25
|
+
#pragma include "light"
|
|
26
|
+
#pragma include "picking"
|
|
27
|
+
|
|
28
|
+
void main() {
|
|
29
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
30
|
+
styleMappingMat = mat4(
|
|
31
|
+
0.0, 0.0, 0.0, 0.0, // opacity - strokeOpacity - strokeWidth - isSide
|
|
32
|
+
0.0, 0.0, 0.0, 0.0, // strokeR - strokeG - strokeB - strokeA
|
|
33
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1]
|
|
34
|
+
0.0, 0.0, 0.0, 0.0 // sidey
|
|
35
|
+
);
|
|
36
|
+
styleMappingMat[0][3] = a_Position.z;
|
|
37
|
+
styleMappingMat[3][0] = a_uvs[2];
|
|
38
|
+
|
|
39
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
40
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
41
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
42
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
43
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
44
|
+
float id = a_vertexId; // 第n个顶点
|
|
45
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
46
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
47
|
+
|
|
48
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
49
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
50
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
51
|
+
|
|
52
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
53
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
54
|
+
textureOffset = opacityAndOffset.g;
|
|
55
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
56
|
+
vec4 pos = vec4(a_Position.xy, a_Position.z * a_Size, 1.0);
|
|
57
|
+
vec4 project_pos = project_position(pos);
|
|
58
|
+
|
|
59
|
+
if(u_heightfixed > 0.0) { // 判断几何体是否固定高度
|
|
60
|
+
project_pos.z = a_Position.z * a_Size;
|
|
61
|
+
project_pos.z += u_raisingHeight;
|
|
62
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
63
|
+
float mapboxZoomScale = 4.0/pow(2.0, 21.0 - u_Zoom);
|
|
64
|
+
project_pos.z *= mapboxZoomScale;
|
|
65
|
+
project_pos.z += u_raisingHeight * mapboxZoomScale;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
// gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
70
|
+
|
|
71
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
72
|
+
// gl_Position = u_Mvp * (vec4(project_pos.xyz * vec3(1.0, 1.0, -1.0), 1.0));
|
|
73
|
+
gl_Position = u_Mvp * (vec4(project_pos.xyz, 1.0));
|
|
74
|
+
} else {
|
|
75
|
+
gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
float lightWeight = calc_lighting(pos);
|
|
79
|
+
// v_Color = a_Color;
|
|
80
|
+
v_Color = vec4(a_Color.rgb * lightWeight, a_Color.w);
|
|
81
|
+
|
|
82
|
+
styleMappingMat[3][1] = lightWeight;
|
|
83
|
+
|
|
84
|
+
setPickingColor(a_PickingColor);
|
|
85
|
+
}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
precision highp float;
|
|
2
|
+
|
|
3
|
+
#define ambientRatio 0.5
|
|
4
|
+
#define diffuseRatio 0.3
|
|
5
|
+
#define specularRatio 0.2
|
|
6
|
+
|
|
7
|
+
attribute vec4 a_Color;
|
|
8
|
+
attribute vec3 a_Position;
|
|
9
|
+
attribute vec3 a_Normal;
|
|
10
|
+
attribute float a_Size;
|
|
11
|
+
attribute vec3 a_uvs;
|
|
12
|
+
uniform mat4 u_ModelMatrix;
|
|
13
|
+
uniform mat4 u_Mvp;
|
|
14
|
+
|
|
15
|
+
varying vec4 v_Color;
|
|
16
|
+
uniform float u_heightfixed: 0.0; // 默认不固定
|
|
17
|
+
uniform float u_raisingHeight: 0.0;
|
|
18
|
+
uniform float u_opacity: 1.0;
|
|
19
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
20
|
+
|
|
21
|
+
#pragma include "styleMapping"
|
|
22
|
+
#pragma include "styleMappingCalOpacity"
|
|
23
|
+
|
|
24
|
+
#pragma include "projection"
|
|
25
|
+
#pragma include "light"
|
|
26
|
+
#pragma include "picking"
|
|
27
|
+
|
|
28
|
+
void main() {
|
|
29
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
30
|
+
styleMappingMat = mat4(
|
|
31
|
+
0.0, 0.0, 0.0, 0.0, // opacity - strokeOpacity - strokeWidth - isSide
|
|
32
|
+
0.0, 0.0, 0.0, 0.0, // strokeR - strokeG - strokeB - strokeA
|
|
33
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1]
|
|
34
|
+
0.0, 0.0, 0.0, 0.0 // sidey
|
|
35
|
+
);
|
|
36
|
+
styleMappingMat[0][3] = a_Position.z;
|
|
37
|
+
styleMappingMat[3][0] = a_uvs[2];
|
|
38
|
+
|
|
39
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
40
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
41
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
42
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
43
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
44
|
+
float id = a_vertexId; // 第n个顶点
|
|
45
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
46
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
47
|
+
|
|
48
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
49
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
50
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
51
|
+
|
|
52
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
53
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
54
|
+
textureOffset = opacityAndOffset.g;
|
|
55
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
56
|
+
|
|
57
|
+
vec4 pos = vec4(a_Position.xy, a_Position.z * a_Size, 1.0);
|
|
58
|
+
vec4 project_pos = project_position(pos);
|
|
59
|
+
|
|
60
|
+
if(u_heightfixed > 0.0) { // 判断几何体是否固定高度
|
|
61
|
+
project_pos.z = a_Position.z * a_Size;
|
|
62
|
+
project_pos.z += u_raisingHeight;
|
|
63
|
+
|
|
64
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
65
|
+
float mapboxZoomScale = 4.0/pow(2.0, 21.0 - u_Zoom);
|
|
66
|
+
project_pos.z *= mapboxZoomScale;
|
|
67
|
+
project_pos.z += u_raisingHeight * mapboxZoomScale;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
// project_pos.z += 500000.0; // amap1
|
|
72
|
+
|
|
73
|
+
// project_pos.z += (500000.0 * 4.0)/pow(2.0, 21.0 - u_Zoom); // mapbox
|
|
74
|
+
// gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
75
|
+
|
|
76
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
77
|
+
// gl_Position = u_Mvp * (vec4(project_pos.xyz * vec3(1.0, 1.0, -1.0), 1.0));
|
|
78
|
+
gl_Position = u_Mvp * (vec4(project_pos.xyz, 1.0));
|
|
79
|
+
} else {
|
|
80
|
+
gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
float lightWeight = calc_lighting(pos);
|
|
84
|
+
// v_Color = a_Color;
|
|
85
|
+
v_Color = vec4(a_Color.rgb * lightWeight, a_Color.w);
|
|
86
|
+
|
|
87
|
+
styleMappingMat[3][1] = lightWeight;
|
|
88
|
+
|
|
89
|
+
setPickingColor(a_PickingColor);
|
|
90
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
uniform sampler2D u_texture;
|
|
2
|
+
uniform float u_opacity: 1.0;
|
|
3
|
+
uniform vec4 u_sourceColor;
|
|
4
|
+
uniform vec4 u_targetColor;
|
|
5
|
+
uniform float u_linearColor: 0;
|
|
6
|
+
|
|
7
|
+
uniform float u_topsurface: 1.0;
|
|
8
|
+
uniform float u_sidesurface: 1.0;
|
|
9
|
+
|
|
10
|
+
varying vec4 v_Color;
|
|
11
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
12
|
+
#pragma include "picking"
|
|
13
|
+
|
|
14
|
+
void main() {
|
|
15
|
+
float opacity = styleMappingMat[0][0];
|
|
16
|
+
float isSide = styleMappingMat[0][3];
|
|
17
|
+
float lightWeight = styleMappingMat[3][1];
|
|
18
|
+
float topU = styleMappingMat[2][2];
|
|
19
|
+
float topV = styleMappingMat[2][3];
|
|
20
|
+
|
|
21
|
+
float sidey = styleMappingMat[3][0];
|
|
22
|
+
if(isSide < 1.0) {
|
|
23
|
+
// side face
|
|
24
|
+
if(u_sidesurface < 1.0) {
|
|
25
|
+
discard;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
if(u_linearColor == 1.0) {
|
|
29
|
+
vec4 linearColor = mix(u_targetColor, u_sourceColor, sidey);
|
|
30
|
+
linearColor.rgb *= lightWeight;
|
|
31
|
+
gl_FragColor = linearColor;
|
|
32
|
+
} else {
|
|
33
|
+
gl_FragColor = v_Color;
|
|
34
|
+
}
|
|
35
|
+
} else {
|
|
36
|
+
|
|
37
|
+
// top face
|
|
38
|
+
if(u_topsurface < 1.0) {
|
|
39
|
+
discard;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
gl_FragColor = texture2D(u_texture, vec2(topU, topV));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
|
|
46
|
+
gl_FragColor.a *= opacity;
|
|
47
|
+
gl_FragColor = filterColor(gl_FragColor);
|
|
48
|
+
}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
precision highp float;
|
|
2
|
+
|
|
3
|
+
#define ambientRatio 0.5
|
|
4
|
+
#define diffuseRatio 0.3
|
|
5
|
+
#define specularRatio 0.2
|
|
6
|
+
|
|
7
|
+
attribute vec4 a_Color;
|
|
8
|
+
attribute vec3 a_Position;
|
|
9
|
+
attribute vec3 a_Normal;
|
|
10
|
+
attribute float a_Size;
|
|
11
|
+
attribute vec3 a_uvs;
|
|
12
|
+
uniform mat4 u_ModelMatrix;
|
|
13
|
+
uniform mat4 u_Mvp;
|
|
14
|
+
|
|
15
|
+
varying vec4 v_Color;
|
|
16
|
+
uniform float u_heightfixed: 0.0; // 默认不固定
|
|
17
|
+
uniform float u_raisingHeight: 0.0;
|
|
18
|
+
uniform float u_opacity: 1.0;
|
|
19
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
20
|
+
|
|
21
|
+
#pragma include "styleMapping"
|
|
22
|
+
#pragma include "styleMappingCalOpacity"
|
|
23
|
+
|
|
24
|
+
#pragma include "projection"
|
|
25
|
+
#pragma include "light"
|
|
26
|
+
#pragma include "picking"
|
|
27
|
+
|
|
28
|
+
void main() {
|
|
29
|
+
v_Color = a_Color;
|
|
30
|
+
|
|
31
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
32
|
+
styleMappingMat = mat4(
|
|
33
|
+
0.0, 0.0, 0.0, 0.0, // opacity - strokeOpacity - strokeWidth - a_Position.z(judge side by a_Position.z)
|
|
34
|
+
0.0, 0.0, 0.0, 0.0, // strokeR - strokeG - strokeB - strokeA
|
|
35
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1] - u - v
|
|
36
|
+
0.0, 0.0, 0.0, 0.0 // sidey
|
|
37
|
+
);
|
|
38
|
+
|
|
39
|
+
styleMappingMat[0][3] = a_Position.z;
|
|
40
|
+
styleMappingMat[2][2] = a_uvs[0];
|
|
41
|
+
styleMappingMat[2][3] = 1.0 - a_uvs[1];
|
|
42
|
+
styleMappingMat[3][0] = a_uvs[2];
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
46
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
47
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
48
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
49
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
50
|
+
float id = a_vertexId; // 第n个顶点
|
|
51
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
52
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
53
|
+
|
|
54
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
55
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
56
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
57
|
+
|
|
58
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
59
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
60
|
+
textureOffset = opacityAndOffset.g;
|
|
61
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
62
|
+
|
|
63
|
+
vec4 pos = vec4(a_Position.xy, a_Position.z * a_Size, 1.0);
|
|
64
|
+
vec4 project_pos = project_position(pos);
|
|
65
|
+
|
|
66
|
+
if(u_heightfixed > 0.0) { // 判断几何体是否固定高度
|
|
67
|
+
project_pos.z = a_Position.z * a_Size;
|
|
68
|
+
project_pos.z += u_raisingHeight;
|
|
69
|
+
|
|
70
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
71
|
+
float mapboxZoomScale = 4.0/pow(2.0, 21.0 - u_Zoom);
|
|
72
|
+
project_pos.z *= mapboxZoomScale;
|
|
73
|
+
project_pos.z += u_raisingHeight * mapboxZoomScale;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
// project_pos.z += 500000.0; // amap1
|
|
78
|
+
|
|
79
|
+
// project_pos.z += (500000.0 * 4.0)/pow(2.0, 21.0 - u_Zoom); // mapbox
|
|
80
|
+
// gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
81
|
+
|
|
82
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
83
|
+
// gl_Position = u_Mvp * (vec4(project_pos.xyz * vec3(1.0, 1.0, -1.0), 1.0));
|
|
84
|
+
gl_Position = u_Mvp * (vec4(project_pos.xyz, 1.0));
|
|
85
|
+
} else {
|
|
86
|
+
gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
float lightWeight = calc_lighting(pos);
|
|
90
|
+
styleMappingMat[3][1] = lightWeight;
|
|
91
|
+
|
|
92
|
+
setPickingColor(a_PickingColor);
|
|
93
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
uniform float u_opacity: 1.0;
|
|
2
|
+
varying vec4 v_Color;
|
|
3
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
4
|
+
|
|
5
|
+
#pragma include "picking"
|
|
6
|
+
|
|
7
|
+
void main() {
|
|
8
|
+
float opacity = styleMappingMat[0][0];
|
|
9
|
+
gl_FragColor = v_Color;
|
|
10
|
+
gl_FragColor.a *= opacity;
|
|
11
|
+
gl_FragColor = filterColor(gl_FragColor);
|
|
12
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
uniform float u_opacity: 1.0;
|
|
2
|
+
varying vec4 v_Color;
|
|
3
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
4
|
+
|
|
5
|
+
#pragma include "picking"
|
|
6
|
+
uniform float u_opacitylinear: 0.0;
|
|
7
|
+
uniform float u_dir: 1.0;
|
|
8
|
+
varying vec3 v_linear;
|
|
9
|
+
varying vec2 v_pos;
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
void main() {
|
|
13
|
+
float opacity = styleMappingMat[0][0];
|
|
14
|
+
gl_FragColor = v_Color;
|
|
15
|
+
|
|
16
|
+
if(u_opacitylinear > 0.0) {
|
|
17
|
+
gl_FragColor.a *= u_dir == 1.0 ? 1.0 - length(v_pos - v_linear.xy)/v_linear.z : length(v_pos - v_linear.xy)/v_linear.z;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
gl_FragColor.a *= opacity;
|
|
21
|
+
gl_FragColor = filterColor(gl_FragColor);
|
|
22
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
attribute vec4 a_Color;
|
|
2
|
+
attribute vec3 a_Position;
|
|
3
|
+
|
|
4
|
+
uniform mat4 u_ModelMatrix;
|
|
5
|
+
uniform mat4 u_Mvp;
|
|
6
|
+
uniform float u_opacity: 1.0;
|
|
7
|
+
uniform float u_raisingHeight: 0.0;
|
|
8
|
+
|
|
9
|
+
varying vec4 v_Color;
|
|
10
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
11
|
+
|
|
12
|
+
#pragma include "styleMapping"
|
|
13
|
+
#pragma include "styleMappingCalOpacity"
|
|
14
|
+
|
|
15
|
+
#pragma include "projection"
|
|
16
|
+
#pragma include "picking"
|
|
17
|
+
|
|
18
|
+
uniform float u_opacitylinear: 0.0;
|
|
19
|
+
|
|
20
|
+
attribute vec3 a_linear;
|
|
21
|
+
varying vec3 v_linear;
|
|
22
|
+
varying vec2 v_pos;
|
|
23
|
+
|
|
24
|
+
void main() {
|
|
25
|
+
if(u_opacitylinear > 0.0) {
|
|
26
|
+
v_linear = a_linear;
|
|
27
|
+
v_pos = a_Position.xy;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
31
|
+
styleMappingMat = mat4(
|
|
32
|
+
0.0, 0.0, 0.0, 0.0, // opacity - strokeOpacity - strokeWidth - empty
|
|
33
|
+
0.0, 0.0, 0.0, 0.0, // strokeR - strokeG - strokeB - strokeA
|
|
34
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1]
|
|
35
|
+
0.0, 0.0, 0.0, 0.0
|
|
36
|
+
);
|
|
37
|
+
|
|
38
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
39
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
40
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
41
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
42
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
43
|
+
float id = a_vertexId; // 第n个顶点
|
|
44
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
45
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
46
|
+
|
|
47
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
48
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
49
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
50
|
+
|
|
51
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
52
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
53
|
+
textureOffset = opacityAndOffset.g;
|
|
54
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
55
|
+
|
|
56
|
+
v_Color = a_Color;
|
|
57
|
+
vec4 project_pos = project_position(vec4(a_Position, 1.0));
|
|
58
|
+
// gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
59
|
+
project_pos.z += u_raisingHeight;
|
|
60
|
+
|
|
61
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
62
|
+
float mapboxZoomScale = 4.0/pow(2.0, 21.0 - u_Zoom);
|
|
63
|
+
project_pos.z *= mapboxZoomScale;
|
|
64
|
+
project_pos.z += u_raisingHeight * mapboxZoomScale;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
68
|
+
gl_Position = u_Mvp * (vec4(project_pos.xyz, 1.0));
|
|
69
|
+
} else {
|
|
70
|
+
gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
setPickingColor(a_PickingColor);
|
|
74
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
attribute vec4 a_Color;
|
|
2
|
+
attribute vec3 a_Position;
|
|
3
|
+
|
|
4
|
+
uniform mat4 u_ModelMatrix;
|
|
5
|
+
uniform mat4 u_Mvp;
|
|
6
|
+
|
|
7
|
+
uniform float u_opacity: 1.0;
|
|
8
|
+
uniform float u_raisingHeight: 0.0;
|
|
9
|
+
|
|
10
|
+
varying vec4 v_Color;
|
|
11
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
12
|
+
|
|
13
|
+
#pragma include "styleMapping"
|
|
14
|
+
#pragma include "styleMappingCalOpacity"
|
|
15
|
+
|
|
16
|
+
#pragma include "projection"
|
|
17
|
+
#pragma include "picking"
|
|
18
|
+
|
|
19
|
+
void main() {
|
|
20
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
21
|
+
styleMappingMat = mat4(
|
|
22
|
+
0.0, 0.0, 0.0, 0.0, // opacity - strokeOpacity - strokeWidth - empty
|
|
23
|
+
0.0, 0.0, 0.0, 0.0, // strokeR - strokeG - strokeB - strokeA
|
|
24
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1]
|
|
25
|
+
0.0, 0.0, 0.0, 0.0
|
|
26
|
+
);
|
|
27
|
+
|
|
28
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
29
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
30
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
31
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
32
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
33
|
+
float id = a_vertexId; // 第n个顶点
|
|
34
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
35
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
36
|
+
|
|
37
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
38
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
39
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
40
|
+
|
|
41
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
42
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
43
|
+
textureOffset = opacityAndOffset.g;
|
|
44
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
45
|
+
|
|
46
|
+
v_Color = a_Color;
|
|
47
|
+
vec4 project_pos = project_position(vec4(a_Position, 1.0));
|
|
48
|
+
// gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
49
|
+
|
|
50
|
+
project_pos.z += u_raisingHeight;
|
|
51
|
+
|
|
52
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
53
|
+
float mapboxZoomScale = 4.0/pow(2.0, 21.0 - u_Zoom);
|
|
54
|
+
project_pos.z *= mapboxZoomScale;
|
|
55
|
+
project_pos.z += u_raisingHeight * mapboxZoomScale;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
59
|
+
gl_Position = u_Mvp * (vec4(project_pos.xyz, 1.0));
|
|
60
|
+
} else {
|
|
61
|
+
gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
setPickingColor(a_PickingColor);
|
|
65
|
+
}
|
|
66
|
+
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
uniform float u_opacity: 1.0;
|
|
2
|
+
varying vec4 v_Color;
|
|
3
|
+
varying mat4 styleMappingMat; // 传递从片元中传递的映射数据
|
|
4
|
+
|
|
5
|
+
#pragma include "picking"
|
|
6
|
+
|
|
7
|
+
void main() {
|
|
8
|
+
float opacity = styleMappingMat[0][0];
|
|
9
|
+
gl_FragColor = v_Color;
|
|
10
|
+
gl_FragColor.a *= opacity;
|
|
11
|
+
gl_FragColor = filterColor(gl_FragColor);
|
|
12
|
+
}
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
attribute vec4 a_Color;
|
|
2
|
+
attribute vec3 a_Position;
|
|
3
|
+
|
|
4
|
+
uniform mat4 u_ModelMatrix;
|
|
5
|
+
uniform mat4 u_Mvp;
|
|
6
|
+
|
|
7
|
+
uniform float u_opacity: 1.0;
|
|
8
|
+
|
|
9
|
+
uniform vec2 u_tileOrigin;
|
|
10
|
+
uniform float u_coord;
|
|
11
|
+
|
|
12
|
+
varying vec4 v_Color;
|
|
13
|
+
varying mat4 styleMappingMat; // 用于将在顶点着色器中计算好的样式值传递给片元
|
|
14
|
+
|
|
15
|
+
#pragma include "styleMapping"
|
|
16
|
+
#pragma include "styleMappingCalOpacity"
|
|
17
|
+
|
|
18
|
+
#pragma include "projection"
|
|
19
|
+
#pragma include "picking"
|
|
20
|
+
|
|
21
|
+
void main() {
|
|
22
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
23
|
+
styleMappingMat = mat4(
|
|
24
|
+
0.0, 0.0, 0.0, 0.0, // opacity - strokeOpacity - strokeWidth - empty
|
|
25
|
+
0.0, 0.0, 0.0, 0.0, // strokeR - strokeG - strokeB - strokeA
|
|
26
|
+
0.0, 0.0, 0.0, 0.0, // offsets[0] - offsets[1]
|
|
27
|
+
0.0, 0.0, 0.0, 0.0
|
|
28
|
+
);
|
|
29
|
+
|
|
30
|
+
float rowCount = u_cellTypeLayout[0][0]; // 当前的数据纹理有几行
|
|
31
|
+
float columnCount = u_cellTypeLayout[0][1]; // 当看到数据纹理有几列
|
|
32
|
+
float columnWidth = 1.0/columnCount; // 列宽
|
|
33
|
+
float rowHeight = 1.0/rowCount; // 行高
|
|
34
|
+
float cellCount = calCellCount(); // opacity - strokeOpacity - strokeWidth - stroke - offsets
|
|
35
|
+
float id = a_vertexId; // 第n个顶点
|
|
36
|
+
float cellCurrentRow = floor(id * cellCount / columnCount) + 1.0; // 起始点在第几行
|
|
37
|
+
float cellCurrentColumn = mod(id * cellCount, columnCount) + 1.0; // 起始点在第几列
|
|
38
|
+
|
|
39
|
+
// cell 固定顺序 opacity -> strokeOpacity -> strokeWidth -> stroke ...
|
|
40
|
+
// 按顺序从 cell 中取值、若没有则自动往下取值
|
|
41
|
+
float textureOffset = 0.0; // 在 cell 中取值的偏移量
|
|
42
|
+
|
|
43
|
+
vec2 opacityAndOffset = calOpacityAndOffset(cellCurrentRow, cellCurrentColumn, columnCount, textureOffset, columnWidth, rowHeight);
|
|
44
|
+
styleMappingMat[0][0] = opacityAndOffset.r;
|
|
45
|
+
textureOffset = opacityAndOffset.g;
|
|
46
|
+
// cal style mapping - 数据纹理映射部分的计算
|
|
47
|
+
|
|
48
|
+
v_Color = a_Color;
|
|
49
|
+
vec4 project_pos = project_position(vec4(a_Position, 1.0));
|
|
50
|
+
|
|
51
|
+
|
|
52
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
53
|
+
float mapboxZoomScale = 4.0/pow(2.0, 21.0 - u_Zoom);
|
|
54
|
+
project_pos.z *= mapboxZoomScale;
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
if(u_coord > 0.0) {
|
|
58
|
+
if(u_CoordinateSystem == COORDINATE_SYSTEM_P20_2) { // gaode2.x
|
|
59
|
+
gl_Position = u_Mvp * (vec4(project_pos.xyz, 1.0));
|
|
60
|
+
} else {
|
|
61
|
+
gl_Position = project_common_position_to_clipspace(vec4(project_pos.xyz, 1.0));
|
|
62
|
+
}
|
|
63
|
+
} else {
|
|
64
|
+
vec2 pointPos = a_Position.xy;
|
|
65
|
+
vec4 world = vec4(project_mvt_offset_position(vec4(u_tileOrigin, 0.0, 1.0)).xyz, 1.0); // 瓦片起始点的世界坐标
|
|
66
|
+
|
|
67
|
+
vec2 pointOffset = pointPos * pow(2.0, u_Zoom); // 瓦片内的点的偏移坐标
|
|
68
|
+
|
|
69
|
+
world.xy += pointOffset;
|
|
70
|
+
|
|
71
|
+
if (u_CoordinateSystem == COORDINATE_SYSTEM_METER_OFFSET || u_CoordinateSystem == COORDINATE_SYSTEM_LNGLAT_OFFSET) {
|
|
72
|
+
// Needs to be divided with project_uCommonUnitsPerMeter
|
|
73
|
+
world.w *= u_PixelsPerMeter.z;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
gl_Position = u_ViewProjectionMatrix * world + u_ViewportCenterProjection;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
|
|
80
|
+
setPickingColor(a_PickingColor);
|
|
81
|
+
}
|
|
82
|
+
|