@antv/l7-layers 2.21.0 → 2.21.2

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 (397) 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 +2 -1
  7. package/es/core/BaseLayer.js +1113 -1405
  8. package/es/core/BaseModel.js +262 -318
  9. package/es/core/CommonStyleAttribute.js +25 -18
  10. package/es/core/LayerPickService.js +92 -142
  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 -13
  16. package/es/core/shape/arrow.js +50 -62
  17. package/es/core/shape/extrude.js +54 -63
  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 -202
  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 -122
  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 -242
  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 +232 -288
  47. package/es/line/models/simple_line.js +142 -192
  48. package/es/line/models/wall.js +221 -273
  49. package/es/line/shaders/line/line_vert.glsl +0 -2
  50. package/es/line/shaders/wall/wall_vert.glsl +15 -0
  51. package/es/mask/index.js +16 -53
  52. package/es/mask/models/fill.js +51 -108
  53. package/es/mask/models/index.js +1 -1
  54. package/es/plugins/DataMappingPlugin.js +205 -251
  55. package/es/plugins/DataSourcePlugin.js +64 -92
  56. package/es/plugins/FeatureScalePlugin.js +258 -302
  57. package/es/plugins/LayerAnimateStylePlugin.js +12 -22
  58. package/es/plugins/LayerMaskPlugin.js +15 -24
  59. package/es/plugins/LayerModelPlugin.js +52 -136
  60. package/es/plugins/LayerStylePlugin.js +14 -23
  61. package/es/plugins/LightingPlugin.js +26 -37
  62. package/es/plugins/MultiPassRendererPlugin.js +34 -39
  63. package/es/plugins/PixelPickingPlugin.js +129 -151
  64. package/es/plugins/RegisterStyleAttributePlugin.js +80 -96
  65. package/es/plugins/ShaderUniformPlugin.js +159 -131
  66. package/es/plugins/UpdateModelPlugin.js +16 -26
  67. package/es/plugins/UpdateStyleAttributePlugin.js +47 -65
  68. package/es/point/index.js +118 -182
  69. package/es/point/models/billboard_point.js +72 -127
  70. package/es/point/models/earthExtrude.js +170 -220
  71. package/es/point/models/earthFill.js +136 -192
  72. package/es/point/models/extrude.js +167 -217
  73. package/es/point/models/fill.js +153 -210
  74. package/es/point/models/fillImage.js +156 -211
  75. package/es/point/models/image.js +127 -180
  76. package/es/point/models/index.js +1 -1
  77. package/es/point/models/normal.js +67 -122
  78. package/es/point/models/radar.js +93 -148
  79. package/es/point/models/text.js +447 -578
  80. package/es/point/shape/extrude.js +19 -25
  81. package/es/polygon/index.js +61 -99
  82. package/es/polygon/models/extrude.js +208 -281
  83. package/es/polygon/models/extrusion.js +95 -142
  84. package/es/polygon/models/fill.js +103 -155
  85. package/es/polygon/models/index.js +1 -2
  86. package/es/polygon/models/ocean.js +139 -198
  87. package/es/polygon/models/water.js +120 -179
  88. package/es/raster/buffers/triangulation.js +13 -11
  89. package/es/raster/index.js +47 -88
  90. package/es/raster/models/index.js +1 -1
  91. package/es/raster/models/raster.js +134 -202
  92. package/es/raster/models/rasterRgb.js +134 -208
  93. package/es/raster/models/rasterTerrainRgb.js +98 -153
  94. package/es/tile/core/BaseLayer.d.ts +1 -0
  95. package/es/tile/core/BaseLayer.js +206 -282
  96. package/es/tile/core/TileDebugLayer.js +12 -46
  97. package/es/tile/interaction/getRasterData.js +24 -31
  98. package/es/tile/interaction/utils.js +15 -33
  99. package/es/tile/service/TileLayerService.js +104 -177
  100. package/es/tile/service/TilePickService.js +99 -156
  101. package/es/tile/service/TileSourceService.js +17 -26
  102. package/es/tile/tile/DebugTile.js +41 -78
  103. package/es/tile/tile/ImageTile.js +33 -66
  104. package/es/tile/tile/MaskTile.js +47 -81
  105. package/es/tile/tile/RasterRGBTile.js +40 -71
  106. package/es/tile/tile/RasterTerrainRGBTile.js +33 -66
  107. package/es/tile/tile/RasterTile.js +69 -104
  108. package/es/tile/tile/Tile.d.ts +1 -1
  109. package/es/tile/tile/Tile.js +151 -232
  110. package/es/tile/tile/VectorTile.js +77 -124
  111. package/es/tile/tile/index.js +4 -2
  112. package/es/tile/utils/constants.js +1 -1
  113. package/es/tile/utils/utils.js +2 -2
  114. package/es/utils/blend.js +52 -47
  115. package/es/utils/collision-index.js +62 -70
  116. package/es/utils/extrude_polyline.js +441 -471
  117. package/es/utils/grid-index.js +97 -123
  118. package/es/utils/identityScale.js +5 -5
  119. package/es/utils/load-image.js +15 -39
  120. package/es/utils/multiPassRender.js +7 -9
  121. package/es/utils/polylineNormal.js +40 -43
  122. package/es/utils/rampcolor_legend.js +5 -4
  123. package/es/utils/simpleLine.js +53 -66
  124. package/es/utils/symbol-layout.js +95 -117
  125. package/es/wind/index.js +28 -71
  126. package/es/wind/models/index.js +1 -1
  127. package/es/wind/models/utils.js +36 -34
  128. package/es/wind/models/wind.js +203 -260
  129. package/es/wind/models/windRender.js +258 -269
  130. package/es/wind/models/windShader.js +145 -6
  131. package/lib/canvas/index.d.ts +18 -0
  132. package/lib/canvas/index.js +64 -113
  133. package/lib/canvas/models/canvas.d.ts +23 -0
  134. package/lib/canvas/models/canvas.js +97 -136
  135. package/lib/canvas/models/constants.d.ts +2 -0
  136. package/lib/canvas/models/constants.js +1 -1
  137. package/lib/canvas/models/index.d.ts +2 -0
  138. package/lib/canvas/models/index.js +2 -2
  139. package/lib/citybuliding/building.d.ts +7 -0
  140. package/lib/citybuliding/building.js +22 -58
  141. package/lib/citybuliding/models/build.d.ts +17 -0
  142. package/lib/citybuliding/models/build.js +144 -199
  143. package/lib/core/BaseLayer.d.ts +247 -0
  144. package/lib/core/BaseLayer.js +1115 -1405
  145. package/lib/core/BaseModel.d.ts +82 -0
  146. package/lib/core/BaseModel.js +262 -316
  147. package/lib/core/CommonStyleAttribute.d.ts +20 -0
  148. package/lib/core/CommonStyleAttribute.js +25 -18
  149. package/lib/core/LayerPickService.d.ts +12 -0
  150. package/lib/core/LayerPickService.js +93 -141
  151. package/lib/core/TextureService.d.ts +15 -0
  152. package/lib/core/TextureService.js +59 -68
  153. package/lib/core/constant.d.ts +6 -0
  154. package/lib/core/constant.js +2 -2
  155. package/lib/core/interface.d.ts +282 -0
  156. package/lib/core/interface.js +5 -5
  157. package/lib/core/line_trangluation.d.ts +19 -0
  158. package/lib/core/line_trangluation.js +38 -43
  159. package/lib/core/schema.d.ts +27 -0
  160. package/lib/core/shape/Path.d.ts +39 -0
  161. package/lib/core/shape/Path.js +21 -14
  162. package/lib/core/shape/arrow.d.ts +25 -0
  163. package/lib/core/shape/arrow.js +50 -62
  164. package/lib/core/shape/extrude.d.ts +17 -0
  165. package/lib/core/shape/extrude.js +54 -63
  166. package/lib/core/triangulation.d.ts +136 -0
  167. package/lib/core/triangulation.js +194 -174
  168. package/lib/core/utils.d.ts +4 -0
  169. package/lib/core/utils.js +5 -5
  170. package/lib/earth/index.d.ts +22 -0
  171. package/lib/earth/index.js +37 -73
  172. package/lib/earth/models/atmosphere.d.ts +15 -0
  173. package/lib/earth/models/atmosphere.js +100 -148
  174. package/lib/earth/models/base.d.ts +22 -0
  175. package/lib/earth/models/base.js +150 -202
  176. package/lib/earth/models/bloomsphere.d.ts +15 -0
  177. package/lib/earth/models/bloomsphere.js +99 -147
  178. package/lib/earth/utils.d.ts +26 -0
  179. package/lib/earth/utils.js +37 -39
  180. package/lib/geometry/index.d.ts +22 -0
  181. package/lib/geometry/index.js +38 -75
  182. package/lib/geometry/models/billboard.d.ts +24 -0
  183. package/lib/geometry/models/billboard.js +149 -204
  184. package/lib/geometry/models/index.d.ts +5 -0
  185. package/lib/geometry/models/index.js +1 -1
  186. package/lib/geometry/models/plane.d.ts +43 -0
  187. package/lib/geometry/models/plane.js +280 -357
  188. package/lib/geometry/models/sprite.d.ts +48 -0
  189. package/lib/geometry/models/sprite.js +184 -240
  190. package/lib/heatmap/index.d.ts +13 -0
  191. package/lib/heatmap/index.js +74 -122
  192. package/lib/heatmap/models/grid.d.ts +15 -0
  193. package/lib/heatmap/models/grid.js +68 -118
  194. package/lib/heatmap/models/grid3d.d.ts +15 -0
  195. package/lib/heatmap/models/grid3d.js +103 -151
  196. package/lib/heatmap/models/heatmap.d.ts +27 -0
  197. package/lib/heatmap/models/heatmap.js +400 -455
  198. package/lib/heatmap/models/hexagon.d.ts +15 -0
  199. package/lib/heatmap/models/hexagon.js +69 -119
  200. package/lib/heatmap/models/index.d.ts +5 -0
  201. package/lib/heatmap/models/index.js +1 -1
  202. package/lib/heatmap/triangulation.d.ts +5 -0
  203. package/lib/heatmap/triangulation.js +20 -20
  204. package/lib/image/index.d.ts +9 -0
  205. package/lib/image/index.js +25 -62
  206. package/lib/image/models/image.d.ts +17 -0
  207. package/lib/image/models/image.js +101 -163
  208. package/lib/image/models/index.d.ts +5 -0
  209. package/lib/image/models/index.js +1 -1
  210. package/lib/index.d.ts +18 -0
  211. package/lib/index.js +17 -17
  212. package/lib/line/index.d.ts +36 -0
  213. package/lib/line/index.js +67 -106
  214. package/lib/line/models/arc.d.ts +22 -0
  215. package/lib/line/models/arc.js +202 -248
  216. package/lib/line/models/arc_3d.d.ts +22 -0
  217. package/lib/line/models/arc_3d.js +193 -242
  218. package/lib/line/models/flow.d.ts +14 -0
  219. package/lib/line/models/flow.js +103 -153
  220. package/lib/line/models/great_circle.d.ts +17 -0
  221. package/lib/line/models/great_circle.js +185 -234
  222. package/lib/line/models/index.d.ts +5 -0
  223. package/lib/line/models/index.js +1 -1
  224. package/lib/line/models/line.d.ts +27 -0
  225. package/lib/line/models/line.js +233 -285
  226. package/lib/line/models/simple_line.d.ts +19 -0
  227. package/lib/line/models/simple_line.js +144 -192
  228. package/lib/line/models/wall.d.ts +17 -0
  229. package/lib/line/models/wall.js +223 -273
  230. package/lib/line/shaders/line/line_vert.glsl +0 -2
  231. package/lib/line/shaders/wall/wall_vert.glsl +15 -0
  232. package/lib/mask/index.d.ts +16 -0
  233. package/lib/mask/index.js +18 -53
  234. package/lib/mask/models/fill.d.ts +18 -0
  235. package/lib/mask/models/fill.js +53 -108
  236. package/lib/mask/models/index.d.ts +5 -0
  237. package/lib/mask/models/index.js +1 -1
  238. package/lib/plugins/DataMappingPlugin.d.ts +13 -0
  239. package/lib/plugins/DataMappingPlugin.js +206 -250
  240. package/lib/plugins/DataSourcePlugin.d.ts +6 -0
  241. package/lib/plugins/DataSourcePlugin.js +65 -91
  242. package/lib/plugins/FeatureScalePlugin.d.ts +20 -0
  243. package/lib/plugins/FeatureScalePlugin.js +261 -304
  244. package/lib/plugins/LayerAnimateStylePlugin.d.ts +4 -0
  245. package/lib/plugins/LayerAnimateStylePlugin.js +13 -21
  246. package/lib/plugins/LayerMaskPlugin.d.ts +7 -0
  247. package/lib/plugins/LayerMaskPlugin.js +16 -24
  248. package/lib/plugins/LayerModelPlugin.d.ts +10 -0
  249. package/lib/plugins/LayerModelPlugin.js +53 -135
  250. package/lib/plugins/LayerStylePlugin.d.ts +7 -0
  251. package/lib/plugins/LayerStylePlugin.js +15 -23
  252. package/lib/plugins/LightingPlugin.d.ts +35 -0
  253. package/lib/plugins/LightingPlugin.js +27 -36
  254. package/lib/plugins/MultiPassRendererPlugin.d.ts +22 -0
  255. package/lib/plugins/MultiPassRendererPlugin.js +35 -38
  256. package/lib/plugins/PixelPickingPlugin.d.ts +11 -0
  257. package/lib/plugins/PixelPickingPlugin.js +130 -150
  258. package/lib/plugins/RegisterStyleAttributePlugin.d.ts +11 -0
  259. package/lib/plugins/RegisterStyleAttributePlugin.js +81 -96
  260. package/lib/plugins/ShaderUniformPlugin.d.ts +22 -0
  261. package/lib/plugins/ShaderUniformPlugin.js +160 -130
  262. package/lib/plugins/UpdateModelPlugin.d.ts +7 -0
  263. package/lib/plugins/UpdateModelPlugin.js +17 -26
  264. package/lib/plugins/UpdateStyleAttributePlugin.d.ts +9 -0
  265. package/lib/plugins/UpdateStyleAttributePlugin.js +48 -65
  266. package/lib/plugins/index.d.ts +15 -0
  267. package/lib/point/index.d.ts +33 -0
  268. package/lib/point/index.js +120 -182
  269. package/lib/point/models/billboard_point.d.ts +21 -0
  270. package/lib/point/models/billboard_point.js +74 -127
  271. package/lib/point/models/earthExtrude.d.ts +16 -0
  272. package/lib/point/models/earthExtrude.js +172 -220
  273. package/lib/point/models/earthFill.d.ts +15 -0
  274. package/lib/point/models/earthFill.js +138 -192
  275. package/lib/point/models/extrude.d.ts +16 -0
  276. package/lib/point/models/extrude.js +169 -217
  277. package/lib/point/models/fill.d.ts +31 -0
  278. package/lib/point/models/fill.js +155 -210
  279. package/lib/point/models/fillImage.d.ts +26 -0
  280. package/lib/point/models/fillImage.js +159 -211
  281. package/lib/point/models/image.d.ts +18 -0
  282. package/lib/point/models/image.js +129 -180
  283. package/lib/point/models/index.d.ts +5 -0
  284. package/lib/point/models/index.js +1 -1
  285. package/lib/point/models/normal.d.ts +22 -0
  286. package/lib/point/models/normal.js +69 -122
  287. package/lib/point/models/radar.d.ts +22 -0
  288. package/lib/point/models/radar.js +95 -148
  289. package/lib/point/models/text.d.ts +69 -0
  290. package/lib/point/models/text.js +449 -578
  291. package/lib/point/shape/extrude.d.ts +15 -0
  292. package/lib/point/shape/extrude.js +19 -25
  293. package/lib/polygon/index.d.ts +18 -0
  294. package/lib/polygon/index.js +63 -99
  295. package/lib/polygon/models/extrude.d.ts +25 -0
  296. package/lib/polygon/models/extrude.js +210 -281
  297. package/lib/polygon/models/extrusion.d.ts +24 -0
  298. package/lib/polygon/models/extrusion.js +97 -142
  299. package/lib/polygon/models/fill.d.ts +18 -0
  300. package/lib/polygon/models/fill.js +104 -154
  301. package/lib/polygon/models/index.d.ts +5 -0
  302. package/lib/polygon/models/index.js +1 -1
  303. package/lib/polygon/models/ocean.d.ts +23 -0
  304. package/lib/polygon/models/ocean.js +141 -198
  305. package/lib/polygon/models/water.d.ts +21 -0
  306. package/lib/polygon/models/water.js +122 -179
  307. package/lib/raster/buffers/triangulation.d.ts +6 -0
  308. package/lib/raster/buffers/triangulation.js +13 -11
  309. package/lib/raster/index.d.ts +11 -0
  310. package/lib/raster/index.js +49 -88
  311. package/lib/raster/models/index.d.ts +5 -0
  312. package/lib/raster/models/index.js +1 -1
  313. package/lib/raster/models/raster.d.ts +21 -0
  314. package/lib/raster/models/raster.js +136 -202
  315. package/lib/raster/models/rasterRgb.d.ts +21 -0
  316. package/lib/raster/models/rasterRgb.js +136 -208
  317. package/lib/raster/models/rasterTerrainRgb.d.ts +16 -0
  318. package/lib/raster/models/rasterTerrainRgb.js +100 -153
  319. package/lib/tile/core/BaseLayer.d.ts +48 -0
  320. package/lib/tile/core/BaseLayer.js +207 -281
  321. package/lib/tile/core/TileDebugLayer.d.ts +15 -0
  322. package/lib/tile/core/TileDebugLayer.js +14 -46
  323. package/lib/tile/interaction/getFeatureData.d.ts +0 -0
  324. package/lib/tile/interaction/getRasterData.d.ts +4 -0
  325. package/lib/tile/interaction/getRasterData.js +24 -32
  326. package/lib/tile/interaction/utils.d.ts +11 -0
  327. package/lib/tile/interaction/utils.js +15 -34
  328. package/lib/tile/interface.d.ts +29 -0
  329. package/lib/tile/service/TileLayerService.d.ts +33 -0
  330. package/lib/tile/service/TileLayerService.js +105 -177
  331. package/lib/tile/service/TilePickService.d.ts +26 -0
  332. package/lib/tile/service/TilePickService.js +100 -156
  333. package/lib/tile/service/TileSourceService.d.ts +7 -0
  334. package/lib/tile/service/TileSourceService.js +20 -29
  335. package/lib/tile/tile/DebugTile.d.ts +16 -0
  336. package/lib/tile/tile/DebugTile.js +43 -78
  337. package/lib/tile/tile/ImageTile.d.ts +14 -0
  338. package/lib/tile/tile/ImageTile.js +35 -66
  339. package/lib/tile/tile/MaskTile.d.ts +18 -0
  340. package/lib/tile/tile/MaskTile.js +49 -81
  341. package/lib/tile/tile/RasterRGBTile.d.ts +11 -0
  342. package/lib/tile/tile/RasterRGBTile.js +42 -71
  343. package/lib/tile/tile/RasterTerrainRGBTile.d.ts +14 -0
  344. package/lib/tile/tile/RasterTerrainRGBTile.js +35 -66
  345. package/lib/tile/tile/RasterTile.d.ts +18 -0
  346. package/lib/tile/tile/RasterTile.js +71 -104
  347. package/lib/tile/tile/Tile.d.ts +114 -0
  348. package/lib/tile/tile/Tile.js +152 -231
  349. package/lib/tile/tile/VectorTile.d.ts +26 -0
  350. package/lib/tile/tile/VectorTile.js +79 -124
  351. package/lib/tile/tile/index.d.ts +12 -0
  352. package/lib/tile/tile/index.js +6 -4
  353. package/lib/tile/tile/util.d.ts +5 -0
  354. package/lib/tile/utils/constants.d.ts +1 -0
  355. package/lib/tile/utils/constants.js +1 -1
  356. package/lib/tile/utils/utils.d.ts +8 -0
  357. package/lib/tile/utils/utils.js +2 -2
  358. package/lib/utils/blend.d.ts +2 -0
  359. package/lib/utils/blend.js +52 -48
  360. package/lib/utils/collision-index.d.ts +47 -0
  361. package/lib/utils/collision-index.js +64 -69
  362. package/lib/utils/extrude_polyline.d.ts +68 -0
  363. package/lib/utils/extrude_polyline.js +442 -470
  364. package/lib/utils/grid-index.d.ts +28 -0
  365. package/lib/utils/grid-index.js +97 -123
  366. package/lib/utils/identityScale.d.ts +8 -0
  367. package/lib/utils/identityScale.js +5 -5
  368. package/lib/utils/load-image.d.ts +1 -0
  369. package/lib/utils/load-image.js +15 -39
  370. package/lib/utils/multiPassRender.d.ts +16 -0
  371. package/lib/utils/multiPassRender.js +7 -10
  372. package/lib/utils/polylineNormal.d.ts +9 -0
  373. package/lib/utils/polylineNormal.js +40 -44
  374. package/lib/utils/rampcolor_legend.d.ts +6 -0
  375. package/lib/utils/rampcolor_legend.js +5 -5
  376. package/lib/utils/simpleLine.d.ts +23 -0
  377. package/lib/utils/simpleLine.js +54 -65
  378. package/lib/utils/stencil.d.ts +7 -0
  379. package/lib/utils/symbol-layout.d.ts +43 -0
  380. package/lib/utils/symbol-layout.js +95 -117
  381. package/lib/wind/index.d.ts +11 -0
  382. package/lib/wind/index.js +30 -71
  383. package/lib/wind/models/index.d.ts +5 -0
  384. package/lib/wind/models/index.js +1 -1
  385. package/lib/wind/models/utils.d.ts +19 -0
  386. package/lib/wind/models/utils.js +36 -34
  387. package/lib/wind/models/wind.d.ts +24 -0
  388. package/lib/wind/models/wind.js +205 -260
  389. package/lib/wind/models/windRender.d.ts +104 -0
  390. package/lib/wind/models/windRender.js +261 -272
  391. package/lib/wind/models/windShader.d.ts +12 -0
  392. package/lib/wind/models/windShader.js +145 -6
  393. package/package.json +16 -19
  394. package/CHANGELOG.md +0 -492
  395. package/LICENSE.md +0 -21
  396. package/es/glsl.d.ts +0 -5
  397. package/lib/glsl.d.ts +0 -5
