@antv/l7-layers 2.21.1 → 2.21.3

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.
Files changed (394) hide show
  1. package/es/canvas/index.js +60 -113
  2. package/es/canvas/models/canvas.js +95 -135
  3. package/es/canvas/models/constants.js +1 -1
  4. package/es/citybuliding/building.js +20 -58
  5. package/es/citybuliding/models/build.js +142 -199
  6. package/es/core/BaseLayer.d.ts +1 -1
  7. package/es/core/BaseLayer.js +1113 -1412
  8. package/es/core/BaseModel.js +263 -317
  9. package/es/core/CommonStyleAttribute.js +25 -18
  10. package/es/core/LayerPickService.js +92 -141
  11. package/es/core/TextureService.js +58 -69
  12. package/es/core/constant.js +2 -2
  13. package/es/core/interface.js +5 -5
  14. package/es/core/line_trangluation.js +38 -43
  15. package/es/core/shape/Path.js +21 -12
  16. package/es/core/shape/arrow.js +50 -62
  17. package/es/core/shape/extrude.js +54 -62
  18. package/es/core/triangulation.js +192 -171
  19. package/es/core/utils.js +5 -5
  20. package/es/earth/index.js +35 -73
  21. package/es/earth/models/atmosphere.js +98 -148
  22. package/es/earth/models/base.js +148 -201
  23. package/es/earth/models/bloomsphere.js +97 -147
  24. package/es/earth/utils.js +37 -38
  25. package/es/geometry/index.js +36 -75
  26. package/es/geometry/models/billboard.js +147 -204
  27. package/es/geometry/models/index.js +1 -1
  28. package/es/geometry/models/plane.js +277 -357
  29. package/es/geometry/models/sprite.js +182 -240
  30. package/es/heatmap/index.js +72 -121
  31. package/es/heatmap/models/grid.js +66 -118
  32. package/es/heatmap/models/grid3d.js +101 -151
  33. package/es/heatmap/models/heatmap.js +398 -455
  34. package/es/heatmap/models/hexagon.js +67 -119
  35. package/es/heatmap/models/index.js +1 -1
  36. package/es/heatmap/triangulation.js +20 -20
  37. package/es/image/index.js +23 -62
  38. package/es/image/models/image.js +99 -163
  39. package/es/image/models/index.js +1 -1
  40. package/es/line/index.js +65 -106
  41. package/es/line/models/arc.js +200 -248
  42. package/es/line/models/arc_3d.js +190 -241
  43. package/es/line/models/flow.js +101 -153
  44. package/es/line/models/great_circle.js +183 -234
  45. package/es/line/models/index.js +1 -1
  46. package/es/line/models/line.js +230 -285
  47. package/es/line/models/simple_line.js +142 -192
  48. package/es/line/models/wall.js +221 -273
  49. package/es/mask/index.js +16 -53
  50. package/es/mask/models/fill.js +51 -108
  51. package/es/mask/models/index.js +1 -1
  52. package/es/plugins/DataMappingPlugin.js +205 -249
  53. package/es/plugins/DataSourcePlugin.js +64 -92
  54. package/es/plugins/FeatureScalePlugin.js +258 -302
  55. package/es/plugins/LayerAnimateStylePlugin.js +12 -22
  56. package/es/plugins/LayerMaskPlugin.js +15 -24
  57. package/es/plugins/LayerModelPlugin.js +52 -136
  58. package/es/plugins/LayerStylePlugin.js +14 -23
  59. package/es/plugins/LightingPlugin.js +26 -37
  60. package/es/plugins/MultiPassRendererPlugin.js +34 -39
  61. package/es/plugins/PixelPickingPlugin.js +129 -150
  62. package/es/plugins/RegisterStyleAttributePlugin.js +80 -96
  63. package/es/plugins/ShaderUniformPlugin.js +159 -131
  64. package/es/plugins/UpdateModelPlugin.js +16 -26
  65. package/es/plugins/UpdateStyleAttributePlugin.js +47 -65
  66. package/es/plugins/index.d.ts +1 -1
  67. package/es/point/index.js +118 -182
  68. package/es/point/models/billboard_point.js +72 -127
  69. package/es/point/models/earthExtrude.js +170 -220
  70. package/es/point/models/earthFill.js +136 -192
  71. package/es/point/models/extrude.js +167 -217
  72. package/es/point/models/fill.js +152 -209
  73. package/es/point/models/fillImage.js +156 -211
  74. package/es/point/models/image.js +127 -180
  75. package/es/point/models/index.js +1 -1
  76. package/es/point/models/normal.js +67 -122
  77. package/es/point/models/radar.js +93 -148
  78. package/es/point/models/text.js +447 -578
  79. package/es/point/shape/extrude.js +19 -25
  80. package/es/polygon/index.js +61 -99
  81. package/es/polygon/models/extrude.js +208 -281
  82. package/es/polygon/models/extrusion.js +95 -142
  83. package/es/polygon/models/fill.js +102 -153
  84. package/es/polygon/models/index.js +1 -1
  85. package/es/polygon/models/ocean.js +139 -198
  86. package/es/polygon/models/water.js +120 -179
  87. package/es/raster/buffers/triangulation.js +13 -11
  88. package/es/raster/index.js +47 -88
  89. package/es/raster/models/index.js +1 -1
  90. package/es/raster/models/raster.js +134 -202
  91. package/es/raster/models/rasterRgb.js +134 -208
  92. package/es/raster/models/rasterTerrainRgb.js +98 -153
  93. package/es/tile/core/BaseLayer.d.ts +1 -0
  94. package/es/tile/core/BaseLayer.js +206 -282
  95. package/es/tile/core/TileDebugLayer.js +12 -46
  96. package/es/tile/interaction/getRasterData.js +24 -30
  97. package/es/tile/interaction/utils.js +15 -33
  98. package/es/tile/service/TileLayerService.js +104 -177
  99. package/es/tile/service/TilePickService.js +99 -156
  100. package/es/tile/service/TileSourceService.js +17 -26
  101. package/es/tile/tile/DebugTile.js +41 -78
  102. package/es/tile/tile/ImageTile.js +33 -66
  103. package/es/tile/tile/MaskTile.js +47 -81
  104. package/es/tile/tile/RasterRGBTile.js +40 -71
  105. package/es/tile/tile/RasterTerrainRGBTile.js +33 -66
  106. package/es/tile/tile/RasterTile.js +69 -104
  107. package/es/tile/tile/Tile.d.ts +1 -1
  108. package/es/tile/tile/Tile.js +151 -232
  109. package/es/tile/tile/VectorTile.js +77 -124
  110. package/es/tile/tile/index.d.ts +1 -1
  111. package/es/tile/tile/index.js +4 -2
  112. package/es/tile/tile/util.d.ts +1 -1
  113. package/es/tile/utils/constants.js +1 -1
  114. package/es/tile/utils/utils.js +2 -2
  115. package/es/utils/blend.js +52 -46
  116. package/es/utils/collision-index.js +62 -70
  117. package/es/utils/extrude_polyline.js +441 -471
  118. package/es/utils/grid-index.js +97 -123
  119. package/es/utils/identityScale.js +5 -5
  120. package/es/utils/load-image.js +15 -39
  121. package/es/utils/multiPassRender.js +7 -9
  122. package/es/utils/polylineNormal.js +40 -42
  123. package/es/utils/rampcolor_legend.js +5 -3
  124. package/es/utils/simpleLine.js +53 -66
  125. package/es/utils/symbol-layout.js +95 -117
  126. package/es/wind/index.js +28 -70
  127. package/es/wind/models/index.js +1 -1
  128. package/es/wind/models/utils.js +36 -34
  129. package/es/wind/models/wind.js +203 -260
  130. package/es/wind/models/windRender.js +258 -269
  131. package/es/wind/models/windShader.js +145 -6
  132. package/lib/canvas/index.d.ts +18 -0
  133. package/lib/canvas/index.js +64 -113
  134. package/lib/canvas/models/canvas.d.ts +23 -0
  135. package/lib/canvas/models/canvas.js +97 -136
  136. package/lib/canvas/models/constants.d.ts +2 -0
  137. package/lib/canvas/models/constants.js +1 -1
  138. package/lib/canvas/models/index.d.ts +2 -0
  139. package/lib/canvas/models/index.js +2 -2
  140. package/lib/citybuliding/building.d.ts +7 -0
  141. package/lib/citybuliding/building.js +22 -58
  142. package/lib/citybuliding/models/build.d.ts +17 -0
  143. package/lib/citybuliding/models/build.js +144 -199
  144. package/lib/core/BaseLayer.d.ts +247 -0
  145. package/lib/core/BaseLayer.js +1115 -1412
  146. package/lib/core/BaseModel.d.ts +82 -0
  147. package/lib/core/BaseModel.js +263 -315
  148. package/lib/core/CommonStyleAttribute.d.ts +20 -0
  149. package/lib/core/CommonStyleAttribute.js +25 -18
  150. package/lib/core/LayerPickService.d.ts +12 -0
  151. package/lib/core/LayerPickService.js +93 -140
  152. package/lib/core/TextureService.d.ts +15 -0
  153. package/lib/core/TextureService.js +59 -68
  154. package/lib/core/constant.d.ts +6 -0
  155. package/lib/core/constant.js +2 -2
  156. package/lib/core/interface.d.ts +282 -0
  157. package/lib/core/interface.js +5 -5
  158. package/lib/core/line_trangluation.d.ts +19 -0
  159. package/lib/core/line_trangluation.js +38 -43
  160. package/lib/core/schema.d.ts +27 -0
  161. package/lib/core/shape/Path.d.ts +39 -0
  162. package/lib/core/shape/Path.js +21 -13
  163. package/lib/core/shape/arrow.d.ts +25 -0
  164. package/lib/core/shape/arrow.js +50 -62
  165. package/lib/core/shape/extrude.d.ts +17 -0
  166. package/lib/core/shape/extrude.js +54 -62
  167. package/lib/core/triangulation.d.ts +136 -0
  168. package/lib/core/triangulation.js +194 -174
  169. package/lib/core/utils.d.ts +4 -0
  170. package/lib/core/utils.js +5 -5
  171. package/lib/earth/index.d.ts +22 -0
  172. package/lib/earth/index.js +37 -73
  173. package/lib/earth/models/atmosphere.d.ts +15 -0
  174. package/lib/earth/models/atmosphere.js +100 -148
  175. package/lib/earth/models/base.d.ts +22 -0
  176. package/lib/earth/models/base.js +150 -201
  177. package/lib/earth/models/bloomsphere.d.ts +15 -0
  178. package/lib/earth/models/bloomsphere.js +99 -147
  179. package/lib/earth/utils.d.ts +26 -0
  180. package/lib/earth/utils.js +37 -39
  181. package/lib/geometry/index.d.ts +22 -0
  182. package/lib/geometry/index.js +38 -75
  183. package/lib/geometry/models/billboard.d.ts +24 -0
  184. package/lib/geometry/models/billboard.js +149 -204
  185. package/lib/geometry/models/index.d.ts +5 -0
  186. package/lib/geometry/models/index.js +1 -1
  187. package/lib/geometry/models/plane.d.ts +43 -0
  188. package/lib/geometry/models/plane.js +280 -357
  189. package/lib/geometry/models/sprite.d.ts +48 -0
  190. package/lib/geometry/models/sprite.js +184 -240
  191. package/lib/heatmap/index.d.ts +13 -0
  192. package/lib/heatmap/index.js +74 -121
  193. package/lib/heatmap/models/grid.d.ts +15 -0
  194. package/lib/heatmap/models/grid.js +68 -118
  195. package/lib/heatmap/models/grid3d.d.ts +15 -0
  196. package/lib/heatmap/models/grid3d.js +103 -151
  197. package/lib/heatmap/models/heatmap.d.ts +27 -0
  198. package/lib/heatmap/models/heatmap.js +400 -455
  199. package/lib/heatmap/models/hexagon.d.ts +15 -0
  200. package/lib/heatmap/models/hexagon.js +69 -119
  201. package/lib/heatmap/models/index.d.ts +5 -0
  202. package/lib/heatmap/models/index.js +1 -1
  203. package/lib/heatmap/triangulation.d.ts +5 -0
  204. package/lib/heatmap/triangulation.js +20 -20
  205. package/lib/image/index.d.ts +9 -0
  206. package/lib/image/index.js +25 -62
  207. package/lib/image/models/image.d.ts +17 -0
  208. package/lib/image/models/image.js +101 -163
  209. package/lib/image/models/index.d.ts +5 -0
  210. package/lib/image/models/index.js +1 -1
  211. package/lib/index.d.ts +18 -0
  212. package/lib/index.js +17 -17
  213. package/lib/line/index.d.ts +36 -0
  214. package/lib/line/index.js +67 -106
  215. package/lib/line/models/arc.d.ts +22 -0
  216. package/lib/line/models/arc.js +202 -248
  217. package/lib/line/models/arc_3d.d.ts +22 -0
  218. package/lib/line/models/arc_3d.js +193 -241
  219. package/lib/line/models/flow.d.ts +14 -0
  220. package/lib/line/models/flow.js +103 -153
  221. package/lib/line/models/great_circle.d.ts +17 -0
  222. package/lib/line/models/great_circle.js +185 -234
  223. package/lib/line/models/index.d.ts +5 -0
  224. package/lib/line/models/index.js +1 -1
  225. package/lib/line/models/line.d.ts +27 -0
  226. package/lib/line/models/line.js +232 -285
  227. package/lib/line/models/simple_line.d.ts +19 -0
  228. package/lib/line/models/simple_line.js +144 -192
  229. package/lib/line/models/wall.d.ts +17 -0
  230. package/lib/line/models/wall.js +223 -273
  231. package/lib/mask/index.d.ts +16 -0
  232. package/lib/mask/index.js +18 -53
  233. package/lib/mask/models/fill.d.ts +18 -0
  234. package/lib/mask/models/fill.js +53 -108
  235. package/lib/mask/models/index.d.ts +5 -0
  236. package/lib/mask/models/index.js +1 -1
  237. package/lib/plugins/DataMappingPlugin.d.ts +13 -0
  238. package/lib/plugins/DataMappingPlugin.js +206 -248
  239. package/lib/plugins/DataSourcePlugin.d.ts +6 -0
  240. package/lib/plugins/DataSourcePlugin.js +65 -91
  241. package/lib/plugins/FeatureScalePlugin.d.ts +20 -0
  242. package/lib/plugins/FeatureScalePlugin.js +261 -304
  243. package/lib/plugins/LayerAnimateStylePlugin.d.ts +4 -0
  244. package/lib/plugins/LayerAnimateStylePlugin.js +13 -21
  245. package/lib/plugins/LayerMaskPlugin.d.ts +7 -0
  246. package/lib/plugins/LayerMaskPlugin.js +16 -24
  247. package/lib/plugins/LayerModelPlugin.d.ts +10 -0
  248. package/lib/plugins/LayerModelPlugin.js +53 -135
  249. package/lib/plugins/LayerStylePlugin.d.ts +7 -0
  250. package/lib/plugins/LayerStylePlugin.js +15 -23
  251. package/lib/plugins/LightingPlugin.d.ts +35 -0
  252. package/lib/plugins/LightingPlugin.js +27 -36
  253. package/lib/plugins/MultiPassRendererPlugin.d.ts +22 -0
  254. package/lib/plugins/MultiPassRendererPlugin.js +35 -38
  255. package/lib/plugins/PixelPickingPlugin.d.ts +11 -0
  256. package/lib/plugins/PixelPickingPlugin.js +130 -149
  257. package/lib/plugins/RegisterStyleAttributePlugin.d.ts +11 -0
  258. package/lib/plugins/RegisterStyleAttributePlugin.js +81 -96
  259. package/lib/plugins/ShaderUniformPlugin.d.ts +22 -0
  260. package/lib/plugins/ShaderUniformPlugin.js +160 -130
  261. package/lib/plugins/UpdateModelPlugin.d.ts +7 -0
  262. package/lib/plugins/UpdateModelPlugin.js +17 -26
  263. package/lib/plugins/UpdateStyleAttributePlugin.d.ts +9 -0
  264. package/lib/plugins/UpdateStyleAttributePlugin.js +48 -65
  265. package/lib/plugins/index.d.ts +15 -0
  266. package/lib/point/index.d.ts +33 -0
  267. package/lib/point/index.js +120 -182
  268. package/lib/point/models/billboard_point.d.ts +21 -0
  269. package/lib/point/models/billboard_point.js +74 -127
  270. package/lib/point/models/earthExtrude.d.ts +16 -0
  271. package/lib/point/models/earthExtrude.js +172 -220
  272. package/lib/point/models/earthFill.d.ts +15 -0
  273. package/lib/point/models/earthFill.js +138 -192
  274. package/lib/point/models/extrude.d.ts +16 -0
  275. package/lib/point/models/extrude.js +169 -217
  276. package/lib/point/models/fill.d.ts +31 -0
  277. package/lib/point/models/fill.js +154 -209
  278. package/lib/point/models/fillImage.d.ts +26 -0
  279. package/lib/point/models/fillImage.js +159 -211
  280. package/lib/point/models/image.d.ts +18 -0
  281. package/lib/point/models/image.js +129 -180
  282. package/lib/point/models/index.d.ts +5 -0
  283. package/lib/point/models/index.js +1 -1
  284. package/lib/point/models/normal.d.ts +22 -0
  285. package/lib/point/models/normal.js +69 -122
  286. package/lib/point/models/radar.d.ts +22 -0
  287. package/lib/point/models/radar.js +95 -148
  288. package/lib/point/models/text.d.ts +69 -0
  289. package/lib/point/models/text.js +449 -578
  290. package/lib/point/shape/extrude.d.ts +15 -0
  291. package/lib/point/shape/extrude.js +19 -25
  292. package/lib/polygon/index.d.ts +18 -0
  293. package/lib/polygon/index.js +63 -99
  294. package/lib/polygon/models/extrude.d.ts +25 -0
  295. package/lib/polygon/models/extrude.js +210 -281
  296. package/lib/polygon/models/extrusion.d.ts +24 -0
  297. package/lib/polygon/models/extrusion.js +97 -142
  298. package/lib/polygon/models/fill.d.ts +18 -0
  299. package/lib/polygon/models/fill.js +104 -153
  300. package/lib/polygon/models/index.d.ts +5 -0
  301. package/lib/polygon/models/index.js +1 -1
  302. package/lib/polygon/models/ocean.d.ts +23 -0
  303. package/lib/polygon/models/ocean.js +141 -198
  304. package/lib/polygon/models/water.d.ts +21 -0
  305. package/lib/polygon/models/water.js +122 -179
  306. package/lib/raster/buffers/triangulation.d.ts +6 -0
  307. package/lib/raster/buffers/triangulation.js +13 -11
  308. package/lib/raster/index.d.ts +11 -0
  309. package/lib/raster/index.js +49 -88
  310. package/lib/raster/models/index.d.ts +5 -0
  311. package/lib/raster/models/index.js +1 -1
  312. package/lib/raster/models/raster.d.ts +21 -0
  313. package/lib/raster/models/raster.js +136 -202
  314. package/lib/raster/models/rasterRgb.d.ts +21 -0
  315. package/lib/raster/models/rasterRgb.js +136 -208
  316. package/lib/raster/models/rasterTerrainRgb.d.ts +16 -0
  317. package/lib/raster/models/rasterTerrainRgb.js +100 -153
  318. package/lib/tile/core/BaseLayer.d.ts +48 -0
  319. package/lib/tile/core/BaseLayer.js +207 -281
  320. package/lib/tile/core/TileDebugLayer.d.ts +15 -0
  321. package/lib/tile/core/TileDebugLayer.js +14 -46
  322. package/lib/tile/interaction/getFeatureData.d.ts +0 -0
  323. package/lib/tile/interaction/getRasterData.d.ts +4 -0
  324. package/lib/tile/interaction/getRasterData.js +24 -31
  325. package/lib/tile/interaction/utils.d.ts +11 -0
  326. package/lib/tile/interaction/utils.js +15 -34
  327. package/lib/tile/interface.d.ts +29 -0
  328. package/lib/tile/service/TileLayerService.d.ts +33 -0
  329. package/lib/tile/service/TileLayerService.js +105 -177
  330. package/lib/tile/service/TilePickService.d.ts +26 -0
  331. package/lib/tile/service/TilePickService.js +100 -156
  332. package/lib/tile/service/TileSourceService.d.ts +7 -0
  333. package/lib/tile/service/TileSourceService.js +20 -29
  334. package/lib/tile/tile/DebugTile.d.ts +16 -0
  335. package/lib/tile/tile/DebugTile.js +43 -78
  336. package/lib/tile/tile/ImageTile.d.ts +14 -0
  337. package/lib/tile/tile/ImageTile.js +35 -66
  338. package/lib/tile/tile/MaskTile.d.ts +18 -0
  339. package/lib/tile/tile/MaskTile.js +49 -81
  340. package/lib/tile/tile/RasterRGBTile.d.ts +11 -0
  341. package/lib/tile/tile/RasterRGBTile.js +42 -71
  342. package/lib/tile/tile/RasterTerrainRGBTile.d.ts +14 -0
  343. package/lib/tile/tile/RasterTerrainRGBTile.js +35 -66
  344. package/lib/tile/tile/RasterTile.d.ts +18 -0
  345. package/lib/tile/tile/RasterTile.js +71 -104
  346. package/lib/tile/tile/Tile.d.ts +114 -0
  347. package/lib/tile/tile/Tile.js +152 -231
  348. package/lib/tile/tile/VectorTile.d.ts +26 -0
  349. package/lib/tile/tile/VectorTile.js +79 -124
  350. package/lib/tile/tile/index.d.ts +12 -0
  351. package/lib/tile/tile/index.js +6 -4
  352. package/lib/tile/tile/util.d.ts +5 -0
  353. package/lib/tile/utils/constants.d.ts +1 -0
  354. package/lib/tile/utils/constants.js +1 -1
  355. package/lib/tile/utils/utils.d.ts +8 -0
  356. package/lib/tile/utils/utils.js +2 -2
  357. package/lib/utils/blend.d.ts +2 -0
  358. package/lib/utils/blend.js +52 -47
  359. package/lib/utils/collision-index.d.ts +47 -0
  360. package/lib/utils/collision-index.js +64 -69
  361. package/lib/utils/extrude_polyline.d.ts +68 -0
  362. package/lib/utils/extrude_polyline.js +442 -470
  363. package/lib/utils/grid-index.d.ts +28 -0
  364. package/lib/utils/grid-index.js +97 -123
  365. package/lib/utils/identityScale.d.ts +8 -0
  366. package/lib/utils/identityScale.js +5 -5
  367. package/lib/utils/load-image.d.ts +1 -0
  368. package/lib/utils/load-image.js +15 -39
  369. package/lib/utils/multiPassRender.d.ts +16 -0
  370. package/lib/utils/multiPassRender.js +7 -10
  371. package/lib/utils/polylineNormal.d.ts +9 -0
  372. package/lib/utils/polylineNormal.js +40 -43
  373. package/lib/utils/rampcolor_legend.d.ts +6 -0
  374. package/lib/utils/rampcolor_legend.js +5 -4
  375. package/lib/utils/simpleLine.d.ts +23 -0
  376. package/lib/utils/simpleLine.js +54 -65
  377. package/lib/utils/stencil.d.ts +7 -0
  378. package/lib/utils/symbol-layout.d.ts +43 -0
  379. package/lib/utils/symbol-layout.js +95 -117
  380. package/lib/wind/index.d.ts +11 -0
  381. package/lib/wind/index.js +30 -70
  382. package/lib/wind/models/index.d.ts +5 -0
  383. package/lib/wind/models/index.js +1 -1
  384. package/lib/wind/models/utils.d.ts +19 -0
  385. package/lib/wind/models/utils.js +36 -34
  386. package/lib/wind/models/wind.d.ts +24 -0
  387. package/lib/wind/models/wind.js +205 -260
  388. package/lib/wind/models/windRender.d.ts +104 -0
  389. package/lib/wind/models/windRender.js +261 -272
  390. package/lib/wind/models/windShader.d.ts +12 -0
  391. package/lib/wind/models/windShader.js +145 -6
  392. package/package.json +16 -19
  393. package/es/glsl.d.ts +0 -5
  394. package/lib/glsl.d.ts +0 -5
