@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,394 +5,317 @@ 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
9
  var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
11
- var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
- var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
13
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
14
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
15
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
16
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
- var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
18
- var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
19
10
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
20
11
  var _l7Core = require("@antv/l7-core");
21
- var _BaseModel2 = _interopRequireDefault(require("../../core/BaseModel"));
12
+ var _BaseModel = _interopRequireDefault(require("../../core/BaseModel"));
22
13
  var _CommonStyleAttribute = require("../../core/CommonStyleAttribute");
23
- 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); }; }
24
- 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; } } // import { mat4, vec3 } from 'gl-matrix';
14
+ // import { mat4, vec3 } from 'gl-matrix';
25
15
  /* babel-plugin-inline-import '../shaders/plane_frag.glsl' */
26
- var planeFrag = "\nuniform sampler2D u_texture;\nlayout(std140) uniform commonUniforms {\n float u_opacity;\n float u_mapFlag;\n float u_terrainClipHeight;\n};\n\nin vec3 v_Color;\nin vec2 v_uv;\nin float v_clip;\nout vec4 outputColor;\n\n#pragma include \"picking\"\nvoid main() {\n // gl_FragColor = vec4(v_Color, u_opacity);\n if(u_mapFlag > 0.0) {\n outputColor = texture(SAMPLER_2D(u_texture), vec2(v_uv.x, 1.0 - v_uv.y));\n outputColor.a *= u_opacity;\n } else {\n // gl_FragColor = vec4(v_uv, 0.0, u_opacity);\n outputColor = vec4(v_Color, u_opacity);\n }\n outputColor.a *= v_clip;\n outputColor = filterColor(outputColor);\n}\n";
16
+ const planeFrag = "\nuniform sampler2D u_texture;\nlayout(std140) uniform commonUniforms {\n float u_opacity;\n float u_mapFlag;\n float u_terrainClipHeight;\n};\n\nin vec3 v_Color;\nin vec2 v_uv;\nin float v_clip;\nout vec4 outputColor;\n\n#pragma include \"picking\"\nvoid main() {\n // gl_FragColor = vec4(v_Color, u_opacity);\n if(u_mapFlag > 0.0) {\n outputColor = texture(SAMPLER_2D(u_texture), vec2(v_uv.x, 1.0 - v_uv.y));\n outputColor.a *= u_opacity;\n } else {\n // gl_FragColor = vec4(v_uv, 0.0, u_opacity);\n outputColor = vec4(v_Color, u_opacity);\n }\n outputColor.a *= v_clip;\n outputColor = filterColor(outputColor);\n}\n";
27
17
  /* babel-plugin-inline-import '../shaders/plane_vert.glsl' */