@@ -5,27 +5,18 @@ Object.defineProperty(exports, "__esModule", {
5
5
  value: true
6
6
  });
7
7
  exports.default = void 0;
8
- var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
9
8
  var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
10
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
12
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
13
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
14
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
15
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
16
9
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
17
10
  var _l7Core = require("@antv/l7-core");
18
11
  var _l7Utils = require("@antv/l7-utils");
19
- var _BaseModel2 = _interopRequireDefault(require("../../core/BaseModel"));
12
+ var _BaseModel = _interopRequireDefault(require("../../core/BaseModel"));
20
13
  var _triangulation = require("../../core/triangulation");
21
14
  var _windRender = require("./windRender");
22
- function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2.default)(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2.default)(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2.default)(this, result); }; }
23
- function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
24
15
  /* babel-plugin-inline-import '../shaders/wind_frag.glsl' */
25
- var WindFrag = "precision mediump float;\nuniform float u_opacity: 1.0;\nuniform sampler2D u_texture;\nvarying vec2 v_texCoord;\nvoid main() {\n vec4 color = texture2D(u_texture,vec2(v_texCoord.x,v_texCoord.y));\n gl_FragColor = color;\n gl_FragColor.a *= u_opacity;\n}\n";
16
+ const WindFrag = "precision mediump float;\nuniform float u_opacity: 1.0;\nuniform sampler2D u_texture;\nvarying vec2 v_texCoord;\nvoid main() {\n vec4 color = texture2D(u_texture,vec2(v_texCoord.x,v_texCoord.y));\n gl_FragColor = color;\n gl_FragColor.a *= u_opacity;\n}\n";
26
17
  /* babel-plugin-inline-import '../shaders/wind_vert.glsl' */