@@ -1,167 +1,146 @@
1
- import _toConsumableArray from "@babel/runtime/helpers/esm/toConsumableArray";
2
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
3
- import _createClass from "@babel/runtime/helpers/esm/createClass";
1
+ import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
4
2
  import { AttributeType, gl } from '@antv/l7-core';
5
3
  import { decodePickingColor, encodePickingColor, lodashUtil, rgb2arr } from '@antv/l7-utils';
6
4
  import { ShaderLocation } from "../core/CommonStyleAttribute";
7
- var isNumber = lodashUtil.isNumber;
8
- var PickingStage = {
5
+ const {
6
+ isNumber
7
+ } = lodashUtil;
8
+ const PickingStage = {
9
9
  NONE: 0.0,
10
10
  ENCODE: 1.0,
11
11
  HIGHLIGHT: 2.0
12
12
  };
13
- var PixelPickingPlugin = /*#__PURE__*/function () {
14
- function PixelPickingPlugin() {
15
- _classCallCheck(this, PixelPickingPlugin);
16
- }
17
- _createClass(PixelPickingPlugin, [{
18
- key: "pickOption2Array",
19
- value:
13
+ export default class PixelPickingPlugin {
14
+ constructor() {
20
15
  /**
21
16
  * Use map to keep order of insertion.
22
17
  * @see https://stackoverflow.com/questions/5525795/does-javascript-guarantee-object-property-order
23
18
  */
19
+ _defineProperty(this, "pickingUniformMap", void 0);
20
+ }
21
+ pickOption2Array() {
22
+ const array = [];
23
+ this.pickingUniformMap.forEach(value => {
24
+ if (isNumber(value)) {
25
+ array.push(value);
26
+ } else {
27
+ array.push(...value);
28
+ }
29
+ });
30
+ return array;
31
+ }
32
+ updatePickOption(options, layer) {
33
+ Object.keys(options).forEach(key => {
34
+ this.pickingUniformMap.set(key, options[key]);
35
+ });
36
+ const u_PickingBuffer = layer.getLayerConfig().pickingBuffer || 0;
37
+ // Tip: 当前地图是否在拖动
38
+ const u_shaderPick = Number(layer.getShaderPickStat());
39
+ this.pickingUniformMap.set('u_PickingBuffer', u_PickingBuffer);
40
+ this.pickingUniformMap.set('u_shaderPick', u_shaderPick);
41
+ const uniformBuffer = layer.getPickingUniformBuffer();
42
+ uniformBuffer.subData({
43
+ offset: 0,
44
+ data: this.pickOption2Array()
45
+ });
46
+ }
47
+ apply(layer, {
48
+ styleAttributeService
49
+ }) {
50
+ this.pickingUniformMap = new Map([['u_HighlightColor', [1, 0, 0, 1]], ['u_SelectColor', [1, 0, 0, 1]], ['u_PickingColor', [0, 0, 0]], ['u_PickingStage', 0], ['u_CurrentSelectedId', [0, 0, 0]], ['u_PickingThreshold', 10], ['u_PickingBuffer', 0], ['u_shaderPick', 0], ['u_activeMix', 0]]);
24
51
 
25
- function pickOption2Array() {
26
- var array = [];
27
- this.pickingUniformMap.forEach(function (value) {
28
- if (isNumber(value)) {
29
- array.push(value);
30
- } else {
31
- array.push.apply(array, _toConsumableArray(value));
32
- }
33
- });
34
- return array;
35
- }
36
- }, {
37
- key: "updatePickOption",
38
- value: function updatePickOption(options, layer) {
39
- var _this = this;
40
- Object.keys(options).forEach(function (key) {
41
- _this.pickingUniformMap.set(key, options[key]);
42
- });
43
- var u_PickingBuffer = layer.getLayerConfig().pickingBuffer || 0;
44
- // Tip: 当前地图是否在拖动
45
- var u_shaderPick = Number(layer.getShaderPickStat());
46
- this.pickingUniformMap.set('u_PickingBuffer', u_PickingBuffer);
47
- this.pickingUniformMap.set('u_shaderPick', u_shaderPick);
48
- var uniformBuffer = layer.getPickingUniformBuffer();
49
- uniformBuffer.subData({
50
- offset: 0,
51
- data: this.pickOption2Array()
52
- });
53
- }
54
- }, {
55
- key: "apply",
56
- value: function apply(layer, _ref) {
57
- var _this2 = this;
58
- var styleAttributeService = _ref.styleAttributeService;
59
- this.pickingUniformMap = new Map([['u_HighlightColor', [1, 0, 0, 1]], ['u_SelectColor', [1, 0, 0, 1]], ['u_PickingColor', [0, 0, 0]], ['u_PickingStage', 0], ['u_CurrentSelectedId', [0, 0, 0]], ['u_PickingThreshold', 10], ['u_PickingBuffer', 0], ['u_shaderPick', 0], ['u_activeMix', 0]]);
60
-
61
- // TODO: 由于 Shader 目前无法根据是否开启拾取进行内容修改,因此即使不开启也需要生成 a_PickingColor
62
- layer.hooks.init.tapPromise('PixelPickingPlugin', function () {
63
- var _layer$getLayerConfig = layer.getLayerConfig(),
64
- enablePicking = _layer$getLayerConfig.enablePicking;
65
- styleAttributeService.registerStyleAttribute({
66
- name: 'pickingColor',
67
- type: AttributeType.Attribute,
68
- descriptor: {
69
- name: 'a_PickingColor',
70
- shaderLocation: ShaderLocation.PICKING_COLOR,
71
- buffer: {
72
- data: [],
73
- type: gl.FLOAT
74
- },
75
- size: 3,
76
- // TODO: 固定 feature range 范围内的 pickingColor 都是固定的,可以生成 cache
77
- update: function update(feature) {
78
- // 只有开启拾取才需要 encode
79
- var id = feature.id;
80
- return enablePicking ? encodePickingColor(id) : [0, 0, 0];
81
- }
52
+ // TODO: 由于 Shader 目前无法根据是否开启拾取进行内容修改,因此即使不开启也需要生成 a_PickingColor
53
+ layer.hooks.init.tapPromise('PixelPickingPlugin', () => {
54
+ const {
55
+ enablePicking
56
+ } = layer.getLayerConfig();
57
+ styleAttributeService.registerStyleAttribute({
58
+ name: 'pickingColor',
59
+ type: AttributeType.Attribute,
60
+ descriptor: {
61
+ name: 'a_PickingColor',
62
+ shaderLocation: ShaderLocation.PICKING_COLOR,
63
+ buffer: {
64
+ data: [],
65
+ type: gl.FLOAT
66
+ },
67
+ size: 3,
68
+ // TODO: 固定 feature range 范围内的 pickingColor 都是固定的,可以生成 cache
69
+ update: feature => {
70
+ // 只有开启拾取才需要 encode
71
+ const {
72
+ id
73
+ } = feature;
74
+ return enablePicking ? encodePickingColor(id) : [0, 0, 0];
82
75
  }
83
- });
84
- });
85
- // 必须要与 PixelPickingPass 结合使用,因此必须开启 multiPassRenderer
86
- layer.hooks.beforePickingEncode.tap('PixelPickingPlugin', function () {
87
- var _layer$getLayerConfig2 = layer.getLayerConfig(),
88
- enablePicking = _layer$getLayerConfig2.enablePicking;
89
- if (enablePicking && layer.isVisible()) {
90
- _this2.updatePickOption({
91
- u_PickingStage: PickingStage.ENCODE
92
- }, layer);
93
- layer.models.forEach(function (model) {
94
- return model.addUniforms({
95
- u_PickingStage: PickingStage.ENCODE
96
- });
97
- });
98
76
  }
99
77
  });
100
- layer.hooks.afterPickingEncode.tap('PixelPickingPlugin', function () {
101
- var _layer$getLayerConfig3 = layer.getLayerConfig(),
102
- enablePicking = _layer$getLayerConfig3.enablePicking;
103
- // 区分选中高亮 和滑过高亮
104
- if (enablePicking && layer.isVisible()) {
105
- _this2.updatePickOption({
106
- u_PickingStage: PickingStage.HIGHLIGHT
107
- }, layer);
108
- layer.models.forEach(function (model) {
109
- return model.addUniforms({
110
- u_PickingStage: PickingStage.HIGHLIGHT
111
- });
112
- });
113
- }
114
- });
115
- layer.hooks.beforeHighlight.tap('PixelPickingPlugin', function (pickedColor) {
116
- var _layer$getLayerConfig4 = layer.getLayerConfig(),
117
- highlightColor = _layer$getLayerConfig4.highlightColor,
118
- _layer$getLayerConfig5 = _layer$getLayerConfig4.activeMix,
119
- activeMix = _layer$getLayerConfig5 === void 0 ? 0 : _layer$getLayerConfig5;
120
- var highlightColorInArray = typeof highlightColor === 'string' ? rgb2arr(highlightColor) : highlightColor || [1, 0, 0, 1];
121
- layer.updateLayerConfig({
122
- pickedFeatureID: decodePickingColor(new Uint8Array(pickedColor))
123
- });
124
- var option = {
125
- u_PickingStage: PickingStage.HIGHLIGHT,
126
- u_PickingColor: pickedColor,
127
- u_HighlightColor: highlightColorInArray.map(function (c) {
128
- return c * 255;
129
- }),
130
- u_activeMix: activeMix
131
- };
132
- _this2.updatePickOption(option, layer);
133
- layer.models.forEach(function (model) {
134
- return model.addUniforms(option);
135
- });
78
+ });
79
+ // 必须要与 PixelPickingPass 结合使用,因此必须开启 multiPassRenderer
80
+ layer.hooks.beforePickingEncode.tap('PixelPickingPlugin', () => {
81
+ const {
82
+ enablePicking
83
+ } = layer.getLayerConfig();
84
+ if (enablePicking && layer.isVisible()) {
85
+ this.updatePickOption({
86
+ u_PickingStage: PickingStage.ENCODE
87
+ }, layer);
88
+ layer.models.forEach(model => model.addUniforms({
89
+ u_PickingStage: PickingStage.ENCODE
90
+ }));
91
+ }
92
+ });
93
+ layer.hooks.afterPickingEncode.tap('PixelPickingPlugin', () => {
94
+ const {
95
+ enablePicking
96
+ } = layer.getLayerConfig();
97
+ // 区分选中高亮 和滑过高亮
98
+ if (enablePicking && layer.isVisible()) {
99
+ this.updatePickOption({
100
+ u_PickingStage: PickingStage.HIGHLIGHT
101
+ }, layer);
102
+ layer.models.forEach(model => model.addUniforms({
103
+ u_PickingStage: PickingStage.HIGHLIGHT
104
+ }));
105
+ }
106
+ });
107
+ layer.hooks.beforeHighlight.tap('PixelPickingPlugin', pickedColor => {
108
+ const {
109
+ highlightColor,
110
+ activeMix = 0
111
+ } = layer.getLayerConfig();
112
+ const highlightColorInArray = typeof highlightColor === 'string' ? rgb2arr(highlightColor) : highlightColor || [1, 0, 0, 1];
113
+ layer.updateLayerConfig({
114
+ pickedFeatureID: decodePickingColor(new Uint8Array(pickedColor))
136
115
  });
137
- layer.hooks.beforeSelect.tap('PixelPickingPlugin', function (pickedColor) {
138
- var _layer$getLayerConfig6 = layer.getLayerConfig(),
139
- selectColor = _layer$getLayerConfig6.selectColor,
140
- _layer$getLayerConfig7 = _layer$getLayerConfig6.selectMix,
141
- selectMix = _layer$getLayerConfig7 === void 0 ? 0 : _layer$getLayerConfig7;
142
- var highlightColorInArray = typeof selectColor === 'string' ? rgb2arr(selectColor) : selectColor || [1, 0, 0, 1];
143
- layer.updateLayerConfig({
144
- pickedFeatureID: decodePickingColor(new Uint8Array(pickedColor))
145
- });
146
- var option = {
147
- u_PickingStage: PickingStage.HIGHLIGHT,
148
- u_PickingColor: pickedColor,
149
- u_HighlightColor: highlightColorInArray.map(function (c) {
150
- return c * 255;
151
- }),
152
- u_activeMix: selectMix,
153
- u_CurrentSelectedId: pickedColor,
154
- u_SelectColor: highlightColorInArray.map(function (c) {
155
- return c * 255;
156
- })
157
- };
158
- _this2.updatePickOption(option, layer);
159
- layer.models.forEach(function (model) {
160
- return model.addUniforms(option);
161
- });
116
+ const option = {
117
+ u_PickingStage: PickingStage.HIGHLIGHT,
118
+ u_PickingColor: pickedColor,
119
+ u_HighlightColor: highlightColorInArray.map(c => c * 255),
120
+ u_activeMix: activeMix
121
+ };
122
+ this.updatePickOption(option, layer);
123
+ layer.models.forEach(model => model.addUniforms(option));
124
+ });
125
+ layer.hooks.beforeSelect.tap('PixelPickingPlugin', pickedColor => {
126
+ const {
127
+ selectColor,
128
+ selectMix = 0
129
+ } = layer.getLayerConfig();
130
+ const highlightColorInArray = typeof selectColor === 'string' ? rgb2arr(selectColor) : selectColor || [1, 0, 0, 1];
131
+ layer.updateLayerConfig({
132
+ pickedFeatureID: decodePickingColor(new Uint8Array(pickedColor))
162
133
  });
163
- }
164
- }]);
165
- return PixelPickingPlugin;
166
- }();
167
- export { PixelPickingPlugin as default };
134
+ const option = {
135
+ u_PickingStage: PickingStage.HIGHLIGHT,
136
+ u_PickingColor: pickedColor,
137
+ u_HighlightColor: highlightColorInArray.map(c => c * 255),
138
+ u_activeMix: selectMix,
139
+ u_CurrentSelectedId: pickedColor,
140
+ u_SelectColor: highlightColorInArray.map(c => c * 255)
141
+ };
142
+ this.updatePickOption(option, layer);
143
+ layer.models.forEach(model => model.addUniforms(option));
144
+ });
145
+ }
146
+ }
@@ -1,5 +1,3 @@
1
- import _classCallCheck from "@babel/runtime/helpers/esm/classCallCheck";
2
- import _createClass from "@babel/runtime/helpers/esm/createClass";
3
1
  import { AttributeType, gl } from '@antv/l7-core';
4
2
  import { ShaderLocation } from "../core/CommonStyleAttribute";
5
3
  import { isTileGroup } from "../tile/utils/utils";
@@ -7,104 +5,90 @@ import { isTileGroup } from "../tile/utils/utils";
7
5
  /**
8
6
  * 在初始化阶段完成属性的注册,以及首次根据 Layer 指定的三角化方法完成 indices 和 attribute 的创建
9
7
  */
10
- var RegisterStyleAttributePlugin = /*#__PURE__*/function () {
11
- function RegisterStyleAttributePlugin() {
12
- _classCallCheck(this, RegisterStyleAttributePlugin);
13
- }
14
- _createClass(RegisterStyleAttributePlugin, [{
15
- key: "apply",
16
- value: function apply(layer, _ref) {
17
- var _this = this;
18
- var styleAttributeService = _ref.styleAttributeService;
19
- layer.hooks.init.tapPromise('RegisterStyleAttributePlugin', function () {
20
- // 过滤 tileGroup layer (瓦片图层不需要注册)
21
- if (isTileGroup(layer)) {
22
- return;
23
- }
24
- _this.registerBuiltinAttributes(styleAttributeService, layer);
25
- });
26
- }
27
- }, {
28
- key: "registerBuiltinAttributes",
29
- value: function registerBuiltinAttributes(styleAttributeService, layer) {
30
- // MaskLayer 只需要注册 a_Position
31
- if (layer.type === 'MaskLayer') {
32
- this.registerPositionAttribute(styleAttributeService);
8
+ export default class RegisterStyleAttributePlugin {
9
+ apply(layer, {
10
+ styleAttributeService
11
+ }) {
12
+ layer.hooks.init.tapPromise('RegisterStyleAttributePlugin', () => {
13
+ // 过滤 tileGroup layer (瓦片图层不需要注册)
14
+ if (isTileGroup(layer)) {
33
15
  return;
34
16
  }
35
- // Tip: normal render layer
17
+ this.registerBuiltinAttributes(styleAttributeService, layer);
18
+ });
19
+ }
20
+ registerBuiltinAttributes(styleAttributeService, layer) {
21
+ // MaskLayer 只需要注册 a_Position
22
+ if (layer.type === 'MaskLayer') {
36
23
  this.registerPositionAttribute(styleAttributeService);
37
- // this.registerFilterAttribute(styleAttributeService);//数据层数据过滤
38
- this.registerColorAttribute(styleAttributeService);
39
- this.registerVertexIdAttribute(styleAttributeService);
24
+ return;
40
25
  }
41
- }, {
42
- key: "registerPositionAttribute",
43
- value: function registerPositionAttribute(styleAttributeService) {
44
- styleAttributeService.registerStyleAttribute({
45
- name: 'position',
46
- type: AttributeType.Attribute,
47
- descriptor: {
48
- name: 'a_Position',
49
- shaderLocation: ShaderLocation.POSITION,
50
- buffer: {
51
- data: [],
52
- type: gl.FLOAT
53
- },
54
- size: 3,
55
- update: function update(feature, featureIdx, vertex) {
56
- return vertex.length === 2 ? [vertex[0], vertex[1], 0] : [vertex[0], vertex[1], vertex[2]];
57
- }
26
+ // Tip: normal render layer
27
+ this.registerPositionAttribute(styleAttributeService);
28
+ // this.registerFilterAttribute(styleAttributeService);//数据层数据过滤
29
+ this.registerColorAttribute(styleAttributeService);
30
+ this.registerVertexIdAttribute(styleAttributeService);
31
+ }
32
+ registerPositionAttribute(styleAttributeService) {
33
+ styleAttributeService.registerStyleAttribute({
34
+ name: 'position',
35
+ type: AttributeType.Attribute,
36
+ descriptor: {
37
+ name: 'a_Position',
38
+ shaderLocation: ShaderLocation.POSITION,
39
+ buffer: {
40
+ data: [],
41
+ type: gl.FLOAT
42
+ },
43
+ size: 3,
44
+ update: (feature, featureIdx, vertex) => {
45
+ return vertex.length === 2 ? [vertex[0], vertex[1], 0] : [vertex[0], vertex[1], vertex[2]];
58
46
  }
59
- });
60
- }
61
- }, {
62
- key: "registerColorAttribute",
63
- value: function registerColorAttribute(styleAttributeService) {
64
- styleAttributeService.registerStyleAttribute({
65
- name: 'color',
66
- type: AttributeType.Attribute,
67
- descriptor: {
68
- name: 'a_Color',
69
- shaderLocation: ShaderLocation.COLOR,
70
- buffer: {
71
- // give the WebGL driver a hint that this buffer may change
72
- usage: gl.DYNAMIC_DRAW,
73
- data: [],
74
- type: gl.FLOAT
75
- },
76
- size: 4,
77
- update: function update(feature) {
78
- var color = feature.color;
79
- return !color || !color.length ? [1, 1, 1, 1] : color;
80
- }
47
+ }
48
+ });
49
+ }
50
+ registerColorAttribute(styleAttributeService) {
51
+ styleAttributeService.registerStyleAttribute({
52
+ name: 'color',
53
+ type: AttributeType.Attribute,
54
+ descriptor: {
55
+ name: 'a_Color',
56
+ shaderLocation: ShaderLocation.COLOR,
57
+ buffer: {
58
+ // give the WebGL driver a hint that this buffer may change
59
+ usage: gl.DYNAMIC_DRAW,
60
+ data: [],
61
+ type: gl.FLOAT
62
+ },
63
+ size: 4,
64
+ update: feature => {
65
+ const {
66
+ color
67
+ } = feature;
68
+ return !color || !color.length ? [1, 1, 1, 1] : color;
81
69
  }
82
- });
83
- }
84
- }, {
85
- key: "registerVertexIdAttribute",
86
- value: function registerVertexIdAttribute(styleAttributeService) {
87
- styleAttributeService.registerStyleAttribute({
88
- // 统一注册每个顶点的唯一编号(目前用于样式的数据映射计算使用)
89
- name: 'vertexId',
90
- type: AttributeType.Attribute,
91
- descriptor: {
92
- name: 'a_vertexId',
93
- shaderLocation: ShaderLocation.VERTEX_ID,
94
- buffer: {
95
- // give the WebGL driver a hint that this buffer may change
96
- usage: gl.DYNAMIC_DRAW,
97
- data: [],
98
- type: gl.FLOAT
99
- },
100
- size: 1,
101
- update: function update(feature, featureIdx) {
102
- return [featureIdx];
103
- }
70
+ }
71
+ });
72
+ }
73
+ registerVertexIdAttribute(styleAttributeService) {
74
+ styleAttributeService.registerStyleAttribute({
75
+ // 统一注册每个顶点的唯一编号(目前用于样式的数据映射计算使用)
76
+ name: 'vertexId',
77
+ type: AttributeType.Attribute,
78
+ descriptor: {
79
+ name: 'a_vertexId',
80
+ shaderLocation: ShaderLocation.VERTEX_ID,
81
+ buffer: {
82
+ // give the WebGL driver a hint that this buffer may change
83
+ usage: gl.DYNAMIC_DRAW,
84
+ data: [],
85
+ type: gl.FLOAT
86
+ },
87
+ size: 1,
88
+ update: (feature, featureIdx) => {
89
+ return [featureIdx];
104
90
  }
105
- });
106
- }
107
- }]);
108
- return RegisterStyleAttributePlugin;
109
- }();
110
- export { RegisterStyleAttributePlugin as default };
91
+ }
92
+ });
93
+ }
94
+ }