28
- var planeVert = "\nlayout(location = 0) in vec3 a_Position;\nlayout(location = 1) in vec3 a_Color;\nlayout(location = 14) in vec2 a_Uv;\n\nlayout(std140) uniform commonUniforms {\n float u_opacity;\n float u_mapFlag;\n float u_terrainClipHeight;\n};\n\nout vec3 v_Color;\nout vec2 v_uv;\nout float v_clip;\n\n#pragma include \"projection\"\n#pragma include \"picking\"\nvoid main() {\n v_Color = a_Color;\n v_uv = a_Uv;\n \n vec4 project_pos = project_position(vec4(a_Position, 1.0));\n\n v_clip = 1.0;\n if(a_Position.z < u_terrainClipHeight) {\n v_clip = 0.0;\n }\n \n gl_Position = project_common_position_to_clipspace_v2(vec4(project_pos.xy, a_Position.z, 1.0));\n\n setPickingColor(a_PickingColor);\n}\n";
29
- var PlaneModel = exports.default = /*#__PURE__*/function (_BaseModel) {
30
- (0, _inherits2.default)(PlaneModel, _BaseModel);
31
- var _super = _createSuper(PlaneModel);
32
- function PlaneModel() {
33
- var _this;
34
- (0, _classCallCheck2.default)(this, PlaneModel);
35
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
36
- args[_key] = arguments[_key];
37
- }
38
- _this = _super.call.apply(_super, [this].concat(args));
39
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "terrainImageLoaded", false);
40
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "planeGeometryTriangulation", function () {
41
- var _this2;
42
- var _ref = _this.layer.getLayerConfig(),
43
- _ref$width = _ref.width,
44
- width = _ref$width === void 0 ? 1 : _ref$width,
45
- _ref$height = _ref.height,
46
- height = _ref$height === void 0 ? 1 : _ref$height,
47
- _ref$widthSegments = _ref.widthSegments,
48
- widthSegments = _ref$widthSegments === void 0 ? 1 : _ref$widthSegments,
49
- _ref$heightSegments = _ref.heightSegments,
50
- heightSegments = _ref$heightSegments === void 0 ? 1 : _ref$heightSegments,
51
- _ref$center = _ref.center,
52
- center = _ref$center === void 0 ? [120, 30] : _ref$center,
53
- terrainTexture = _ref.terrainTexture;
54
- var _this$initPlane = (_this2 = _this).initPlane.apply(_this2, [width, height, widthSegments, heightSegments].concat((0, _toConsumableArray2.default)(center))),
55
- indices = _this$initPlane.indices,
56
- positions = _this$initPlane.positions;
18
+ const planeVert = "\nlayout(location = 0) in vec3 a_Position;\nlayout(location = 1) in vec3 a_Color;\nlayout(location = 14) in vec2 a_Uv;\n\nlayout(std140) uniform commonUniforms {\n float u_opacity;\n float u_mapFlag;\n float u_terrainClipHeight;\n};\n\nout vec3 v_Color;\nout vec2 v_uv;\nout float v_clip;\n\n#pragma include \"projection\"\n#pragma include \"picking\"\nvoid main() {\n v_Color = a_Color;\n v_uv = a_Uv;\n \n vec4 project_pos = project_position(vec4(a_Position, 1.0));\n\n v_clip = 1.0;\n if(a_Position.z < u_terrainClipHeight) {\n v_clip = 0.0;\n }\n \n gl_Position = project_common_position_to_clipspace_v2(vec4(project_pos.xy, a_Position.z, 1.0));\n\n setPickingColor(a_PickingColor);\n}\n";
19
+ class PlaneModel extends _BaseModel.default {
20
+ constructor(...args) {
21
+ super(...args);
22
+ (0, _defineProperty2.default)(this, "texture", void 0);
23
+ (0, _defineProperty2.default)(this, "terrainImage", void 0);
24
+ (0, _defineProperty2.default)(this, "terrainImageLoaded", false);
25
+ (0, _defineProperty2.default)(this, "mapTexture", void 0);
26
+ (0, _defineProperty2.default)(this, "planeGeometryTriangulation", () => {
27
+ const {
28
+ width = 1,
29
+ height = 1,
30
+ widthSegments = 1,
31
+ heightSegments = 1,
32
+ center = [120, 30],
33
+ terrainTexture
34
+ } = this.layer.getLayerConfig();
35
+ const {
36
+ indices,
37
+ positions
38
+ } = this.initPlane(width, height, widthSegments, heightSegments, ...center);
57
39
  if (terrainTexture) {
58
40
  // 存在地形贴图的时候会根据地形贴图对顶点进行偏移
59
- _this.loadTerrainTexture(positions, indices);
41
+ this.loadTerrainTexture(positions, indices);
60
42
  }
61
43
  return {
62
44
  vertices: positions,
63
- indices: indices,
45
+ indices,
64
46
  size: 5
65
47
  };
66
48
  });
67
- return _this;
68
49
  }
69
- (0, _createClass2.default)(PlaneModel, [{
70
- key: "initPlane",
71
- value: function initPlane() {
72
- var width = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1;
73
- var height = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
74
- var widthSegments = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 1;
75
- var heightSegments = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 1;
76
- var lng = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : 120;
77
- var lat = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 30;
78
- // https://github.com/mrdoob/three.js/blob/dev/src/geometries/PlaneGeometry.js
79
- var widthHalf = width / 2;
80
- var heightHalf = height / 2;
81
- var gridX = Math.floor(widthSegments);
82
- var gridY = Math.floor(heightSegments);
83
- var gridX1 = gridX + 1;
84
- var gridY1 = gridY + 1;
85
- var segmentWidth = width / gridX;
86
- var segmentHeight = height / gridY;
87
- var indices = [];
88
- var positions = [];
89
- for (var iy = 0; iy < gridY1; iy++) {
90
- var y = iy * segmentHeight - heightHalf;
91
- for (var ix = 0; ix < gridX1; ix++) {
92
- var x = ix * segmentWidth - widthHalf;
93
- if (this.mapService.version === 'GAODE2.x') {
94
- // @ts-ignore
95
- var _ref2 = this.mapService.lngLatToCoord([x + lng, -y + lat]),
96
- _ref3 = (0, _slicedToArray2.default)(_ref2, 2),
97
- a = _ref3[0],
98
- _b = _ref3[1];
99
- positions.push(a, _b, 0);
100
- } else {
101
- positions.push(x + lng, -y + lat, 0);
102
- }
103
- positions.push(ix / gridX);
104
- positions.push(1 - iy / gridY);
105
- }
106
- }
107
- for (var _iy = 0; _iy < gridY; _iy++) {
108
- for (var _ix = 0; _ix < gridX; _ix++) {
109
- var _a = _ix + gridX1 * _iy;
110
- var _b2 = _ix + gridX1 * (_iy + 1);
111
- var c = _ix + 1 + gridX1 * (_iy + 1);
112
- var d = _ix + 1 + gridX1 * _iy;
113
- indices.push(_a, _b2, d);
114
- indices.push(_b2, c, d);
50
+ initPlane(width = 1, height = 1, widthSegments = 1, heightSegments = 1, lng = 120, lat = 30) {
51
+ // https://github.com/mrdoob/three.js/blob/dev/src/geometries/PlaneGeometry.js
52
+ const widthHalf = width / 2;
53
+ const heightHalf = height / 2;
54
+ const gridX = Math.floor(widthSegments);
55
+ const gridY = Math.floor(heightSegments);
56
+ const gridX1 = gridX + 1;
57
+ const gridY1 = gridY + 1;
58
+ const segmentWidth = width / gridX;
59
+ const segmentHeight = height / gridY;
60
+ const indices = [];
61
+ const positions = [];
62
+ for (let iy = 0; iy < gridY1; iy++) {
63
+ const y = iy * segmentHeight - heightHalf;
64
+ for (let ix = 0; ix < gridX1; ix++) {
65
+ const x = ix * segmentWidth - widthHalf;
66
+ if (this.mapService.version === 'GAODE2.x') {
67
+ // @ts-ignore
68
+ const [a, b] = this.mapService.lngLatToCoord([x + lng, -y + lat]);
69
+ positions.push(a, b, 0);
70
+ } else {
71
+ positions.push(x + lng, -y + lat, 0);
115
72
  }
73
+ positions.push(ix / gridX);
74
+ positions.push(1 - iy / gridY);
116
75
  }
117
- return {
118
- indices: indices,
119
- positions: positions
120
- };
121
- }
122
- }, {
123
- key: "getUninforms",
124
- value: function getUninforms() {
125
- var commoninfo = this.getCommonUniformsInfo();
126
- var attributeInfo = this.getUniformsBufferInfo(this.getStyleAttribute());
127
- this.updateStyleUnifoms();
128
- return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, commoninfo.uniformsOption), attributeInfo.uniformsOption);
129
76
  }
130
- }, {
131
- key: "getCommonUniformsInfo",
132
- value: function getCommonUniformsInfo() {
133
- var _ref4 = this.layer.getLayerConfig(),
134
- opacity = _ref4.opacity,
135
- mapTexture = _ref4.mapTexture,
136
- _ref4$terrainClipHeig = _ref4.terrainClipHeight,
137
- terrainClipHeight = _ref4$terrainClipHeig === void 0 ? 0 : _ref4$terrainClipHeig,
138
- terrainTexture = _ref4.terrainTexture;
139
- if (this.mapTexture !== mapTexture) {
140
- var _this$texture;
141
- this.mapTexture = mapTexture;
142
- (_this$texture = this.texture) === null || _this$texture === void 0 || _this$texture.destroy();
143
- this.updateTexture(mapTexture);
77
+ for (let iy = 0; iy < gridY; iy++) {
78
+ for (let ix = 0; ix < gridX; ix++) {
79
+ const a = ix + gridX1 * iy;
80
+ const b = ix + gridX1 * (iy + 1);
81
+ const c = ix + 1 + gridX1 * (iy + 1);
82
+ const d = ix + 1 + gridX1 * iy;
83
+ indices.push(a, b, d);
84
+ indices.push(b, c, d);
144
85
  }
145
- var commonOptions = {
146
- u_opacity: opacity || 1,
147
- u_mapFlag: mapTexture ? 1 : 0,
148
- u_terrainClipHeight: terrainTexture ? terrainClipHeight : -1,
149
- u_texture: this.texture
150
- };
151
- this.textures = [this.texture];
152
- var commonBufferInfo = this.getUniformsBufferInfo(commonOptions);
153
- return commonBufferInfo;
154
86
  }
155
- }, {
156
- key: "clearModels",
157
- value: function clearModels() {
158
- var _this$texture2;
159
- // @ts-ignore
160
- this.terrainImage = null;
161
- (_this$texture2 = this.texture) === null || _this$texture2 === void 0 || _this$texture2.destroy();
162
- this.textures = [];
87
+ return {
88
+ indices,
89
+ positions
90
+ };
91
+ }
92
+ getUninforms() {
93
+ const commoninfo = this.getCommonUniformsInfo();
94
+ const attributeInfo = this.getUniformsBufferInfo(this.getStyleAttribute());
95
+ this.updateStyleUnifoms();
96
+ return (0, _objectSpread2.default)((0, _objectSpread2.default)({}, commoninfo.uniformsOption), attributeInfo.uniformsOption);
97
+ }
98
+ getCommonUniformsInfo() {
99
+ const {
100
+ opacity,
101
+ mapTexture,
102
+ terrainClipHeight = 0,
103
+ terrainTexture
104
+ } = this.layer.getLayerConfig();
105
+ if (this.mapTexture !== mapTexture) {
106
+ var _this$texture;
107
+ this.mapTexture = mapTexture;
108
+ (_this$texture = this.texture) === null || _this$texture === void 0 || _this$texture.destroy();
109
+ this.updateTexture(mapTexture);
163
110
  }
164
- }, {
165
- key: "initModels",
166
- value: function () {
167
- var _initModels = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
168
- var _ref5, mapTexture, createTexture2D, model;
169
- return _regenerator.default.wrap(function _callee$(_context) {
170
- while (1) switch (_context.prev = _context.next) {
171
- case 0:
172
- _ref5 = this.layer.getLayerConfig(), mapTexture = _ref5.mapTexture;
173
- this.mapTexture = mapTexture;
174
- createTexture2D = this.rendererService.createTexture2D;
175
- this.texture = createTexture2D({
176
- height: 0,
177
- width: 0
178
- });
179
- this.updateTexture(mapTexture);
180
- this.initUniformsBuffer();
181
- _context.next = 8;
182
- return this.layer.buildLayerModel({
183
- moduleName: 'geometryPlane',
184
- vertexShader: planeVert,
185
- fragmentShader: planeFrag,
186
- triangulation: this.planeGeometryTriangulation,
187
- inject: this.getInject(),
188
- primitive: _l7Core.gl.TRIANGLES,
189
- depth: {
190
- enable: true
191
- },
192
- cull: {
193
- enable: true,
194
- face: _l7Core.gl.BACK // gl.FRONT | gl.BACK;
195
- }
196
- });
197
- case 8:
198
- model = _context.sent;
199
- return _context.abrupt("return", [model]);
200
- case 10:
201
- case "end":
202
- return _context.stop();
203
- }
204
- }, _callee, this);
205
- }));
206
- function initModels() {
207
- return _initModels.apply(this, arguments);
208
- }
209
- return initModels;
210
- }()
211
- }, {
212
- key: "buildModels",
213
- value: function () {
214
- var _buildModels = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
215
- return _regenerator.default.wrap(function _callee2$(_context2) {
216
- while (1) switch (_context2.prev = _context2.next) {
217
- case 0:
218
- return _context2.abrupt("return", this.initModels());
219
- case 1:
220
- case "end":
221
- return _context2.stop();
222
- }
223
- }, _callee2, this);
224
- }));
225
- function buildModels() {
226
- return _buildModels.apply(this, arguments);
227
- }
228
- return buildModels;
229
- }()
230
- }, {
231
- key: "createModelData",
232
- value: function createModelData(options) {
233
- if (options) {
234
- var _ref6 = this.layer.getLayerConfig(),
235
- oldwidthSegments = _ref6.widthSegments,
236
- oldheightSegments = _ref6.heightSegments,
237
- oldwidth = _ref6.width,
238
- oldheight = _ref6.height;
239
- var _ref7 = options,
240
- widthSegments = _ref7.widthSegments,
241
- heightSegments = _ref7.heightSegments,
242
- width = _ref7.width,
243
- height = _ref7.height;
244
- this.layer.style({
245
- widthSegments: widthSegments !== undefined ? widthSegments : oldwidthSegments,
246
- heightSegments: heightSegments !== undefined ? heightSegments : oldheightSegments,
247
- width: width !== undefined ? width : oldwidth,
248
- height: height !== undefined ? height : oldheight
249
- });
250
- }
251
- var oldFeatures = this.layer.getEncodedData();
252
- var res = this.styleAttributeService.createAttributesAndIndices(oldFeatures, this.planeGeometryTriangulation);
253
- return res;
111
+ const commonOptions = {
112
+ u_opacity: opacity || 1,
113
+ u_mapFlag: mapTexture ? 1 : 0,
114
+ u_terrainClipHeight: terrainTexture ? terrainClipHeight : -1,
115
+ u_texture: this.texture
116
+ };
117
+ this.textures = [this.texture];
118
+ const commonBufferInfo = this.getUniformsBufferInfo(commonOptions);
119
+ return commonBufferInfo;
120
+ }
121
+ clearModels() {
122
+ var _this$texture2;
123
+ // @ts-ignore
124
+ this.terrainImage = null;
125
+ (_this$texture2 = this.texture) === null || _this$texture2 === void 0 || _this$texture2.destroy();
126
+ this.textures = [];
127
+ }
128
+ initModels() {
129
+ var _this = this;
130
+ return (0, _asyncToGenerator2.default)(function* () {
131
+ const {
132
+ mapTexture
133
+ } = _this.layer.getLayerConfig();
134
+ _this.mapTexture = mapTexture;
135
+ const {
136
+ createTexture2D
137
+ } = _this.rendererService;
138
+ _this.texture = createTexture2D({
139
+ height: 0,
140
+ width: 0
141
+ });
142
+ _this.updateTexture(mapTexture);
143
+ _this.initUniformsBuffer();
144
+ const model = yield _this.layer.buildLayerModel({
145
+ moduleName: 'geometryPlane',
146
+ vertexShader: planeVert,
147
+ fragmentShader: planeFrag,
148
+ triangulation: _this.planeGeometryTriangulation,
149
+ inject: _this.getInject(),
150
+ primitive: _l7Core.gl.TRIANGLES,
151
+ depth: {
152
+ enable: true
153
+ },
154
+ cull: {
155
+ enable: true,
156
+ face: _l7Core.gl.BACK // gl.FRONT | gl.BACK;
157
+ }
158
+ });
159
+ return [model];
160
+ })();
161
+ }
162
+ buildModels() {
163
+ var _this2 = this;
164
+ return (0, _asyncToGenerator2.default)(function* () {
165
+ return _this2.initModels();
166
+ })();
167
+ }
168
+ createModelData(options) {
169
+ if (options) {
170
+ const {
171
+ widthSegments: oldwidthSegments,
172
+ heightSegments: oldheightSegments,
173
+ width: oldwidth,
174
+ height: oldheight
175
+ } = this.layer.getLayerConfig();
176
+ const {
177
+ widthSegments,
178
+ heightSegments,
179
+ width,
180
+ height
181
+ } = options;
182
+ this.layer.style({
183
+ widthSegments: widthSegments !== undefined ? widthSegments : oldwidthSegments,
184
+ heightSegments: heightSegments !== undefined ? heightSegments : oldheightSegments,
185
+ width: width !== undefined ? width : oldwidth,
186
+ height: height !== undefined ? height : oldheight
187
+ });
254
188
  }
255
- }, {
256
- key: "updateTexture",
257
- value: function updateTexture(mapTexture) {
258
- var _this3 = this;
259
- var createTexture2D = this.rendererService.createTexture2D;
260
- if (mapTexture) {
261
- var img = new Image();
262
- img.crossOrigin = 'anonymous';
263
- img.onload = function () {
264
- _this3.texture = createTexture2D({
265
- data: img,
266
- width: img.width,
267
- height: img.height,
268
- wrapS: _l7Core.gl.CLAMP_TO_EDGE,
269
- wrapT: _l7Core.gl.CLAMP_TO_EDGE
270
- });
271
- _this3.layerService.reRender();
272
- };
273
- img.src = mapTexture;
274
- } else {
189
+ const oldFeatures = this.layer.getEncodedData();
190
+ const res = this.styleAttributeService.createAttributesAndIndices(oldFeatures, this.planeGeometryTriangulation);
191
+ return res;
192
+ }
193
+ updateTexture(mapTexture) {
194
+ const {
195
+ createTexture2D
196
+ } = this.rendererService;
197
+ if (mapTexture) {
198
+ const img = new Image();
199
+ img.crossOrigin = 'anonymous';
200
+ img.onload = () => {
275
201
  this.texture = createTexture2D({
276
- width: 0,
277
- height: 0
202
+ data: img,
203
+ width: img.width,
204
+ height: img.height,
205
+ wrapS: _l7Core.gl.CLAMP_TO_EDGE,
206
+ wrapT: _l7Core.gl.CLAMP_TO_EDGE
278
207
  });
279
- }
280
- }
281
- }, {
282
- key: "getImageData",
283
- value: function getImageData(img) {
284
- var canvas = document.createElement('canvas');
285
- var ctx = canvas.getContext('2d');
286
- var width = img.width,
287
- height = img.height;
288
- canvas.width = width;
289
- canvas.height = height;
290
- ctx.drawImage(img, 0, 0, width, height);
291
- var imageData = ctx.getImageData(0, 0, width, height);
292
- return imageData;
208
+ this.layerService.reRender();
209
+ };
210
+ img.src = mapTexture;
211
+ } else {
212
+ this.texture = createTexture2D({
213
+ width: 0,
214
+ height: 0
215
+ });
293
216
  }
294
- }, {
295
- key: "translateVertex",
296
- value: function translateVertex(positions, indices, image, widthSegments, heightSegments, rgb2height) {
297
- var imgWidth = image.width;
298
- var imgHeight = image.height;
299
- var imageData = this.getImageData(image).data;
300
- var gridX = Math.floor(widthSegments);
301
- var gridY = Math.floor(heightSegments);
302
- var gridX1 = gridX + 1;
303
- var gridY1 = gridY + 1;
304
- var widthStep = imgWidth / gridX;
305
- var heightStep = imgHeight / gridY;
306
- for (var iy = 0; iy < gridY1; iy++) {
307
- var imgIndexY = Math.floor(iy * heightStep);
308
- var imgLen = imgIndexY * imgWidth;
309
- for (var ix = 0; ix < gridX1; ix++) {
310
- var imgIndexX = Math.floor(ix * widthStep);
311
- var imgDataIndex = (imgLen + imgIndexX) * 4;
312
- var _r = imageData[imgDataIndex];
313
- var _g = imageData[imgDataIndex + 1];
314
- var _b3 = imageData[imgDataIndex + 2];
315
- var z = (iy * gridX1 + ix) * 5 + 2;
316
- positions[z] = rgb2height(_r, _g, _b3);
317
- }
217
+ }
218
+ getImageData(img) {
219
+ const canvas = document.createElement('canvas');
220
+ const ctx = canvas.getContext('2d');
221
+ const {
222
+ width,
223
+ height
224
+ } = img;
225
+ canvas.width = width;
226
+ canvas.height = height;
227
+ ctx.drawImage(img, 0, 0, width, height);
228
+ const imageData = ctx.getImageData(0, 0, width, height);
229
+ return imageData;
230
+ }
231
+ translateVertex(positions, indices, image, widthSegments, heightSegments, rgb2height) {
232
+ const imgWidth = image.width;
233
+ const imgHeight = image.height;
234
+ const imageData = this.getImageData(image).data;
235
+ const gridX = Math.floor(widthSegments);
236
+ const gridY = Math.floor(heightSegments);
237
+ const gridX1 = gridX + 1;
238
+ const gridY1 = gridY + 1;
239
+ const widthStep = imgWidth / gridX;
240
+ const heightStep = imgHeight / gridY;
241
+ for (let iy = 0; iy < gridY1; iy++) {
242
+ const imgIndexY = Math.floor(iy * heightStep);
243
+ const imgLen = imgIndexY * imgWidth;
244
+ for (let ix = 0; ix < gridX1; ix++) {
245
+ const imgIndexX = Math.floor(ix * widthStep);
246
+ const imgDataIndex = (imgLen + imgIndexX) * 4;
247
+ const r = imageData[imgDataIndex];
248
+ const g = imageData[imgDataIndex + 1];
249
+ const b = imageData[imgDataIndex + 2];
250
+ const z = (iy * gridX1 + ix) * 5 + 2;
251
+ positions[z] = rgb2height(r, g, b);
318
252
  }
319
- var oldFeatures = this.layer.getEncodedData();
320
- var modelData = this.styleAttributeService.createAttributesAndIndices(oldFeatures, function () {
321
- return {
322
- vertices: positions,
323
- indices: indices,
324
- size: 5
325
- };
326
- });
327
- this.layer.updateModelData(modelData);
328
- this.layerService.throttleRenderLayers();
329
253
  }
254
+ const oldFeatures = this.layer.getEncodedData();
255
+ const modelData = this.styleAttributeService.createAttributesAndIndices(oldFeatures, () => {
256
+ return {
257
+ vertices: positions,
258
+ indices,
259
+ size: 5
260
+ };
261
+ });
262
+ this.layer.updateModelData(modelData);
263
+ this.layerService.throttleRenderLayers();
264
+ }
330
265
 
331
- /**
332
- * load terrain texture & offset attribute z
333
- */
334
- }, {
335
- key: "loadTerrainTexture",
336
- value: function loadTerrainTexture(positions, indices) {
337
- var _this4 = this;
338
- var _ref8 = this.layer.getLayerConfig(),
339
- _ref8$widthSegments = _ref8.widthSegments,
340
- widthSegments = _ref8$widthSegments === void 0 ? 1 : _ref8$widthSegments,
341
- _ref8$heightSegments = _ref8.heightSegments,
342
- heightSegments = _ref8$heightSegments === void 0 ? 1 : _ref8$heightSegments,
343
- terrainTexture = _ref8.terrainTexture,
344
- _ref8$rgb2height = _ref8.rgb2height,
345
- rgb2height = _ref8$rgb2height === void 0 ? function (r, g, b) {
346
- return r + g + b;
347
- } : _ref8$rgb2height;
348
- if (this.terrainImage) {
349
- // 若当前已经存在 image,直接进行偏移计算(LOD)
350
- if (this.terrainImageLoaded) {
351
- this.translateVertex(positions, indices, this.terrainImage, widthSegments, heightSegments, rgb2height);
352
- } else {
353
- this.terrainImage.onload = function () {
354
- _this4.translateVertex(positions, indices, _this4.terrainImage, widthSegments, heightSegments, rgb2height);
355
- };
356
- }
266
+ /**
267
+ * load terrain texture & offset attribute z
268
+ */
269
+ loadTerrainTexture(positions, indices) {
270
+ const {
271
+ widthSegments = 1,
272
+ heightSegments = 1,
273
+ terrainTexture,
274
+ rgb2height = (r, g, b) => r + g + b
275
+ } = this.layer.getLayerConfig();
276
+ if (this.terrainImage) {
277
+ // 若当前已经存在 image,直接进行偏移计算(LOD)
278
+ if (this.terrainImageLoaded) {
279
+ this.translateVertex(positions, indices, this.terrainImage, widthSegments, heightSegments, rgb2height);
357
280
  } else {
358
- // 加载地形贴图、根据地形贴图对 planeGeometry 进行偏移
359
- var terrainImage = new Image();
360
- this.terrainImage = terrainImage;
361
- terrainImage.crossOrigin = 'anonymous';
362
- terrainImage.onload = function () {
363
- _this4.terrainImageLoaded = true;
364
- // 图片加载完,触发事件,可以进行地形图的顶点计算存储
365
- setTimeout(function () {
366
- return _this4.layer.emit('terrainImageLoaded', null);
367
- });
368
- _this4.translateVertex(positions, indices, terrainImage, widthSegments, heightSegments, rgb2height);
281
+ this.terrainImage.onload = () => {
282
+ this.translateVertex(positions, indices, this.terrainImage, widthSegments, heightSegments, rgb2height);
369
283
  };
370
- terrainImage.src = terrainTexture;
371
284
  }
285
+ } else {
286
+ // 加载地形贴图、根据地形贴图对 planeGeometry 进行偏移
287
+ const terrainImage = new Image();
288
+ this.terrainImage = terrainImage;
289
+ terrainImage.crossOrigin = 'anonymous';
290
+ terrainImage.onload = () => {
291
+ this.terrainImageLoaded = true;
292
+ // 图片加载完,触发事件,可以进行地形图的顶点计算存储
293
+ setTimeout(() => this.layer.emit('terrainImageLoaded', null));
294
+ this.translateVertex(positions, indices, terrainImage, widthSegments, heightSegments, rgb2height);
295
+ };
296
+ terrainImage.src = terrainTexture;
372
297
  }
373
- }, {
374
- key: "registerBuiltinAttributes",
375
- value: function registerBuiltinAttributes() {
376
- // point layer size;
377
- this.styleAttributeService.registerStyleAttribute({
378
- name: 'uv',
379
- type: _l7Core.AttributeType.Attribute,
380
- descriptor: {
381
- name: 'a_Uv',
382
- shaderLocation: _CommonStyleAttribute.ShaderLocation.UV,
383
- buffer: {
384
- // give the WebGL driver a hint that this buffer may change
385
- usage: _l7Core.gl.DYNAMIC_DRAW,
386
- data: [],
387
- type: _l7Core.gl.FLOAT
388
- },
389
- size: 2,
390
- update: function update(feature, featureIdx, vertex) {
391
- return [vertex[3], vertex[4]];
392
- }
298
+ }
299
+ registerBuiltinAttributes() {
300
+ // point layer size;
301
+ this.styleAttributeService.registerStyleAttribute({
302
+ name: 'uv',
303
+ type: _l7Core.AttributeType.Attribute,
304
+ descriptor: {
305
+ name: 'a_Uv',
306
+ shaderLocation: _CommonStyleAttribute.ShaderLocation.UV,
307
+ buffer: {
308
+ // give the WebGL driver a hint that this buffer may change
309
+ usage: _l7Core.gl.DYNAMIC_DRAW,
310
+ data: [],
311
+ type: _l7Core.gl.FLOAT
312
+ },
313
+ size: 2,
314
+ update: (feature, featureIdx, vertex) => {
315
+ return [vertex[3], vertex[4]];
393
316
  }
394
- });
395
- }
396
- }]);
397
- return PlaneModel;
398
- }(_BaseModel2.default);
317
+ }
318
+ });
319
+ }
320
+ }
321
+ exports.default = PlaneModel;