27
- var WindVert = "precision highp float;\nuniform mat4 u_ModelMatrix;\n\nattribute vec3 a_Position;\nattribute vec2 a_Uv;\nvarying vec2 v_texCoord;\n#pragma include \"projection\"\nvoid main() {\n v_texCoord = a_Uv;\n vec4 project_pos = project_position(vec4(a_Position, 1.0));\n\n gl_Position = project_common_position_to_clipspace_v2(vec4(project_pos.xy,0., 1.0));\n}\n";
28
- var defaultRampColors = {
18
+ const WindVert = "precision highp float;\nuniform mat4 u_ModelMatrix;\n\nattribute vec3 a_Position;\nattribute vec2 a_Uv;\nvarying vec2 v_texCoord;\n#pragma include \"projection\"\nvoid main() {\n v_texCoord = a_Uv;\n vec4 project_pos = project_position(vec4(a_Position, 1.0));\n\n gl_Position = project_common_position_to_clipspace_v2(vec4(project_pos.xy,0., 1.0));\n}\n";
19
+ const defaultRampColors = {
29
20
  0.0: '#3288bd',
30
21
  0.1: '#66c2a5',
31
22
  0.2: '#abdda4',
@@ -35,261 +26,215 @@ var defaultRampColors = {
35
26
  0.6: '#f46d43',
36
27
  1.0: '#d53e4f'
37
28
  };
38
- var WindModel = exports.default = /*#__PURE__*/function (_BaseModel) {
39
- (0, _inherits2.default)(WindModel, _BaseModel);
40
- var _super = _createSuper(WindModel);
41
- function WindModel() {
42
- var _this;
43
- (0, _classCallCheck2.default)(this, WindModel);
44
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
45
- args[_key] = arguments[_key];
46
- }
47
- _this = _super.call.apply(_super, [this].concat(args));
48
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "sizeScale", 0.5);
29
+ class WindModel extends _BaseModel.default {
30
+ constructor(...args) {
31
+ super(...args);
32
+ (0, _defineProperty2.default)(this, "texture", void 0);
33
+ (0, _defineProperty2.default)(this, "colorModel", void 0);
34
+ (0, _defineProperty2.default)(this, "wind", void 0);
35
+ (0, _defineProperty2.default)(this, "imageCoords", void 0);
36
+ (0, _defineProperty2.default)(this, "sizeScale", 0.5);
49
37
  // https://mapbox.github.io/webgl-wind/demo/
50
38
  // source: 'http://nomads.ncep.noaa.gov',
51
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "frequency", new _l7Utils.FrequencyController(7.2));
52
- return _this;
39
+ (0, _defineProperty2.default)(this, "frequency", new _l7Utils.FrequencyController(7.2));
40
+ (0, _defineProperty2.default)(this, "cacheZoom", void 0);
41
+ }
42
+ render(options) {
43
+ this.drawColorMode(options);
44
+ // Tip: 控制风场的平均更新频率
45
+ this.frequency.run(() => {
46
+ this.drawWind();
47
+ });
53
48
  }
54
- (0, _createClass2.default)(WindModel, [{
55
- key: "render",
56
- value: function render(options) {
57
- var _this2 = this;
58
- this.drawColorMode(options);
59
- // Tip: 控制风场的平均更新频率
60
- this.frequency.run(function () {
61
- _this2.drawWind();
49
+ getUninforms() {
50
+ throw new Error('Method not implemented.');
51
+ }
52
+ initModels() {
53
+ var _this = this;
54
+ return (0, _asyncToGenerator2.default)(function* () {
55
+ var _source$data, _source$data2;
56
+ const {
57
+ uMin = -21.32,
58
+ uMax = 26.8,
59
+ vMin = -21.57,
60
+ vMax = 21.42,
61
+ fadeOpacity = 0.996,
62
+ speedFactor = 0.25,
63
+ dropRate = 0.003,
64
+ dropRateBump = 0.01,
65
+ rampColors = defaultRampColors,
66
+ sizeScale = 0.5
67
+ // mask
68
+ } = _this.layer.getLayerConfig();
69
+ const {
70
+ createTexture2D
71
+ } = _this.rendererService;
72
+ const source = _this.layer.getSource();
73
+ _this.texture = createTexture2D({
74
+ height: 0,
75
+ width: 0
62
76
  });
63
- }
64
- }, {
65
- key: "getUninforms",
66
- value: function getUninforms() {
67
- throw new Error('Method not implemented.');
68
- }
69
- }, {
70
- key: "initModels",
71
- value: function () {
72
- var _initModels = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
73
- var _source$data,
74
- _source$data2,
75
- _this3 = this;
76
- var _ref, _ref$uMin, uMin, _ref$uMax, uMax, _ref$vMin, vMin, _ref$vMax, vMax, _ref$fadeOpacity, fadeOpacity, _ref$speedFactor, speedFactor, _ref$dropRate, dropRate, _ref$dropRateBump, dropRateBump, _ref$rampColors, rampColors, _ref$sizeScale, sizeScale, createTexture2D, source, glContext, model;
77
- return _regenerator.default.wrap(function _callee$(_context) {
78
- while (1) switch (_context.prev = _context.next) {
79
- case 0:
80
- _ref = this.layer.getLayerConfig(), _ref$uMin = _ref.uMin, uMin = _ref$uMin === void 0 ? -21.32 : _ref$uMin, _ref$uMax = _ref.uMax, uMax = _ref$uMax === void 0 ? 26.8 : _ref$uMax, _ref$vMin = _ref.vMin, vMin = _ref$vMin === void 0 ? -21.57 : _ref$vMin, _ref$vMax = _ref.vMax, vMax = _ref$vMax === void 0 ? 21.42 : _ref$vMax, _ref$fadeOpacity = _ref.fadeOpacity, fadeOpacity = _ref$fadeOpacity === void 0 ? 0.996 : _ref$fadeOpacity, _ref$speedFactor = _ref.speedFactor, speedFactor = _ref$speedFactor === void 0 ? 0.25 : _ref$speedFactor, _ref$dropRate = _ref.dropRate, dropRate = _ref$dropRate === void 0 ? 0.003 : _ref$dropRate, _ref$dropRateBump = _ref.dropRateBump, dropRateBump = _ref$dropRateBump === void 0 ? 0.01 : _ref$dropRateBump, _ref$rampColors = _ref.rampColors, rampColors = _ref$rampColors === void 0 ? defaultRampColors : _ref$rampColors, _ref$sizeScale = _ref.sizeScale, sizeScale = _ref$sizeScale === void 0 ? 0.5 : _ref$sizeScale;
81
- createTexture2D = this.rendererService.createTexture2D;
82
- source = this.layer.getSource();
83
- this.texture = createTexture2D({
84
- height: 0,
85
- width: 0
86
- });
87
- this.cacheZoom = Math.floor(this.mapService.getZoom());
88
- glContext = this.rendererService.getGLContext();
89
- this.imageCoords = (_source$data = source.data) === null || _source$data === void 0 ? void 0 : _source$data.dataArray[0].coordinates;
90
- (_source$data2 = source.data) === null || _source$data2 === void 0 || (_source$data2 = _source$data2.images) === null || _source$data2 === void 0 || _source$data2.then(function (imageData) {
91
- var _this3$texture;
92
- _this3.sizeScale = sizeScale * _this3.getZoomScale();
93
- var _this3$getWindSize = _this3.getWindSize(),
94
- imageWidth = _this3$getWindSize.imageWidth,
95
- imageHeight = _this3$getWindSize.imageHeight;
96
- var options = {
97
- glContext: glContext,
98
- imageWidth: imageWidth,
99
- imageHeight: imageHeight,
100
- fadeOpacity: fadeOpacity,
101
- speedFactor: speedFactor,
102
- dropRate: dropRate,
103
- dropRateBump: dropRateBump,
104
- rampColors: rampColors
105
- };
106
- _this3.wind = new _windRender.Wind(options);
77
+ _this.cacheZoom = Math.floor(_this.mapService.getZoom());
78
+ const glContext = _this.rendererService.getGLContext();
79
+ _this.imageCoords = (_source$data = source.data) === null || _source$data === void 0 ? void 0 : _source$data.dataArray[0].coordinates;
80
+ (_source$data2 = source.data) === null || _source$data2 === void 0 || (_source$data2 = _source$data2.images) === null || _source$data2 === void 0 || _source$data2.then(imageData => {
81
+ var _this$texture;
82
+ _this.sizeScale = sizeScale * _this.getZoomScale();
83
+ const {
84
+ imageWidth,
85
+ imageHeight
86
+ } = _this.getWindSize();
87
+ const options = {
88
+ glContext,
89
+ imageWidth,
90
+ imageHeight,
91
+ fadeOpacity,
92
+ speedFactor,
93
+ dropRate,
94
+ dropRateBump,
95
+ rampColors
96
+ };
97
+ _this.wind = new _windRender.Wind(options);
107
98
 
108
- // imageData[0] 风场图
109
- _this3.wind.setWind({
110
- uMin: uMin,
111
- uMax: uMax,
112
- vMin: vMin,
113
- vMax: vMax,
114
- image: imageData[0]
115
- });
116
- (_this3$texture = _this3.texture) === null || _this3$texture === void 0 || _this3$texture.destroy();
117
- _this3.texture = createTexture2D({
118
- width: imageWidth,
119
- height: imageHeight
120
- });
121
- _this3.layerService.reRender();
122
- });
123
- _context.next = 10;
124
- return this.layer.buildLayerModel({
125
- moduleName: 'wind',
126
- vertexShader: WindVert,
127
- fragmentShader: WindFrag,
128
- triangulation: _triangulation.RasterImageTriangulation,
129
- primitive: _l7Core.gl.TRIANGLES,
130
- depth: {
131
- enable: false
132
- }
133
- });
134
- case 10:
135
- model = _context.sent;
136
- this.colorModel = model;
137
- return _context.abrupt("return", [model]);
138
- case 13:
139
- case "end":
140
- return _context.stop();
141
- }
142
- }, _callee, this);
143
- }));
144
- function initModels() {
145
- return _initModels.apply(this, arguments);
146
- }
147
- return initModels;
148
- }()
149
- }, {
150
- key: "getWindSize",
151
- value: function getWindSize() {
152
- var p1 = this.mapService.lngLatToPixel(this.imageCoords[0]);
153
- var p2 = this.mapService.lngLatToPixel(this.imageCoords[1]);
154
- var imageWidth = Math.min(Math.floor((p2.x - p1.x) * this.sizeScale), 2048);
155
- var imageHeight = Math.min(Math.floor((p1.y - p2.y) * this.sizeScale), 2048);
156
- return {
157
- imageWidth: imageWidth,
158
- imageHeight: imageHeight
159
- };
160
- }
161
- }, {
162
- key: "buildModels",
163
- value: function () {
164
- var _buildModels = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
165
- return _regenerator.default.wrap(function _callee2$(_context2) {
166
- while (1) switch (_context2.prev = _context2.next) {
167
- case 0:
168
- return _context2.abrupt("return", this.initModels());
169
- case 1:
170
- case "end":
171
- return _context2.stop();
172
- }
173
- }, _callee2, this);
174
- }));
175
- function buildModels() {
176
- return _buildModels.apply(this, arguments);
177
- }
178
- return buildModels;
179
- }()
180
- }, {
181
- key: "clearModels",
182
- value: function clearModels() {
183
- var _this$texture, _this$wind;
184
- (_this$texture = this.texture) === null || _this$texture === void 0 || _this$texture.destroy();
185
- (_this$wind = this.wind) === null || _this$wind === void 0 || _this$wind.destroy();
186
- }
187
- }, {
188
- key: "registerBuiltinAttributes",
189
- value: function registerBuiltinAttributes() {
190
- // point layer size;
191
- this.styleAttributeService.registerStyleAttribute({
192
- name: 'uv',
193
- type: _l7Core.AttributeType.Attribute,
194
- descriptor: {
195
- name: 'a_Uv',
196
- buffer: {
197
- // give the WebGL driver a hint that this buffer may change
198
- usage: _l7Core.gl.DYNAMIC_DRAW,
199
- data: [],
200
- type: _l7Core.gl.FLOAT
201
- },
202
- size: 2,
203
- update: function update(feature, featureIdx, vertex) {
204
- return [vertex[3], vertex[4]];
205
- }
99
+ // imageData[0] 风场图
100
+ _this.wind.setWind({
101
+ uMin,
102
+ uMax,
103
+ vMin,
104
+ vMax,
105
+ image: imageData[0]
106
+ });
107
+ (_this$texture = _this.texture) === null || _this$texture === void 0 || _this$texture.destroy();
108
+ _this.texture = createTexture2D({
109
+ width: imageWidth,
110
+ height: imageHeight
111
+ });
112
+ _this.layerService.reRender();
113
+ });
114
+ const model = yield _this.layer.buildLayerModel({
115
+ moduleName: 'wind',
116
+ vertexShader: WindVert,
117
+ fragmentShader: WindFrag,
118
+ triangulation: _triangulation.RasterImageTriangulation,
119
+ primitive: _l7Core.gl.TRIANGLES,
120
+ depth: {
121
+ enable: false
206
122
  }
207
123
  });
208
- }
209
- }, {
210
- key: "getZoomScale",
211
- value: function getZoomScale() {
212
- return Math.min((this.cacheZoom + 4) / 30 * 2, 2);
213
- }
214
- }, {
215
- key: "drawWind",
216
- value: function drawWind() {
217
- if (this.wind) {
218
- var _ref2 = this.layer.getLayerConfig(),
219
- _ref2$uMin = _ref2.uMin,
220
- uMin = _ref2$uMin === void 0 ? -21.32 : _ref2$uMin,
221
- _ref2$uMax = _ref2.uMax,
222
- uMax = _ref2$uMax === void 0 ? 26.8 : _ref2$uMax,
223
- _ref2$vMin = _ref2.vMin,
224
- vMin = _ref2$vMin === void 0 ? -21.57 : _ref2$vMin,
225
- _ref2$vMax = _ref2.vMax,
226
- vMax = _ref2$vMax === void 0 ? 21.42 : _ref2$vMax,
227
- _ref2$numParticles = _ref2.numParticles,
228
- numParticles = _ref2$numParticles === void 0 ? 65535 : _ref2$numParticles,
229
- _ref2$fadeOpacity = _ref2.fadeOpacity,
230
- fadeOpacity = _ref2$fadeOpacity === void 0 ? 0.996 : _ref2$fadeOpacity,
231
- _ref2$speedFactor = _ref2.speedFactor,
232
- speedFactor = _ref2$speedFactor === void 0 ? 0.25 : _ref2$speedFactor,
233
- _ref2$dropRate = _ref2.dropRate,
234
- dropRate = _ref2$dropRate === void 0 ? 0.003 : _ref2$dropRate,
235
- _ref2$dropRateBump = _ref2.dropRateBump,
236
- dropRateBump = _ref2$dropRateBump === void 0 ? 0.01 : _ref2$dropRateBump,
237
- _ref2$rampColors = _ref2.rampColors,
238
- rampColors = _ref2$rampColors === void 0 ? defaultRampColors : _ref2$rampColors,
239
- _ref2$sizeScale = _ref2.sizeScale,
240
- sizeScale = _ref2$sizeScale === void 0 ? 0.5 : _ref2$sizeScale;
241
- var newNumParticles = numParticles;
242
- var currentZoom = Math.floor(this.mapService.getZoom());
243
- if (typeof sizeScale === 'number' && sizeScale !== this.sizeScale || currentZoom !== this.cacheZoom) {
244
- var zoomScale = this.getZoomScale();
245
- this.sizeScale = sizeScale;
246
- newNumParticles *= zoomScale;
247
- var _this$getWindSize = this.getWindSize(),
248
- imageWidth = _this$getWindSize.imageWidth,
249
- imageHeight = _this$getWindSize.imageHeight;
250
- this.wind.reSize(imageWidth, imageHeight);
251
- this.cacheZoom = currentZoom;
124
+ _this.colorModel = model;
125
+ return [model];
126
+ })();
127
+ }
128
+ getWindSize() {
129
+ const p1 = this.mapService.lngLatToPixel(this.imageCoords[0]);
130
+ const p2 = this.mapService.lngLatToPixel(this.imageCoords[1]);
131
+ const imageWidth = Math.min(Math.floor((p2.x - p1.x) * this.sizeScale), 2048);
132
+ const imageHeight = Math.min(Math.floor((p1.y - p2.y) * this.sizeScale), 2048);
133
+ return {
134
+ imageWidth,
135
+ imageHeight
136
+ };
137
+ }
138
+ buildModels() {
139
+ var _this2 = this;
140
+ return (0, _asyncToGenerator2.default)(function* () {
141
+ return _this2.initModels();
142
+ })();
143
+ }
144
+ clearModels() {
145
+ var _this$texture2, _this$wind;
146
+ (_this$texture2 = this.texture) === null || _this$texture2 === void 0 || _this$texture2.destroy();
147
+ (_this$wind = this.wind) === null || _this$wind === void 0 || _this$wind.destroy();
148
+ }
149
+ registerBuiltinAttributes() {
150
+ // point layer size;
151
+ this.styleAttributeService.registerStyleAttribute({
152
+ name: 'uv',
153
+ type: _l7Core.AttributeType.Attribute,
154
+ descriptor: {
155
+ name: 'a_Uv',
156
+ buffer: {
157
+ // give the WebGL driver a hint that this buffer may change
158
+ usage: _l7Core.gl.DYNAMIC_DRAW,
159
+ data: [],
160
+ type: _l7Core.gl.FLOAT
161
+ },
162
+ size: 2,
163
+ update: (feature, featureIdx, vertex) => {
164
+ return [vertex[3], vertex[4]];
252
165
  }
253
- this.wind.updateWindDir(uMin, uMax, vMin, vMax);
254
- this.wind.updateParticelNum(newNumParticles);
255
- this.wind.updateColorRampTexture(rampColors);
256
- this.wind.fadeOpacity = fadeOpacity;
257
- this.wind.speedFactor = speedFactor;
258
- this.wind.dropRate = dropRate;
259
- this.wind.dropRateBump = dropRateBump;
260
- var _this$wind$draw = this.wind.draw(),
261
- d = _this$wind$draw.d,
262
- w = _this$wind$draw.w,
263
- h = _this$wind$draw.h;
264
- // 恢复 L7 渲染流程中 gl 状态
265
- this.rendererService.setBaseState();
266
- this.texture.update({
267
- data: d,
268
- width: w,
269
- height: h
270
- });
271
166
  }
272
- }
273
- }, {
274
- key: "drawColorMode",
275
- value: function drawColorMode() {
276
- var _this$colorModel;
277
- var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
278
- var _ref3 = this.layer.getLayerConfig(),
279
- opacity = _ref3.opacity;
280
- this.layerService.beforeRenderData(this.layer);
281
- this.layer.hooks.beforeRender.call();
282
- this.layerService.renderMask(this.layer.masks);
283
- (_this$colorModel = this.colorModel) === null || _this$colorModel === void 0 || _this$colorModel.draw({
284
- uniforms: {
285
- u_opacity: opacity || 1.0,
286
- u_texture: this.texture
287
- },
288
- blend: this.getBlend(),
289
- stencil: this.getStencil(options)
167
+ });
168
+ }
169
+ getZoomScale() {
170
+ return Math.min((this.cacheZoom + 4) / 30 * 2, 2);
171
+ }
172
+ drawWind() {
173
+ if (this.wind) {
174
+ const {
175
+ uMin = -21.32,
176
+ uMax = 26.8,
177
+ vMin = -21.57,
178
+ vMax = 21.42,
179
+ numParticles = 65535,
180
+ fadeOpacity = 0.996,
181
+ speedFactor = 0.25,
182
+ dropRate = 0.003,
183
+ dropRateBump = 0.01,
184
+ rampColors = defaultRampColors,
185
+ sizeScale = 0.5
186
+ } = this.layer.getLayerConfig();
187
+ let newNumParticles = numParticles;
188
+ const currentZoom = Math.floor(this.mapService.getZoom());
189
+ if (typeof sizeScale === 'number' && sizeScale !== this.sizeScale || currentZoom !== this.cacheZoom) {
190
+ const zoomScale = this.getZoomScale();
191
+ this.sizeScale = sizeScale;
192
+ newNumParticles *= zoomScale;
193
+ const {
194
+ imageWidth,
195
+ imageHeight
196
+ } = this.getWindSize();
197
+ this.wind.reSize(imageWidth, imageHeight);
198
+ this.cacheZoom = currentZoom;
199
+ }
200
+ this.wind.updateWindDir(uMin, uMax, vMin, vMax);
201
+ this.wind.updateParticelNum(newNumParticles);
202
+ this.wind.updateColorRampTexture(rampColors);
203
+ this.wind.fadeOpacity = fadeOpacity;
204
+ this.wind.speedFactor = speedFactor;
205
+ this.wind.dropRate = dropRate;
206
+ this.wind.dropRateBump = dropRateBump;
207
+ const {
208
+ d,
209
+ w,
210
+ h
211
+ } = this.wind.draw();
212
+ // 恢复 L7 渲染流程中 gl 状态
213
+ this.rendererService.setBaseState();
214
+ this.texture.update({
215
+ data: d,
216
+ width: w,
217
+ height: h
290
218
  });
291
- this.layer.hooks.afterRender.call();
292
219
  }
293
- }]);
294
- return WindModel;
295
- }(_BaseModel2.default);
220
+ }
221
+ drawColorMode(options = {}) {
222
+ var _this$colorModel;
223
+ const {
224
+ opacity
225
+ } = this.layer.getLayerConfig();
226
+ this.layerService.beforeRenderData(this.layer);
227
+ this.layer.hooks.beforeRender.call();
228
+ this.layerService.renderMask(this.layer.masks);
229
+ (_this$colorModel = this.colorModel) === null || _this$colorModel === void 0 || _this$colorModel.draw({
230
+ uniforms: {
231
+ u_opacity: opacity || 1.0,
232
+ u_texture: this.texture
233
+ },
234
+ blend: this.getBlend(),
235
+ stencil: this.getStencil(options)
236
+ });
237
+ this.layer.hooks.afterRender.call();
238
+ }
239
+ }
240
+ exports.default = WindModel;
@@ -0,0 +1,104 @@
1
+ export interface IWindData {
2
+ uMin: number;
3
+ uMax: number;
4
+ vMin: number;
5
+ vMax: number;
6
+ image: HTMLImageElement;
7
+ }
8
+ export interface IWind {
9
+ width: number;
10
+ height: number;
11
+ fadeOpacity: number;
12
+ speedFactor: number;
13
+ dropRate: number;
14
+ dropRateBump: number;
15
+ setWind: (windData: IWindData) => void;
16
+ draw: () => {
17
+ d: Uint8Array;
18
+ w: number;
19
+ h: number;
20
+ };
21
+ updateParticelNum: (num: number) => void;
22
+ updateWindDir: (uMin: number, uMax: number, vMin: number, vMax: number) => void;
23
+ updateColorRampTexture: (rampColors: {
24
+ [key: number]: string;
25
+ }) => void;
26
+ reSize: (width: number, height: number) => void;
27
+ destroy: () => void;
28
+ }
29
+ export interface IWindProps {
30
+ glContext: WebGLRenderingContext;
31
+ imageWidth: number;
32
+ imageHeight: number;
33
+ fadeOpacity: number;
34
+ speedFactor: number;
35
+ dropRate: number;
36
+ dropRateBump: number;
37
+ rampColors: {
38
+ [key: number]: string;
39
+ };
40
+ }
41
+ export declare class Wind {
42
+ width: number;
43
+ height: number;
44
+ pixels: Uint8Array;
45
+ fadeOpacity: number;
46
+ speedFactor: number;
47
+ dropRate: number;
48
+ dropRateBump: number;
49
+ private gl;
50
+ private drawProgram;
51
+ private fullScreenProgram;
52
+ private updateProgram;
53
+ private rampColors;
54
+ private numParticles;
55
+ private numParticlesSize;
56
+ private particleStateResolution;
57
+ private quadBuffer;
58
+ private particleIndexBuffer;
59
+ private framebuffer;
60
+ private colorRampTexture;
61
+ private backgroundTexture;
62
+ private screenTexture;
63
+ private particleStateTexture0;
64
+ private particleStateTexture1;
65
+ private windTexture;
66
+ private windData;
67
+ constructor(options: IWindProps);
68
+ init(): void;
69
+ setWind(windData: IWindData): void;
70
+ /**
71
+ * 更新风场粒子数量
72
+ * @param num
73
+ */
74
+ updateParticelNum(num: number): void;
75
+ /**
76
+ * 更新风场风向风速
77
+ * @param uMin
78
+ * @param uMax
79
+ * @param vMin
80
+ * @param vMax
81
+ */
82
+ updateWindDir(uMin: number, uMax: number, vMin: number, vMax: number): void;
83
+ /**
84
+ * update rampColors
85
+ * @param rampColors
86
+ */
87
+ updateColorRampTexture(rampColors: {
88
+ [key: number]: string;
89
+ }): void;
90
+ isColorChanged(rampColors: {
91
+ [key: number]: string;
92
+ }): boolean;
93
+ reSize(width: number, height: number): void;
94
+ draw(): {
95
+ d: Uint8Array;
96
+ w: number;
97
+ h: number;
98
+ };
99
+ drawScreen(): void;
100
+ drawFullTexture(texture: any, opacity: number): void;
101
+ drawParticles(): void;
102
+ updateParticles(): void;
103
+ destroy(): void;
104
+ }