@pirireis/webglobeplugins 0.16.0 → 0.16.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (480) hide show
  1. package/Math/angle-calculation.js +13 -14
  2. package/Math/bounds/line-bbox.js +186 -225
  3. package/Math/index.js +1 -0
  4. package/Math/mesh/mapbox-delaunay.js +544 -607
  5. package/Math/utils.js +2 -3
  6. package/algorithms/search-binary.js +16 -14
  7. package/altitude-locator/adaptors.js +1 -0
  8. package/altitude-locator/keymethod.js +1 -0
  9. package/altitude-locator/plugin.js +345 -446
  10. package/altitude-locator/types.js +21 -26
  11. package/arrowfield/adaptor.js +11 -11
  12. package/arrowfield/index.js +3 -3
  13. package/arrowfield/plugin.js +83 -128
  14. package/bearing-line/index.js +2 -2
  15. package/bearing-line/plugin.js +444 -520
  16. package/circle-line-chain/chain-list-map.js +201 -221
  17. package/circle-line-chain/init.js +1 -0
  18. package/circle-line-chain/plugin.js +411 -464
  19. package/circle-line-chain/util.js +1 -1
  20. package/compass-rose/compass-rose-padding-flat.js +230 -274
  21. package/compass-rose/compass-text-writer.js +149 -173
  22. package/compass-rose/index.js +3 -3
  23. package/compassrose/compassrose.js +293 -341
  24. package/compassrose/index.js +2 -2
  25. package/constants.js +3 -0
  26. package/heatwave/index.js +3 -4
  27. package/heatwave/isobar/objectarraylabels.js +200 -247
  28. package/heatwave/isobar/plugin.js +302 -339
  29. package/heatwave/isobar/quadtreecontours.js +298 -336
  30. package/heatwave/plugins/heatwaveglobeshell.js +204 -259
  31. package/index.js +12 -15
  32. package/jest.config.js +7 -6
  33. package/package.json +1 -4
  34. package/partialrings/buffer-manager.js +75 -89
  35. package/partialrings/index.js +2 -3
  36. package/partialrings/plugin.js +128 -160
  37. package/partialrings/program.js +188 -233
  38. package/pin/pin-object-array.js +300 -381
  39. package/pin/pin-point-totem.js +60 -77
  40. package/point-heat-map/adaptors/timetracksplugin-format-to-this.js +63 -78
  41. package/point-heat-map/index.js +1 -0
  42. package/point-heat-map/plugin-webworker.js +121 -148
  43. package/point-heat-map/point-to-heat-map-flow.js +124 -150
  44. package/point-tracks/key-methods.js +2 -3
  45. package/point-tracks/plugin.js +393 -480
  46. package/programs/arrowfield/index.js +2 -2
  47. package/programs/arrowfield/logic.js +141 -173
  48. package/programs/arrowfield/object.js +60 -89
  49. package/programs/data2legend/density-to-legend.js +73 -90
  50. package/programs/data2legend/point-to-density-texture.js +70 -87
  51. package/programs/float2legendwithratio/index.js +2 -3
  52. package/programs/float2legendwithratio/logic.js +118 -144
  53. package/programs/float2legendwithratio/object.js +104 -141
  54. package/programs/globe-util/is-globe-moved.js +19 -27
  55. package/programs/globeshell/index.js +2 -2
  56. package/programs/globeshell/wiggle/index.js +2 -3
  57. package/programs/globeshell/wiggle/logic.js +243 -272
  58. package/programs/globeshell/wiggle/object.js +66 -93
  59. package/programs/helpers/blender/index.js +1 -0
  60. package/programs/helpers/blender/program.js +58 -73
  61. package/programs/helpers/fadeaway/index.js +2 -3
  62. package/programs/helpers/fadeaway/logic.js +46 -53
  63. package/programs/helpers/fadeaway/object.js +14 -20
  64. package/programs/helpers/index.js +2 -2
  65. package/programs/index.js +9 -21
  66. package/programs/line-on-globe/circle-accurate-3d.js +87 -115
  67. package/programs/line-on-globe/circle-accurate-flat.js +149 -201
  68. package/programs/line-on-globe/degree-padding-around-circle-3d.js +104 -136
  69. package/programs/line-on-globe/index.js +1 -0
  70. package/programs/line-on-globe/lines-color-instanced-flat.js +83 -102
  71. package/programs/line-on-globe/util.js +5 -8
  72. package/programs/picking/pickable-polygon-renderer.js +98 -129
  73. package/programs/picking/pickable-renderer.js +98 -129
  74. package/programs/point-on-globe/element-globe-surface-glow.js +93 -122
  75. package/programs/point-on-globe/element-point-glow.js +80 -114
  76. package/programs/point-on-globe/square-pixel-point.js +120 -138
  77. package/programs/rings/distancering/circleflatprogram.js +116 -138
  78. package/programs/rings/distancering/circlepaddingfreeangleprogram.js +275 -323
  79. package/programs/rings/distancering/circlepaddysharedbuffer.js +368 -423
  80. package/programs/rings/distancering/index.js +6 -5
  81. package/programs/rings/distancering/paddyflatprogram.js +127 -148
  82. package/programs/rings/distancering/paddyflatprogram2d.js +129 -153
  83. package/programs/rings/distancering/paddyflatprogram3d.js +128 -149
  84. package/programs/rings/index.js +1 -1
  85. package/{dist/programs → programs}/totems/camerauniformblock.js +10 -3
  86. package/programs/totems/gpu-selection-uniform-block.js +99 -127
  87. package/programs/two-d/pixel-circle.js +1 -0
  88. package/programs/two-d/pixel-padding-for-compass.js +97 -112
  89. package/programs/util.js +14 -19
  90. package/programs/vectorfields/index.js +3 -3
  91. package/programs/vectorfields/logics/drawrectangleparticles.js +58 -78
  92. package/programs/vectorfields/logics/index.js +2 -4
  93. package/programs/vectorfields/logics/pixelbased.js +73 -92
  94. package/programs/vectorfields/logics/ubo.js +51 -57
  95. package/programs/vectorfields/pingpongbuffermanager.js +73 -80
  96. package/rangerings/index.js +5 -5
  97. package/rangerings/plugin.js +543 -644
  98. package/rangerings/rangeringangletext.js +326 -369
  99. package/rangerings/ring-account.js +112 -129
  100. package/shaders/fragment-toy/firework.js +1 -1
  101. package/shaders/fragment-toy/singularity.js +2 -5
  102. package/timetracks/adaptors-line-strip.js +65 -80
  103. package/timetracks/index.js +1 -0
  104. package/timetracks/plugin-line-strip.js +240 -295
  105. package/timetracks/program-line-strip.js +411 -491
  106. package/timetracks/programpoint-line-strip.js +98 -122
  107. package/util/account/bufferoffsetmanager.js +176 -209
  108. package/util/account/index.js +3 -6
  109. package/util/account/util.js +18 -22
  110. package/util/algorithms/index.js +1 -0
  111. package/util/algorithms/search-binary.js +25 -26
  112. package/util/check/index.js +1 -0
  113. package/util/geometry/index.js +121 -0
  114. package/util/gl-util/uniform-block/shader.js +1 -0
  115. package/util/heatwavedatamanager/datamanager.js +149 -168
  116. package/util/heatwavedatamanager/index.js +2 -2
  117. package/util/index.js +13 -13
  118. package/util/interpolation/index.js +1 -0
  119. package/util/interpolation/timetrack/index.js +2 -9
  120. package/util/interpolation/timetrack/timetrack-interpolator.js +79 -94
  121. package/util/interpolation/timetrack/web-worker.js +46 -51
  122. package/util/jshelpers/data-filler.js +17 -19
  123. package/util/jshelpers/equality.js +18 -17
  124. package/util/jshelpers/index.js +2 -1
  125. package/util/jshelpers/timefilters.js +30 -32
  126. package/util/picking/fence.js +43 -46
  127. package/util/picking/picker-displayer.js +136 -177
  128. package/util/programs/draw-texture-on-canvas.js +66 -82
  129. package/util/programs/index.js +1 -1
  130. package/util/programs/shapesonglobe.js +167 -203
  131. package/util/programs/supersampletotextures.js +99 -132
  132. package/util/programs/texturetoglobe.js +128 -152
  133. package/util/shaderfunctions/index.js +2 -2
  134. package/util/shaderfunctions/nodata.js +2 -4
  135. package/util/shaderfunctions/noisefunctions.js +7 -10
  136. package/util/surface-line-data/arcs-to-cuts.js +50 -74
  137. package/util/surface-line-data/cut-arc.js +1 -0
  138. package/util/surface-line-data/rbush-manager.js +1 -0
  139. package/util/surface-line-data/web-worker.js +1 -0
  140. package/util/webglobe/gldefaultstates.js +4 -5
  141. package/util/webglobe/index.js +2 -2
  142. package/util/webglobe/rasteroverlay.js +75 -96
  143. package/waveparticles/adaptor.js +15 -16
  144. package/waveparticles/index.js +3 -3
  145. package/waveparticles/plugin.js +290 -342
  146. package/wind/imagetovectorfieldandmagnitude.js +56 -71
  147. package/wind/index.js +5 -5
  148. package/wind/plugin.js +670 -845
  149. package/wind/vectorfieldimage.js +23 -27
  150. package/write-text/attached-text-writer.js +87 -105
  151. package/{dist/write-text → write-text}/context-text-bulk.js +28 -15
  152. package/write-text/context-text.js +94 -125
  153. package/write-text/context-text3old.js +152 -179
  154. package/write-text/index.js +1 -1
  155. package/write-text/writer-plugin.js +8 -7
  156. package/Math/arc-cdf-points.ts +0 -329
  157. package/Math/arc-generate-points-exponantial.ts +0 -299
  158. package/Math/arc.ts +0 -299
  159. package/Math/circle-cdf-points.ts +0 -143
  160. package/Math/circle.ts +0 -49
  161. package/Math/constants.ts +0 -12
  162. package/Math/juction/arc-plane.ts +0 -129
  163. package/Math/juction/line-sphere.ts +0 -30
  164. package/Math/juction/plane-plane.ts +0 -64
  165. package/Math/line.ts +0 -84
  166. package/Math/matrix4.ts +0 -0
  167. package/Math/methods.ts +0 -157
  168. package/Math/plane.ts +0 -92
  169. package/Math/quaternion.ts +0 -128
  170. package/Math/roadmap.md +0 -10
  171. package/Math/templete-shapes/grid-visually-equal.ts +0 -119
  172. package/Math/types.ts +0 -66
  173. package/Math/vec3.ts +0 -180
  174. package/circle-line-chain/readme.md +0 -57
  175. package/depth-locator/readme.md +0 -26
  176. package/dist/Math/angle-calculation.js +0 -13
  177. package/dist/Math/bounds/line-bbox.js +0 -186
  178. package/dist/Math/index.js +0 -1
  179. package/dist/Math/mesh/mapbox-delaunay.js +0 -544
  180. package/dist/Math/utils.js +0 -2
  181. package/dist/algorithms/search-binary.js +0 -16
  182. package/dist/altitude-locator/adaptors.js +0 -1
  183. package/dist/altitude-locator/keymethod.js +0 -1
  184. package/dist/altitude-locator/plugin.js +0 -345
  185. package/dist/altitude-locator/types.js +0 -21
  186. package/dist/arrowfield/adaptor.js +0 -11
  187. package/dist/arrowfield/index.js +0 -3
  188. package/dist/arrowfield/plugin.js +0 -83
  189. package/dist/bearing-line/index.js +0 -2
  190. package/dist/bearing-line/plugin.js +0 -444
  191. package/dist/circle-line-chain/chain-list-map.js +0 -201
  192. package/dist/circle-line-chain/init.js +0 -1
  193. package/dist/circle-line-chain/plugin.js +0 -411
  194. package/dist/circle-line-chain/util.js +0 -1
  195. package/dist/compass-rose/compass-rose-padding-flat.js +0 -230
  196. package/dist/compass-rose/compass-text-writer.js +0 -149
  197. package/dist/compass-rose/index.js +0 -3
  198. package/dist/compassrose/compassrose.js +0 -293
  199. package/dist/compassrose/index.js +0 -2
  200. package/dist/heatwave/index.js +0 -3
  201. package/dist/heatwave/isobar/objectarraylabels.js +0 -200
  202. package/dist/heatwave/isobar/plugin.js +0 -302
  203. package/dist/heatwave/isobar/quadtreecontours.js +0 -298
  204. package/dist/heatwave/plugins/heatwaveglobeshell.js +0 -204
  205. package/dist/index.js +0 -12
  206. package/dist/jest.config.js +0 -7
  207. package/dist/partialrings/buffer-manager.js +0 -75
  208. package/dist/partialrings/index.js +0 -2
  209. package/dist/partialrings/plugin.js +0 -128
  210. package/dist/partialrings/program.js +0 -279
  211. package/dist/pin/pin-object-array.js +0 -300
  212. package/dist/pin/pin-point-totem.js +0 -60
  213. package/dist/point-heat-map/adaptors/timetracksplugin-format-to-this.js +0 -63
  214. package/dist/point-heat-map/index.js +0 -1
  215. package/dist/point-heat-map/plugin-webworker.js +0 -121
  216. package/dist/point-heat-map/point-to-heat-map-flow.js +0 -124
  217. package/dist/point-tracks/key-methods.js +0 -2
  218. package/dist/point-tracks/plugin.js +0 -393
  219. package/dist/programs/arrowfield/index.js +0 -2
  220. package/dist/programs/arrowfield/logic.js +0 -254
  221. package/dist/programs/arrowfield/object.js +0 -60
  222. package/dist/programs/data2legend/density-to-legend.js +0 -98
  223. package/dist/programs/data2legend/point-to-density-texture.js +0 -97
  224. package/dist/programs/float2legendwithratio/index.js +0 -2
  225. package/dist/programs/float2legendwithratio/logic.js +0 -167
  226. package/dist/programs/float2legendwithratio/object.js +0 -104
  227. package/dist/programs/globe-util/is-globe-moved.js +0 -19
  228. package/dist/programs/globeshell/index.js +0 -2
  229. package/dist/programs/globeshell/wiggle/index.js +0 -2
  230. package/dist/programs/globeshell/wiggle/logic.js +0 -342
  231. package/dist/programs/globeshell/wiggle/object.js +0 -66
  232. package/dist/programs/helpers/blender/index.js +0 -1
  233. package/dist/programs/helpers/blender/program.js +0 -76
  234. package/dist/programs/helpers/fadeaway/index.js +0 -2
  235. package/dist/programs/helpers/fadeaway/logic.js +0 -69
  236. package/dist/programs/helpers/fadeaway/object.js +0 -14
  237. package/dist/programs/helpers/index.js +0 -2
  238. package/dist/programs/index.js +0 -9
  239. package/dist/programs/line-on-globe/circle-accurate-3d.js +0 -138
  240. package/dist/programs/line-on-globe/circle-accurate-flat.js +0 -210
  241. package/dist/programs/line-on-globe/degree-padding-around-circle-3d.js +0 -156
  242. package/dist/programs/line-on-globe/index.js +0 -1
  243. package/dist/programs/line-on-globe/lines-color-instanced-flat.js +0 -131
  244. package/dist/programs/line-on-globe/util.js +0 -5
  245. package/dist/programs/picking/pickable-polygon-renderer.js +0 -184
  246. package/dist/programs/picking/pickable-renderer.js +0 -184
  247. package/dist/programs/point-on-globe/element-globe-surface-glow.js +0 -138
  248. package/dist/programs/point-on-globe/element-point-glow.js +0 -150
  249. package/dist/programs/point-on-globe/square-pixel-point.js +0 -171
  250. package/dist/programs/rings/distancering/circleflatprogram.js +0 -116
  251. package/dist/programs/rings/distancering/circlepaddingfreeangleprogram.js +0 -326
  252. package/dist/programs/rings/distancering/circlepaddysharedbuffer.js +0 -368
  253. package/dist/programs/rings/distancering/index.js +0 -6
  254. package/dist/programs/rings/distancering/paddyflatprogram.js +0 -127
  255. package/dist/programs/rings/distancering/paddyflatprogram2d.js +0 -129
  256. package/dist/programs/rings/distancering/paddyflatprogram3d.js +0 -128
  257. package/dist/programs/rings/index.js +0 -1
  258. package/dist/programs/totems/gpu-selection-uniform-block.js +0 -104
  259. package/dist/programs/two-d/pixel-circle.js +0 -1
  260. package/dist/programs/two-d/pixel-padding-for-compass.js +0 -159
  261. package/dist/programs/util.js +0 -14
  262. package/dist/programs/vectorfields/index.js +0 -3
  263. package/dist/programs/vectorfields/logics/drawrectangleparticles.js +0 -113
  264. package/dist/programs/vectorfields/logics/index.js +0 -2
  265. package/dist/programs/vectorfields/logics/pixelbased.js +0 -140
  266. package/dist/programs/vectorfields/logics/ubo.js +0 -60
  267. package/dist/programs/vectorfields/pingpongbuffermanager.js +0 -73
  268. package/dist/rangerings/index.js +0 -5
  269. package/dist/rangerings/plugin.js +0 -543
  270. package/dist/rangerings/rangeringangletext.js +0 -326
  271. package/dist/rangerings/ring-account.js +0 -112
  272. package/dist/shaders/fragment-toy/firework.js +0 -55
  273. package/dist/shaders/fragment-toy/singularity.js +0 -56
  274. package/dist/timetracks/adaptors-line-strip.js +0 -65
  275. package/dist/timetracks/index.js +0 -1
  276. package/dist/timetracks/plugin-line-strip.js +0 -240
  277. package/dist/timetracks/program-line-strip.js +0 -608
  278. package/dist/timetracks/programpoint-line-strip.js +0 -151
  279. package/dist/util/account/bufferoffsetmanager.js +0 -176
  280. package/dist/util/account/index.js +0 -3
  281. package/dist/util/account/util.js +0 -18
  282. package/dist/util/algorithms/index.js +0 -1
  283. package/dist/util/algorithms/search-binary.js +0 -25
  284. package/dist/util/check/index.js +0 -1
  285. package/dist/util/geometry/index.js +0 -47
  286. package/dist/util/gl-util/uniform-block/shader.js +0 -1
  287. package/dist/util/heatwavedatamanager/datamanager.js +0 -149
  288. package/dist/util/heatwavedatamanager/index.js +0 -2
  289. package/dist/util/index.js +0 -13
  290. package/dist/util/interpolation/index.js +0 -1
  291. package/dist/util/interpolation/timetrack/index.js +0 -2
  292. package/dist/util/interpolation/timetrack/timetrack-interpolator.js +0 -79
  293. package/dist/util/interpolation/timetrack/web-worker.js +0 -46
  294. package/dist/util/jshelpers/data-filler.js +0 -17
  295. package/dist/util/jshelpers/equality.js +0 -18
  296. package/dist/util/jshelpers/index.js +0 -2
  297. package/dist/util/jshelpers/timefilters.js +0 -30
  298. package/dist/util/picking/fence.js +0 -43
  299. package/dist/util/picking/picker-displayer.js +0 -136
  300. package/dist/util/programs/draw-texture-on-canvas.js +0 -86
  301. package/dist/util/programs/index.js +0 -1
  302. package/dist/util/programs/shapesonglobe.js +0 -210
  303. package/dist/util/programs/supersampletotextures.js +0 -109
  304. package/dist/util/programs/texturetoglobe.js +0 -179
  305. package/dist/util/shaderfunctions/index.js +0 -2
  306. package/dist/util/shaderfunctions/nodata.js +0 -8
  307. package/dist/util/shaderfunctions/noisefunctions.js +0 -41
  308. package/dist/util/surface-line-data/arcs-to-cuts.js +0 -50
  309. package/dist/util/surface-line-data/cut-arc.js +0 -1
  310. package/dist/util/surface-line-data/rbush-manager.js +0 -1
  311. package/dist/util/surface-line-data/web-worker.js +0 -1
  312. package/dist/util/webglobe/gldefaultstates.js +0 -4
  313. package/dist/util/webglobe/index.js +0 -2
  314. package/dist/util/webglobe/rasteroverlay.js +0 -75
  315. package/dist/waveparticles/adaptor.js +0 -15
  316. package/dist/waveparticles/index.js +0 -3
  317. package/dist/waveparticles/plugin.js +0 -290
  318. package/dist/wind/imagetovectorfieldandmagnitude.js +0 -56
  319. package/dist/wind/index.js +0 -5
  320. package/dist/wind/plugin.js +0 -921
  321. package/dist/wind/vectorfieldimage.js +0 -23
  322. package/dist/write-text/attached-text-writer.js +0 -87
  323. package/dist/write-text/context-text.js +0 -94
  324. package/dist/write-text/context-text3old.js +0 -152
  325. package/dist/write-text/index.js +0 -1
  326. package/dist/write-text/writer-plugin.js +0 -8
  327. package/partialrings/goals.md +0 -17
  328. package/point-heat-map/readme.md +0 -15
  329. package/programs/line-on-globe/linestrip/data.ts +0 -29
  330. package/programs/line-on-globe/linestrip/linestrip.ts +0 -201
  331. package/programs/line-on-globe/naive-accurate-flexible.ts +0 -258
  332. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin.ts +0 -120
  333. package/programs/polygon-on-globe/texture-dem-triangles.ts +0 -207
  334. package/programs/programcache.ts +0 -131
  335. package/programs/rings/partial-ring/piece-of-pie.ts +0 -323
  336. package/programs/totems/camerauniformblock.ts +0 -310
  337. package/programs/totems/canvas-webglobe-info.ts +0 -156
  338. package/programs/totems/globe-changes.ts +0 -79
  339. package/programs/totems/index.ts +0 -2
  340. package/programs/vectorfields/logics/constants.ts +0 -5
  341. package/programs/vectorfields/logics/ubo-new.ts +0 -37
  342. package/publish.bat +0 -62
  343. package/range-tools-on-terrain/bearing-line/adapters.ts +0 -154
  344. package/range-tools-on-terrain/bearing-line/plugin.ts +0 -569
  345. package/range-tools-on-terrain/bearing-line/types.ts +0 -65
  346. package/range-tools-on-terrain/circle-line-chain/adapters.ts +0 -109
  347. package/range-tools-on-terrain/circle-line-chain/chain-list-map.ts +0 -446
  348. package/range-tools-on-terrain/circle-line-chain/plugin.ts +0 -607
  349. package/range-tools-on-terrain/circle-line-chain/types.ts +0 -43
  350. package/range-tools-on-terrain/range-ring/adapters.ts +0 -114
  351. package/range-tools-on-terrain/range-ring/enum.ts +0 -2
  352. package/range-tools-on-terrain/range-ring/plugin.ts +0 -447
  353. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +0 -396
  354. package/range-tools-on-terrain/range-ring/types.ts +0 -30
  355. package/rangerings/enum.ts +0 -2
  356. package/semiplugins/interface.ts +0 -14
  357. package/semiplugins/lightweight/line-plugin.ts +0 -343
  358. package/semiplugins/lightweight/piece-of-pie-plugin.ts +0 -275
  359. package/semiplugins/shape-on-terrain/arc-plugin.ts +0 -602
  360. package/semiplugins/shape-on-terrain/circle-plugin.ts +0 -588
  361. package/semiplugins/shape-on-terrain/goal.md +0 -12
  362. package/semiplugins/shape-on-terrain/padding-1-degree.ts +0 -714
  363. package/semiplugins/shape-on-terrain/terrain-cover/notes.md +0 -90
  364. package/semiplugins/shape-on-terrain/terrain-cover/texture-dem-cover.ts +0 -0
  365. package/semiplugins/type.ts +0 -8
  366. package/tests/Math/arc-sampling-test.js +0 -367
  367. package/tests/Math/arc-sampling-test.ts +0 -429
  368. package/tests/Math/arc.test.ts +0 -102
  369. package/tests/Math/junction/arc-plane.test.ts +0 -163
  370. package/tests/Math/junction/plane-plane.test.ts +0 -91
  371. package/tests/Math/plane-test.ts +0 -17
  372. package/tests/Math/plane.test.ts +0 -43
  373. package/tests/Math/vec3.test.ts +0 -14
  374. package/timetracks/readme.md +0 -1
  375. package/tsconfig.json +0 -22
  376. package/types.ts +0 -265
  377. package/util/account/create-buffermap-orchastration.ts +0 -85
  378. package/util/account/single-attribute-buffer-management/buffer-manager.ts +0 -149
  379. package/util/account/single-attribute-buffer-management/buffer-orchestrator.ts +0 -332
  380. package/util/account/single-attribute-buffer-management/buffer-orchestrator1.ts +0 -184
  381. package/util/account/single-attribute-buffer-management/index.ts +0 -11
  382. package/util/account/single-attribute-buffer-management/object-store.ts +0 -76
  383. package/util/account/single-attribute-buffer-management/types.ts +0 -43
  384. package/util/build-strategy/general-strategy.ts +0 -99
  385. package/util/build-strategy/static-dynamic.ts +0 -50
  386. package/util/check/typecheck.ts +0 -74
  387. package/util/frame-counter-trigger.ts +0 -99
  388. package/util/geometry/index.ts +0 -64
  389. package/util/gl-util/buffer/attribute-loader.ts +0 -84
  390. package/util/gl-util/buffer/index.ts +0 -6
  391. package/util/gl-util/draw-options/methods.ts +0 -47
  392. package/util/gl-util/uniform-block/manager.ts +0 -210
  393. package/util/gl-util/uniform-block/roadmap.md +0 -70
  394. package/util/gl-util/uniform-block/types.ts +0 -20
  395. package/util/heatwavedatamanager/pointcoordsmeta.ts +0 -28
  396. package/util/heatwavedatamanager/texture-point-sampler.ts +0 -198
  397. package/util/shaderfunctions/geometrytransformations.ts +0 -388
  398. package/util/surface-line-data/arc-bboxes.ts +0 -42
  399. package/util/surface-line-data/flow.ts +0 -52
  400. package/util/surface-line-data/types.ts +0 -27
  401. package/util/webglobjectbuilders.ts +0 -446
  402. package/write-text/context-text-bulk.ts +0 -268
  403. package/write-text/context-text3.ts +0 -253
  404. package/write-text/context-text4.ts +0 -243
  405. /package/{dist/Math → Math}/arc-cdf-points.js +0 -0
  406. /package/{dist/Math → Math}/arc-generate-points-exponantial.js +0 -0
  407. /package/{dist/Math → Math}/arc.js +0 -0
  408. /package/{dist/Math → Math}/circle-cdf-points.js +0 -0
  409. /package/{dist/Math → Math}/circle.js +0 -0
  410. /package/{dist/Math → Math}/constants.js +0 -0
  411. /package/{dist/Math → Math}/juction/arc-plane.js +0 -0
  412. /package/{dist/Math → Math}/juction/line-sphere.js +0 -0
  413. /package/{dist/Math → Math}/juction/plane-plane.js +0 -0
  414. /package/{dist/Math → Math}/line.js +0 -0
  415. /package/{dist/Math → Math}/matrix4.js +0 -0
  416. /package/{dist/Math → Math}/methods.js +0 -0
  417. /package/{dist/Math → Math}/plane.js +0 -0
  418. /package/{dist/Math → Math}/quaternion.js +0 -0
  419. /package/{dist/Math → Math}/templete-shapes/grid-visually-equal.js +0 -0
  420. /package/{dist/Math → Math}/types.js +0 -0
  421. /package/{dist/Math → Math}/vec3.js +0 -0
  422. /package/{dist/programs → programs}/line-on-globe/linestrip/data.js +0 -0
  423. /package/{dist/programs → programs}/line-on-globe/linestrip/linestrip.js +0 -0
  424. /package/{dist/programs → programs}/line-on-globe/naive-accurate-flexible.js +0 -0
  425. /package/{dist/programs → programs}/polygon-on-globe/texture-dem-triangle-test-plugin.js +0 -0
  426. /package/{dist/programs → programs}/polygon-on-globe/texture-dem-triangles.js +0 -0
  427. /package/{dist/programs → programs}/programcache.js +0 -0
  428. /package/{dist/programs → programs}/rings/partial-ring/piece-of-pie.js +0 -0
  429. /package/{dist/programs → programs}/totems/canvas-webglobe-info.js +0 -0
  430. /package/{dist/programs → programs}/totems/globe-changes.js +0 -0
  431. /package/{dist/programs → programs}/totems/index.js +0 -0
  432. /package/{dist/programs → programs}/vectorfields/logics/constants.js +0 -0
  433. /package/{dist/programs → programs}/vectorfields/logics/ubo-new.js +0 -0
  434. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/bearing-line/adapters.js +0 -0
  435. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/bearing-line/plugin.js +0 -0
  436. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/bearing-line/types.js +0 -0
  437. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/adapters.js +0 -0
  438. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/chain-list-map.js +0 -0
  439. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/plugin.js +0 -0
  440. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/types.js +0 -0
  441. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/adapters.js +0 -0
  442. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/enum.js +0 -0
  443. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/plugin.js +0 -0
  444. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/rangeringangletext.js +0 -0
  445. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/types.js +0 -0
  446. /package/{dist/rangerings → rangerings}/enum.js +0 -0
  447. /package/{dist/semiplugins → semiplugins}/interface.js +0 -0
  448. /package/{dist/semiplugins → semiplugins}/lightweight/line-plugin.js +0 -0
  449. /package/{dist/semiplugins → semiplugins}/lightweight/piece-of-pie-plugin.js +0 -0
  450. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/arc-plugin.js +0 -0
  451. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/circle-plugin.js +0 -0
  452. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/padding-1-degree.js +0 -0
  453. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/terrain-cover/texture-dem-cover.js +0 -0
  454. /package/{dist/semiplugins → semiplugins}/type.js +0 -0
  455. /package/{dist/types.js → types.js} +0 -0
  456. /package/{dist/util → util}/account/create-buffermap-orchastration.js +0 -0
  457. /package/{dist/util → util}/account/single-attribute-buffer-management/buffer-manager.js +0 -0
  458. /package/{dist/util → util}/account/single-attribute-buffer-management/buffer-orchestrator.js +0 -0
  459. /package/{dist/util → util}/account/single-attribute-buffer-management/buffer-orchestrator1.js +0 -0
  460. /package/{dist/util → util}/account/single-attribute-buffer-management/index.js +0 -0
  461. /package/{dist/util → util}/account/single-attribute-buffer-management/object-store.js +0 -0
  462. /package/{dist/util → util}/account/single-attribute-buffer-management/types.js +0 -0
  463. /package/{dist/util → util}/build-strategy/general-strategy.js +0 -0
  464. /package/{dist/util → util}/build-strategy/static-dynamic.js +0 -0
  465. /package/{dist/util → util}/check/typecheck.js +0 -0
  466. /package/{dist/util → util}/frame-counter-trigger.js +0 -0
  467. /package/{dist/util → util}/gl-util/buffer/attribute-loader.js +0 -0
  468. /package/{dist/util → util}/gl-util/buffer/index.js +0 -0
  469. /package/{dist/util → util}/gl-util/draw-options/methods.js +0 -0
  470. /package/{dist/util → util}/gl-util/uniform-block/manager.js +0 -0
  471. /package/{dist/util → util}/gl-util/uniform-block/types.js +0 -0
  472. /package/{dist/util → util}/heatwavedatamanager/pointcoordsmeta.js +0 -0
  473. /package/{dist/util → util}/heatwavedatamanager/texture-point-sampler.js +0 -0
  474. /package/{dist/util → util}/shaderfunctions/geometrytransformations.js +0 -0
  475. /package/{dist/util → util}/surface-line-data/arc-bboxes.js +0 -0
  476. /package/{dist/util → util}/surface-line-data/flow.js +0 -0
  477. /package/{dist/util → util}/surface-line-data/types.js +0 -0
  478. /package/{dist/util → util}/webglobjectbuilders.js +0 -0
  479. /package/{dist/write-text → write-text}/context-text3.js +0 -0
  480. /package/{dist/write-text → write-text}/context-text4.js +0 -0
@@ -1,644 +1,543 @@
1
- /**
2
- * @typedef RangeRingData
3
- * @property {number} centerX
4
- * @property {number} centerY
5
- * @property {Array<Ring>} rings
6
- *
7
- * @typedef Ring
8
- * @property {number} radius
9
- * @property {number} padding
10
- * @property {[number, number, number]} color
11
- *
12
- *
13
- * @method insertBulk
14
- * @typedef {Array<{ringID, radius, padding}>} rings
15
- * @param {Array<centerID:string, x:number, y:number, stepAngle:number, rgba:[4 numbers], rings:rings} items
16
-
17
- * @method updateCentersCoordinate @param {Array<{centerID, long,lat}>} items
18
- * @method updateCentersColor @param {Array<{centerID, rgba:[4 numbers]}>} centerColors
19
- *
20
- * @method updateCentersHide @param {Array<{centerID, hide, textHide}>} centerHides
21
- * @method removeCenters @param {Array<{centerID}>} centerIds
22
- * @method setOpacity @param {number} opacity
23
- *
24
- * @method setOneDegreePaddingOn // performance consuming, might be removed
25
- *
26
- */
27
-
28
- import { centerCoords2dflatDataCreatorWithRadius, CircleCache as CircleCache2D } from "../programs/line-on-globe/circle-accurate-flat";
29
- import { CircleCache as CircleCache3D } from "../programs/line-on-globe/circle-accurate-3d";
30
- import { LinesColorInstancedFlatCache } from "../programs/line-on-globe/lines-color-instanced-flat";
31
- import { BufferOrchestrator, BufferManager } from "../util/account";
32
- // import { mapGetOrThrow } from "../util/check/get";
33
- import { populateFloat32Array } from "../util/jshelpers/data-filler";
34
- import { RingAccount, ringBigPaddingKeyMethod, ringKeyMethod } from "./ring-account";
35
- import { CirclePadding3DCache } from "../programs/line-on-globe/degree-padding-around-circle-3d";
36
- import { LineOnGlobeCache } from '../programs/line-on-globe/naive-accurate-flexible';
37
- import RangeRingAngleText from "./rangeringangletext";
38
- import { Z_ALPHA_MODE } from "../programs/line-on-globe/util";
39
- import { ENUM_HIDE } from "./enum";
40
- import { opacityCheck, mapGetOrThrow } from "../util/check/typecheck";
41
- import { sphereCoord } from "../util/geometry/index"
42
- const CIRCLE_FLAT_EDGE_COUNT = 362; // 360 + 2 for closing the circle and a cutting point
43
-
44
-
45
-
46
- /**
47
- *
48
- *
49
- * @typedef {string} centerID
50
- *
51
- * @typedef {Object} RangeRing
52
- * @property {string} ringID
53
- * @property {number} radius in range meters
54
- * @property {number} padding badding range in meter
55
- *
56
- *
57
- * Array < centerID: string, long: number, lat: number, stepAngle: number, rgba: [4 numbers], rings: rings, hide, textHide
58
- * @typedef {Object} RangeRingsItem
59
- * @property {centerID} centerID
60
- * @property {number} long
61
- * @property {number} lat
62
- * @property {number} stepAngle
63
- * @property {number} altitude
64
- * @property {number} hide
65
- * @property {number} textHide
66
- * @property {number} rgba
67
- * @property {Array<RangeRing>} rings
68
- */
69
-
70
- class RangeRings {
71
- constructor(id,
72
- {
73
- oneDegreePadding = true, showNumbers = true, numbersStyle = null, opacity = 1, zAlphaOnDegreePadding = Z_ALPHA_MODE.ON
74
- } = {},
75
- {
76
- textDataPreAdaptor = null,
77
- textWritersMap = new Map()
78
- } = {}) {
79
- this.id = id;
80
- this._oneDegreePadding = oneDegreePadding;
81
- this._zAlphaOnDegreePadding = zAlphaOnDegreePadding;
82
- this._showNumbers = showNumbers;
83
- this._numbersStyle = numbersStyle;
84
- this._opacity = opacity;
85
- this._ringAccount = new RingAccount();
86
- this._textWritersMap = textWritersMap;
87
- this._textDataPreAdaptor = textDataPreAdaptor;
88
- this._textWritersMap.forEach((textWriter) => textWriter.setKeyAdaptor((item) => item.__identity__));
89
- }
90
-
91
-
92
- // USER API
93
-
94
- /**
95
- * @method updateCentersCoordinate @param { Array < { centerID, long,lat } >} items
96
- */
97
- updateCentersCoordinate(items, { textWriterIDs = [] } = {}) {
98
- // Algorithm
99
- /**
100
- * 1. ask centerRingAccount for existing rings COORDINATE RELATED KEYS
101
- * 2. update centers
102
- * 3. update buffer orchestators
103
- */
104
-
105
- this._ringAccount.updateCentersCoordinate(items);
106
- const { globe,
107
- bufferOrchestrator, bufferManagersCompMap,
108
- paddingBufferOrchestrator,
109
- bufferManagersCompMapPadding
110
- } = this;
111
- for (const { centerID } of items) {
112
- const datas = this.__reconstructCentralRings(centerID);
113
- bufferOrchestrator.updateBulk(datas, bufferManagersCompMap, ["centerCoords3d", "centerCoords2dflat", "targetCoords3d", "centerCoords2dflatForPadding"]);
114
- const paddingDatas = this.__reconstructCentralRingsBigPaddings(centerID);
115
- paddingBufferOrchestrator.updateBulk(paddingDatas, bufferManagersCompMapPadding, ["circlePoint2d", "paddingPoint2d", "circlePoint3d", "paddingPoint3d"]);
116
- }
117
- this.paddingTextPlugin?.updateCentersXY(items);
118
-
119
- this.__contextTextWriterUpdate(items.map(({ centerID }) => centerID), textWriterIDs);
120
- globe.DrawRender();
121
- }
122
-
123
- /**
124
- * @method insertBulk
125
- * @param { Array < RangeRingsItem> } items
126
- */
127
- insertBulk(items, { textWriterIDs = [] } = {}) {
128
- // Algorithm
129
- /**
130
- * 1 ask centerRingAccount for existing rings
131
- * 2. delete all existing keys with buffer orchestators
132
- * 3. insert new centerRings to centerRingAccount
133
- * 4. insert new keys with buffer orchestators
134
- */
135
- const { globe, _ringAccount, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding } = this;
136
- for (const item of items) {
137
- const existingKeys = _ringAccount.ringKeys(item.centerID);
138
- if (existingKeys.length) {
139
- bufferOrchestrator.deleteBulk(existingKeys, bufferManagersCompMap);
140
- }
141
- const paddingKeys = _ringAccount.ringBigPaddingKeys(item.centerID);
142
- if (paddingKeys.length) {
143
- paddingBufferOrchestrator.deleteBulk(paddingKeys, bufferManagersCompMapPadding);
144
- }
145
- }
146
-
147
- for (const item of items) {
148
- _ringAccount.insertCenter(item);
149
- const datas = this.__reconstructCentralRings(item.centerID);
150
- bufferOrchestrator.insertBulk(datas, bufferManagersCompMap);
151
- const paddingDatas = this.__reconstructCentralRingsBigPaddings(item.centerID);
152
- paddingBufferOrchestrator.insertBulk(paddingDatas, bufferManagersCompMapPadding);
153
- }
154
- this.paddingTextPlugin?.insertBulk(items);
155
- this.__contextTextWriterUpdate(items.map(({ centerID }) => centerID), textWriterIDs);
156
- globe.DrawRender();
157
- }
158
-
159
-
160
-
161
-
162
- /**
163
- * @method updateCentersColor @param { Array < { centerID, rgba: [4 numbers] } >} centerColors
164
- */
165
- updateCentersColor(centerColors, { textWriterIDs = [] } = {}) {
166
- // Algorithm
167
- /**
168
- * 1. ask centerRingAccount for existing rings COLOR KEYS
169
- * 2. update centers
170
- * 3. update buffer orchestators
171
- */
172
- this._ringAccount.updateCentersColor(centerColors);
173
- const { globe,
174
- bufferOrchestrator, bufferManagersCompMap,
175
- paddingBufferOrchestrator, bufferManagersCompMapPadding
176
- } = this;
177
- for (const { centerID } of centerColors) {
178
- const datas = this.__reconstructCentralProperties(centerID);
179
- bufferOrchestrator.updateBulk(datas, bufferManagersCompMap, ["rgba", "rgbaMercator"]);
180
- const paddingDatas = this.__reconstructCentralPaddingProperties(centerID)
181
- paddingBufferOrchestrator.updateBulk(paddingDatas, bufferManagersCompMapPadding, ["rgba"]);
182
- }
183
- this.__contextTextWriterUpdate(centerColors.map(({ centerID }) => centerID), textWriterIDs);
184
- globe.DrawRender();
185
- }
186
-
187
- /**
188
- *
189
- * @method updateCentersHide @param { Array < { centerID, hide, textHide } >} centerHides
190
- */
191
- updateCentersHide(centerHides, { textWriterIDs = [] } = {}) {
192
- // Algorithm
193
- /**
194
- * Simple
195
- * 1. update centers
196
- * 2. reconstruct data,
197
- * 3. update color buffer
198
- * */
199
- this._ringAccount.updateCentersHide(centerHides);
200
- const { globe,
201
- bufferOrchestrator, bufferManagersCompMap,
202
- paddingBufferOrchestrator, bufferManagersCompMapPadding
203
- } = this;
204
-
205
- for (const { centerID } of centerHides) {
206
- const datas = this.__reconstructCentralProperties(centerID);
207
- bufferOrchestrator.updateBulk(datas, bufferManagersCompMap, ["rgba", "rgbaMercator"]);
208
- const paddingDatas0 = this.__reconstructCentralRings(centerID);
209
- bufferOrchestrator.updateBulk(paddingDatas0, bufferManagersCompMap, ["radius3dsmall", "centerCoords2dflatForPadding"]);
210
-
211
- const paddingDatas = this.__reconstructCentralPaddingProperties(centerID)
212
- paddingBufferOrchestrator.updateBulk(paddingDatas, bufferManagersCompMapPadding, ["rgba"]);
213
- }
214
- this.paddingTextPlugin?.updateCentersHide(centerHides);
215
- this.__contextTextWriterUpdate(centerHides.map(({ centerID }) => centerID), textWriterIDs);
216
- globe.DrawRender();
217
- /**
218
- * Complicated
219
- * 1. ask centerRingAccount for existing rings HIDE KEYS
220
- * 2. delete from buffer orchestators
221
- * 3. mark centers as hidden
222
- */
223
- }
224
-
225
-
226
- /**
227
- * @param {Array<string>} textWriterIDs textWritersMap keys to be used for writing text.
228
- * @param {Array<string>} itemKeys if empty, all texts will be updated. Use {@link ringKeyMethod} method to get keys
229
- */
230
- updateText(textWriterIDs = [], itemKeys = null) {
231
- const textWritersMap = textWriterGetOrThrow(this._textWritersMap, textWriterIDs);
232
- if (itemKeys === null) {
233
- this._ringAccount.updateAllText(textWritersMap, this._textDataPreAdaptor);
234
- this.globe.DrawRender();
235
- } else {
236
- itemKeys.forEach((key) => {
237
- const item = this._ringAccount.getCenter(key);
238
- if (item === undefined) throw new Error("Center not found");
239
- const textData = this._textDataPreAdaptor(item);
240
- textWritersMap.forEach((textWriter) => textWriter.insertText(textData));
241
- });
242
- }
243
- this.globe.DrawRender();
244
- }
245
-
246
-
247
-
248
-
249
- /**
250
- * @method removeCenters @param { Array < { centerID } >} centerIDs
251
- */
252
- removeCenters(centerIDs) {
253
- const { globe,
254
- bufferOrchestrator, bufferManagersCompMap,
255
- paddingBufferOrchestrator, bufferManagersCompMapPadding,
256
- _ringAccount } = this;
257
- for (const centerID of centerIDs) {
258
- const existingKeys = _ringAccount.ringKeys(centerID);
259
- if (existingKeys.length) {
260
- bufferOrchestrator.deleteBulk(existingKeys, bufferManagersCompMap);
261
- this._textWritersMap.forEach((textWriter) => textWriter.deleteTextBulk(existingKeys));
262
-
263
- }
264
- }
265
- for (const centerID of centerIDs) {
266
- const paddingKeys = _ringAccount.ringBigPaddingKeys(centerID);
267
- if (paddingKeys.length) {
268
- paddingBufferOrchestrator.deleteBulk(paddingKeys, bufferManagersCompMapPadding);
269
- }
270
- }
271
- this.paddingTextPlugin?.removeCenters(centerIDs);
272
- this._ringAccount.removeCenters(centerIDs);
273
- globe.DrawRender();
274
- }
275
-
276
- /**
277
- * @method setOpacity @param { number } opacity
278
- */
279
- setOpacity(opacity) {
280
- opacityCheck(opacity);
281
- this._opacity = opacity;
282
- this.paddingTextPlugin?.setOpacity(opacity);
283
- this._textWritersMap.forEach((writer) => writer.setOpacity(opacity));
284
- this.globe.DrawRender();
285
- }
286
-
287
-
288
- /**
289
- * @method setOneDegreePaddingOn // performance consuming, might be removed
290
- */
291
- setOneDegreePaddingOn(isOneDegreePaddingOn) {
292
- if (typeof isOneDegreePaddingOn !== "boolean") throw new Error("Invalid value for one degree padding");
293
- if (this._oneDegreePadding === isOneDegreePaddingOn) return;
294
- this._oneDegreePadding = isOneDegreePaddingOn;
295
- this.globe.DrawRender();
296
- }
297
-
298
-
299
- setZAlphaOnDegreePadding(zAlphaOnDegreePadding) {
300
- if (zAlphaOnDegreePadding !== 0 && zAlphaOnDegreePadding !== 1) throw new Error("Invalid value for zAlphaOnDegreePadding");
301
- if (this._zAlphaOnDegreePadding === zAlphaOnDegreePadding) return;
302
- this._zAlphaOnDegreePadding = zAlphaOnDegreePadding;
303
- this.globe.DrawRender();
304
- }
305
-
306
-
307
- // PRIVATE METHODS
308
-
309
- _initPrograms() {
310
- const { globe } = this;
311
- this._circleProgram2D = CircleCache2D.get(globe);
312
- this._circleProgram3D = CircleCache3D.get(globe);
313
- this._padding2dProgram = LinesColorInstancedFlatCache.get(globe);
314
- this._padding3dProgram = CirclePadding3DCache.get(globe);
315
- this._lineOnGlobe_bigPadding = LineOnGlobeCache.get(globe);
316
-
317
- }
318
-
319
-
320
- _initBufferManagers() {
321
- const { gl } = this;
322
-
323
- const initialCapacity = 10;
324
- const bufferType = "DYNAMIC_DRAW";
325
- // circle2d, circle3d, 1 degree paddings,
326
- this.bufferOrchestrator = new BufferOrchestrator({ capacity: initialCapacity });
327
-
328
- this.bufferManagersCompMap = new Map(
329
- [
330
- // circle 3D
331
- ["centerCoords3d", {
332
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
333
- 'adaptor': (item) => new Float32Array(item.centerCoords3d),
334
- }],
335
- ["targetCoords3d", {
336
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
337
- 'adaptor': (item) => new Float32Array(item.targetCoords3d),
338
- }],
339
-
340
- ["rgba", {
341
- 'bufferManager': new BufferManager(gl, 4, { bufferType, initialCapacity }),
342
- 'adaptor': (item) => new Float32Array(item.hide === ENUM_HIDE.HIDE ? [0, 0, 0, 0] : item.rgba)
343
- }],
344
- ["radius3d", {
345
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
346
- 'adaptor': (item) => new Float32Array([item.radius])
347
- }],
348
- ["radius3dsmall", {
349
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
350
- 'adaptor': (item) => {
351
- if (item.hide === ENUM_HIDE.HIDE_1_DEGREE_PADDINGS) return new Float32Array([item.radius]);
352
- return new Float32Array([item.radius - item.padding / 3])
353
- }
354
- }],
355
- ["circleDashAngle", {
356
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
357
- 'adaptor': (item) => new Float32Array([1]),
358
- }],
359
- ["dashOpacity", {
360
- 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
361
- 'adaptor': (item) => new Float32Array([1]),
362
- }],
363
-
364
- // circle 2D
365
- ["centerCoords2dflatForPadding", {
366
- 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT * 2, { bufferType, initialCapacity }),
367
- 'adaptor': (item) => item.centerCoords2dflatForPadding,
368
- }],
369
- ["centerCoords2dflat", {
370
- 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT * 2, { bufferType, initialCapacity }),
371
- 'adaptor': (item) => item.centerCoords2dflat,
372
- }],
373
- ["rgbaMercator", {
374
- 'bufferManager': new BufferManager(gl, 4 * CIRCLE_FLAT_EDGE_COUNT, { bufferType, initialCapacity }),
375
- 'adaptor': (item) => populateFloat32Array.fillWithListData(CIRCLE_FLAT_EDGE_COUNT, item.hide === ENUM_HIDE.HIDE ? [0, 0, 0, 0] : item.rgba),
376
- }],
377
- ["circleDashAngleMercator", {
378
- 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT, { bufferType, initialCapacity }),
379
- 'adaptor': (item) => populateFloat32Array.fillFloat32Array(CIRCLE_FLAT_EDGE_COUNT, 1),
380
- }],
381
- ["dashOpacityMercator", {
382
- 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT, { bufferType, initialCapacity }),
383
- 'adaptor': (item) => populateFloat32Array.fillFloat32Array(CIRCLE_FLAT_EDGE_COUNT, 1),
384
- }],
385
- ]
386
- );
387
-
388
- const obj = function (bufferManagerComp, divisor = 1) {
389
- if (bufferManagerComp === null) return null;
390
- return { 'buffer': bufferManagerComp.bufferManager.buffer, 'stride': 0, 'offset': 0, divisor }
391
-
392
- };
393
- this._circle2DVao = this._circleProgram2D.createVAO(
394
- ...["centerCoords2dflat", "rgbaMercator", "circleDashAngleMercator", "dashOpacityMercator"].map(key => obj(this.bufferManagersCompMap.get(key)))
395
- );
396
-
397
- this._circle3DVao = this._circleProgram3D.createVAO(
398
- ...["centerCoords3d", "targetCoords3d", "rgba", "circleDashAngle", "dashOpacity"].map(key => obj(this.bufferManagersCompMap.get(key)))
399
- );
400
-
401
- this._oneDegree2DPaddingVao = this._padding2dProgram.createVAO(
402
- { buffer: this.bufferManagersCompMap.get("centerCoords2dflat").bufferManager.buffer, size: 2, stride: 0, offset: 0 },
403
- { buffer: this.bufferManagersCompMap.get("centerCoords2dflatForPadding").bufferManager.buffer, size: 2, stride: 0, offset: 0 },
404
- { buffer: this.bufferManagersCompMap.get("rgbaMercator").bufferManager.buffer, size: 4, stride: 0, offset: 0 },
405
- );
406
-
407
- // PADDING
408
- // this one needs glue to assosiate rings and their big paddings since the count for center is not fixed
409
- this.paddingBufferOrchestrator = new BufferOrchestrator({ capacity: initialCapacity });
410
- this.bufferManagersCompMapPadding = new Map(
411
- [
412
- ["circlePoint2d", {
413
- 'bufferManager': new BufferManager(gl, 2, { bufferType, initialCapacity }),
414
- 'adaptor': (item) => item.circlePoint2d,
415
- }],
416
- ["paddingPoint2d", {
417
- 'bufferManager': new BufferManager(gl, 2, { bufferType, initialCapacity }),
418
- 'adaptor': (item) => item.paddingPoint2d,
419
- }],
420
- ["circlePoint3d", {
421
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
422
- 'adaptor': (item) => item.circlePoint3d
423
- }],
424
- ["paddingPoint3d", {
425
- 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
426
- 'adaptor': (item) => item.paddingPoint3d
427
- }],
428
- ["rgba", {
429
- 'bufferManager': new BufferManager(gl, 4, { bufferType, initialCapacity }),
430
- 'adaptor': (item) => new Float32Array(item.rgba)
431
- }],
432
-
433
- // ["dashOpacity", {
434
- // 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
435
- // 'adaptor': (item) => new Float32Array([1]),
436
- // }],
437
- // ["dashRatio", {
438
- // 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
439
- // 'adaptor': (item) => new Float32Array([1]),
440
- // }],
441
- ]
442
- );
443
-
444
- this._bigPadding3dFlatVAO = this._lineOnGlobe_bigPadding.createVAO(//"dashRatio", "dashOpacity"
445
- ...["circlePoint2d", "circlePoint3d", "paddingPoint2d", "paddingPoint3d", null, null, "rgba",].map(key =>
446
- (key === null) ? null : obj(this.bufferManagersCompMapPadding.get(key)))
447
- );
448
-
449
- this._padding3dOneDegreeVao = this._padding3dProgram.createVAO(
450
- ...["centerCoords3d", "radius3d", "radius3dsmall", "rgba"].map(key => obj(this.bufferManagersCompMap.get(key)))
451
- );
452
-
453
-
454
-
455
- }
456
-
457
- // IMPLICIT METHODS
458
-
459
- __reconstructCentralRingsBigPaddings(centerID) {
460
- const { globe } = this;
461
- const centerItem = this._ringAccount.getCenter(centerID);
462
- if (centerItem === undefined) throw new Error("Center not found");
463
- const { long, lat, stepAngle, rgba, rings, hide = 0, textHide = 0, altitude: centerAltitude = 0 } = centerItem;
464
- const result = [];
465
- const color = hide === 1 ? new Float32Array([0, 0, 0, 0]) : new Float32Array(rgba)
466
- for (const { ringID, radius, padding, altitude = centerAltitude } of rings) {
467
- let azimuthAngle = 0;
468
- while (azimuthAngle < 360) {
469
- const circlePoint = globe.Math.FindPointByPolar(long, lat, radius, azimuthAngle); // long lat
470
- const paddingPoint = globe.Math.FindPointByPolar(long, lat, radius - padding, azimuthAngle); // long lat
471
- result.push({
472
- key: ringBigPaddingKeyMethod(centerID, ringID, azimuthAngle),
473
- circlePoint2d: new Float32Array(globe.api_GetMercator2DPoint(circlePoint.long, circlePoint.lat)),
474
- paddingPoint2d: new Float32Array(globe.api_GetMercator2DPoint(paddingPoint.long, paddingPoint.lat)),
475
- circlePoint3d: sphereCoord(circlePoint.long, circlePoint.lat, globe, altitude / 1000),
476
- paddingPoint3d: sphereCoord(paddingPoint.long, paddingPoint.lat, globe, altitude / 1000),
477
- rgba: color,
478
- hide,
479
- textHide
480
- });
481
- azimuthAngle += stepAngle;
482
-
483
- }
484
- }
485
- return result;
486
- }
487
-
488
-
489
- __reconstructCentralRings(centerID) {
490
- const { globe } = this;
491
- const centerItem = this._ringAccount.getCenter(centerID);
492
- if (centerItem === undefined) throw new Error("Center not found");
493
-
494
- const { long, lat, rgba, rings, hide = 0, textHide = 0, altitude: centralAltitude = 0 } = centerItem;
495
- const centerCoords3d = sphereCoord(long, lat, globe, centralAltitude / 1000);
496
-
497
- const result = [];
498
-
499
- for (const { ringID, radius, padding, __identity__, altitude = centralAltitude } of rings) {
500
- const key = __identity__;
501
-
502
- const centerCoords2dflat = centerCoords2dflatDataCreatorWithRadius(globe, long, lat, radius, { edgeCount: CIRCLE_FLAT_EDGE_COUNT });
503
- const radiusPadding = hide === ENUM_HIDE.HIDE_1_DEGREE_PADDINGS ? radius : radius - padding / 3;
504
- const targetPoint = globe.Math.FindPointByPolar(long, lat, radius, 0); // long lat
505
- const targetCoords3d = sphereCoord(targetPoint.long, targetPoint.lat, globe, altitude / 1000);
506
- const centerCoords2dflatForPadding = centerCoords2dflatDataCreatorWithRadius(globe, long, lat, radiusPadding, { edgeCount: CIRCLE_FLAT_EDGE_COUNT });
507
- result.push({
508
- key,
509
- centerCoords3d,
510
- targetCoords3d,
511
- centerCoords2dflat,
512
- radius,
513
- padding,
514
- rgba,
515
- centerCoords2dflatForPadding,
516
- hide,
517
- textHide
518
- });
519
- }
520
- return result;
521
-
522
- }
523
-
524
- __reconstructCentralPaddingProperties(centerID) {
525
- const centerItem = this._ringAccount.getCenter(centerID);
526
- if (centerItem === undefined) throw new Error("Center not found");
527
- const { stepAngle, rgba, rings, hide = 0, textHide = 0 } = centerItem;
528
- const result = [];
529
- for (const { ringID, } of rings) {
530
- let angle = 0;
531
- while (angle < 360) {
532
- result.push({
533
- key: ringBigPaddingKeyMethod(centerID, ringID, angle),
534
- rgba: hide === 1 ? new Float32Array([0, 0, 0, 0]) : rgba,
535
- textHide
536
- });
537
- angle += stepAngle;
538
- }
539
- }
540
- return result;
541
- }
542
-
543
- __reconstructCentralProperties(centerID) {
544
- const centerItem = this._ringAccount.getCenter(centerID);
545
- if (centerItem === undefined) throw new Error("Center not found");
546
- const { rgba, rings, hide = 0, textHide = 0 } = centerItem;
547
- const result = [];
548
- for (const { ringID, __identity__ } of rings) {
549
- const key = __identity__;
550
- result.push({
551
- key,
552
- rgba: hide === ENUM_HIDE.HIDE ? new Float32Array([0, 0, 0, 0]) : rgba,
553
- textHide
554
- });
555
- }
556
- return result;
557
- }
558
-
559
-
560
-
561
- // GLOBE API
562
-
563
-
564
- init(globe, gl) {
565
- this.globe = globe;
566
- this.gl = gl;
567
- this._initPrograms();
568
- this._initBufferManagers();
569
- if (this._showNumbers) {
570
- this.paddingTextPlugin = new RangeRingAngleText(globe, this.id + "text", { style: this._numbersStyle, opacity: this._opacity });
571
- delete this._numbersStyle;
572
- }
573
- }
574
-
575
-
576
-
577
- draw3D() {
578
- const {
579
- globe, gl,
580
- _circleProgram2D, _circleProgram3D, _padding2dProgram, _padding3dProgram, _lineOnGlobe_bigPadding,
581
- _circle2DVao, _circle3DVao, _oneDegree2DPaddingVao, _padding3dOneDegreeVao, _bigPadding3dFlatVAO,
582
- bufferOrchestrator, paddingBufferOrchestrator,
583
- _opacity, _oneDegreePadding, _zAlphaOnDegreePadding } = this;
584
- gl.disable(gl.DEPTH_TEST);
585
- const is3D = globe.api_GetCurrentGeometry() === 0;
586
- // const lod = globe.api_GetCurrentLOD();
587
- if (is3D) {
588
- _circleProgram3D.draw(_circle3DVao, bufferOrchestrator.length, _opacity);
589
- if (_oneDegreePadding) _padding3dProgram.draw(_padding3dOneDegreeVao, bufferOrchestrator.length, 360, 1, _opacity, _zAlphaOnDegreePadding);
590
- } else {
591
- _circleProgram2D.draw(_circle2DVao, bufferOrchestrator.length, CIRCLE_FLAT_EDGE_COUNT, _opacity);
592
- // _padding2dProgram.draw(bigPaddingVAO, paddingBufferOrchestrator.length, _opacity);
593
- if (_oneDegreePadding) _padding2dProgram.draw(_oneDegree2DPaddingVao, bufferOrchestrator.length * CIRCLE_FLAT_EDGE_COUNT, _opacity, _zAlphaOnDegreePadding);
594
- }
595
- const drawOptions = { drawRange: { first: 0, count: paddingBufferOrchestrator.length } };
596
- _lineOnGlobe_bigPadding.draw(_bigPadding3dFlatVAO, drawOptions, _opacity);
597
- this._textWritersMap.forEach((textWriter) => textWriter.draw());
598
- gl.enable(gl.DEPTH_TEST);
599
- }
600
-
601
- free() {
602
- if (this._isFreed) return;
603
- const { globe } = this;
604
- this.bufferManagersCompMap.forEach(({ bufferManager }) => bufferManager.free());
605
- this.bufferManagersCompMapPadding.forEach(({ bufferManager }) => bufferManager.free());
606
- // delete vaos
607
- this.gl.deleteVertexArray(this._circle2DVao);
608
- this.gl.deleteVertexArray(this._circle3DVao);
609
- this.gl.deleteVertexArray(this._oneDegree2DPaddingVao);
610
- this.gl.deleteVertexArray(this._padding3dOneDegreeVao);
611
- this.gl.deleteVertexArray(this._bigPadding3dFlatVAO);
612
- // delete programs
613
- CircleCache2D.release(globe);
614
- CircleCache3D.release(globe);
615
- LinesColorInstancedFlatCache.release(globe);
616
- CirclePadding3DCache.release(globe);
617
- LineOnGlobeCache.release(globe);
618
- this._circleProgram2D = null;
619
- this._circleProgram3D = null;
620
- this._padding2dProgram = null;
621
- this._padding3dProgram = null;
622
- this._lineOnGlobe_bigPadding = null;
623
- this.paddingTextPlugin?.free();
624
- this._isFreed = true;
625
- }
626
-
627
-
628
- __contextTextWriterUpdate(centerIDs, textWriterIDs = null) {
629
- let textWriters = null;
630
- if (textWriterIDs === null) {
631
- textWriters = Array.from(this._textWritersMap.values());
632
- } else if (textWriterIDs.length === 0) {
633
- return
634
- } else {
635
- textWriters = textWriterGetOrThrow(this._textWritersMap, textWriterIDs);
636
- }
637
- centerIDs.forEach((centerID) => { this._ringAccount.textUpdate(centerID, textWriters, this._textDataPreAdaptor); });
638
- }
639
- }
640
-
641
-
642
- const textWriterGetOrThrow = mapGetOrThrow("textWriterIDs is invalid")
643
-
644
- export { RangeRings, Z_ALPHA_MODE };
1
+ /**
2
+ * @typedef RangeRingData
3
+ * @property {number} centerX
4
+ * @property {number} centerY
5
+ * @property {Array<Ring>} rings
6
+ *
7
+ * @typedef Ring
8
+ * @property {number} radius
9
+ * @property {number} padding
10
+ * @property {[number, number, number]} color
11
+ *
12
+ *
13
+ * @method insertBulk
14
+ * @typedef {Array<{ringID, radius, padding}>} rings
15
+ * @param {Array<centerID:string, x:number, y:number, stepAngle:number, rgba:[4 numbers], rings:rings} items
16
+
17
+ * @method updateCentersCoordinate @param {Array<{centerID, long,lat}>} items
18
+ * @method updateCentersColor @param {Array<{centerID, rgba:[4 numbers]}>} centerColors
19
+ *
20
+ * @method updateCentersHide @param {Array<{centerID, hide, textHide}>} centerHides
21
+ * @method removeCenters @param {Array<{centerID}>} centerIds
22
+ * @method setOpacity @param {number} opacity
23
+ *
24
+ * @method setOneDegreePaddingOn // performance consuming, might be removed
25
+ *
26
+ */
27
+ import { centerCoords2dflatDataCreatorWithRadius, CircleCache as CircleCache2D } from "../programs/line-on-globe/circle-accurate-flat";
28
+ import { CircleCache as CircleCache3D } from "../programs/line-on-globe/circle-accurate-3d";
29
+ import { LinesColorInstancedFlatCache } from "../programs/line-on-globe/lines-color-instanced-flat";
30
+ import { BufferOrchestrator, BufferManager } from "../util/account";
31
+ // import { mapGetOrThrow } from "../util/check/get";
32
+ import { populateFloat32Array } from "../util/jshelpers/data-filler";
33
+ import { RingAccount, ringBigPaddingKeyMethod, ringKeyMethod } from "./ring-account";
34
+ import { CirclePadding3DCache } from "../programs/line-on-globe/degree-padding-around-circle-3d";
35
+ import { LineOnGlobeCache } from '../programs/line-on-globe/naive-accurate-flexible';
36
+ import RangeRingAngleText from "./rangeringangletext";
37
+ import { Z_ALPHA_MODE } from "../programs/line-on-globe/util";
38
+ import { ENUM_HIDE } from "./enum";
39
+ import { opacityCheck, mapGetOrThrow } from "../util/check/typecheck";
40
+ import { sphereCoord } from "../util/geometry/index";
41
+ const CIRCLE_FLAT_EDGE_COUNT = 362; // 360 + 2 for closing the circle and a cutting point
42
+ /**
43
+ *
44
+ *
45
+ * @typedef {string} centerID
46
+ *
47
+ * @typedef {Object} RangeRing
48
+ * @property {string} ringID
49
+ * @property {number} radius in range meters
50
+ * @property {number} padding badding range in meter
51
+ *
52
+ *
53
+ * Array < centerID: string, long: number, lat: number, stepAngle: number, rgba: [4 numbers], rings: rings, hide, textHide
54
+ * @typedef {Object} RangeRingsItem
55
+ * @property {centerID} centerID
56
+ * @property {number} long
57
+ * @property {number} lat
58
+ * @property {number} stepAngle
59
+ * @property {number} altitude
60
+ * @property {number} hide
61
+ * @property {number} textHide
62
+ * @property {number} rgba
63
+ * @property {Array<RangeRing>} rings
64
+ */
65
+ class RangeRings {
66
+ constructor(id, { oneDegreePadding = true, showNumbers = true, numbersStyle = null, opacity = 1, zAlphaOnDegreePadding = Z_ALPHA_MODE.ON } = {}, { textDataPreAdaptor = null, textWritersMap = new Map() } = {}) {
67
+ this.id = id;
68
+ this._oneDegreePadding = oneDegreePadding;
69
+ this._zAlphaOnDegreePadding = zAlphaOnDegreePadding;
70
+ this._showNumbers = showNumbers;
71
+ this._numbersStyle = numbersStyle;
72
+ this._opacity = opacity;
73
+ this._ringAccount = new RingAccount();
74
+ this._textWritersMap = textWritersMap;
75
+ this._textDataPreAdaptor = textDataPreAdaptor;
76
+ this._textWritersMap.forEach((textWriter) => textWriter.setKeyAdaptor((item) => item.__identity__));
77
+ }
78
+ // USER API
79
+ /**
80
+ * @method updateCentersCoordinate @param { Array < { centerID, long,lat } >} items
81
+ */
82
+ updateCentersCoordinate(items, { textWriterIDs = [] } = {}) {
83
+ // Algorithm
84
+ /**
85
+ * 1. ask centerRingAccount for existing rings COORDINATE RELATED KEYS
86
+ * 2. update centers
87
+ * 3. update buffer orchestators
88
+ */
89
+ this._ringAccount.updateCentersCoordinate(items);
90
+ const { globe, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding } = this;
91
+ for (const { centerID } of items) {
92
+ const datas = this.__reconstructCentralRings(centerID);
93
+ bufferOrchestrator.updateBulk(datas, bufferManagersCompMap, ["centerCoords3d", "centerCoords2dflat", "targetCoords3d", "centerCoords2dflatForPadding"]);
94
+ const paddingDatas = this.__reconstructCentralRingsBigPaddings(centerID);
95
+ paddingBufferOrchestrator.updateBulk(paddingDatas, bufferManagersCompMapPadding, ["circlePoint2d", "paddingPoint2d", "circlePoint3d", "paddingPoint3d"]);
96
+ }
97
+ this.paddingTextPlugin?.updateCentersXY(items);
98
+ this.__contextTextWriterUpdate(items.map(({ centerID }) => centerID), textWriterIDs);
99
+ globe.DrawRender();
100
+ }
101
+ /**
102
+ * @method insertBulk
103
+ * @param { Array < RangeRingsItem> } items
104
+ */
105
+ insertBulk(items, { textWriterIDs = [] } = {}) {
106
+ // Algorithm
107
+ /**
108
+ * 1 ask centerRingAccount for existing rings
109
+ * 2. delete all existing keys with buffer orchestators
110
+ * 3. insert new centerRings to centerRingAccount
111
+ * 4. insert new keys with buffer orchestators
112
+ */
113
+ const { globe, _ringAccount, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding } = this;
114
+ for (const item of items) {
115
+ const existingKeys = _ringAccount.ringKeys(item.centerID);
116
+ if (existingKeys.length) {
117
+ bufferOrchestrator.deleteBulk(existingKeys, bufferManagersCompMap);
118
+ }
119
+ const paddingKeys = _ringAccount.ringBigPaddingKeys(item.centerID);
120
+ if (paddingKeys.length) {
121
+ paddingBufferOrchestrator.deleteBulk(paddingKeys, bufferManagersCompMapPadding);
122
+ }
123
+ }
124
+ for (const item of items) {
125
+ _ringAccount.insertCenter(item);
126
+ const datas = this.__reconstructCentralRings(item.centerID);
127
+ bufferOrchestrator.insertBulk(datas, bufferManagersCompMap);
128
+ const paddingDatas = this.__reconstructCentralRingsBigPaddings(item.centerID);
129
+ paddingBufferOrchestrator.insertBulk(paddingDatas, bufferManagersCompMapPadding);
130
+ }
131
+ this.paddingTextPlugin?.insertBulk(items);
132
+ this.__contextTextWriterUpdate(items.map(({ centerID }) => centerID), textWriterIDs);
133
+ globe.DrawRender();
134
+ }
135
+ /**
136
+ * @method updateCentersColor @param { Array < { centerID, rgba: [4 numbers] } >} centerColors
137
+ */
138
+ updateCentersColor(centerColors, { textWriterIDs = [] } = {}) {
139
+ // Algorithm
140
+ /**
141
+ * 1. ask centerRingAccount for existing rings COLOR KEYS
142
+ * 2. update centers
143
+ * 3. update buffer orchestators
144
+ */
145
+ this._ringAccount.updateCentersColor(centerColors);
146
+ const { globe, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding } = this;
147
+ for (const { centerID } of centerColors) {
148
+ const datas = this.__reconstructCentralProperties(centerID);
149
+ bufferOrchestrator.updateBulk(datas, bufferManagersCompMap, ["rgba", "rgbaMercator"]);
150
+ const paddingDatas = this.__reconstructCentralPaddingProperties(centerID);
151
+ paddingBufferOrchestrator.updateBulk(paddingDatas, bufferManagersCompMapPadding, ["rgba"]);
152
+ }
153
+ this.__contextTextWriterUpdate(centerColors.map(({ centerID }) => centerID), textWriterIDs);
154
+ globe.DrawRender();
155
+ }
156
+ /**
157
+ *
158
+ * @method updateCentersHide @param { Array < { centerID, hide, textHide } >} centerHides
159
+ */
160
+ updateCentersHide(centerHides, { textWriterIDs = [] } = {}) {
161
+ // Algorithm
162
+ /**
163
+ * Simple
164
+ * 1. update centers
165
+ * 2. reconstruct data,
166
+ * 3. update color buffer
167
+ * */
168
+ this._ringAccount.updateCentersHide(centerHides);
169
+ const { globe, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding } = this;
170
+ for (const { centerID } of centerHides) {
171
+ const datas = this.__reconstructCentralProperties(centerID);
172
+ bufferOrchestrator.updateBulk(datas, bufferManagersCompMap, ["rgba", "rgbaMercator"]);
173
+ const paddingDatas0 = this.__reconstructCentralRings(centerID);
174
+ bufferOrchestrator.updateBulk(paddingDatas0, bufferManagersCompMap, ["radius3dsmall", "centerCoords2dflatForPadding"]);
175
+ const paddingDatas = this.__reconstructCentralPaddingProperties(centerID);
176
+ paddingBufferOrchestrator.updateBulk(paddingDatas, bufferManagersCompMapPadding, ["rgba"]);
177
+ }
178
+ this.paddingTextPlugin?.updateCentersHide(centerHides);
179
+ this.__contextTextWriterUpdate(centerHides.map(({ centerID }) => centerID), textWriterIDs);
180
+ globe.DrawRender();
181
+ /**
182
+ * Complicated
183
+ * 1. ask centerRingAccount for existing rings HIDE KEYS
184
+ * 2. delete from buffer orchestators
185
+ * 3. mark centers as hidden
186
+ */
187
+ }
188
+ /**
189
+ * @param {Array<string>} textWriterIDs textWritersMap keys to be used for writing text.
190
+ * @param {Array<string>} itemKeys if empty, all texts will be updated. Use {@link ringKeyMethod} method to get keys
191
+ */
192
+ updateText(textWriterIDs = [], itemKeys = null) {
193
+ const textWritersMap = textWriterGetOrThrow(this._textWritersMap, textWriterIDs);
194
+ if (itemKeys === null) {
195
+ this._ringAccount.updateAllText(textWritersMap, this._textDataPreAdaptor);
196
+ this.globe.DrawRender();
197
+ }
198
+ else {
199
+ itemKeys.forEach((key) => {
200
+ const item = this._ringAccount.getCenter(key);
201
+ if (item === undefined)
202
+ throw new Error("Center not found");
203
+ const textData = this._textDataPreAdaptor(item);
204
+ textWritersMap.forEach((textWriter) => textWriter.insertText(textData));
205
+ });
206
+ }
207
+ this.globe.DrawRender();
208
+ }
209
+ /**
210
+ * @method removeCenters @param { Array < { centerID } >} centerIDs
211
+ */
212
+ removeCenters(centerIDs) {
213
+ const { globe, bufferOrchestrator, bufferManagersCompMap, paddingBufferOrchestrator, bufferManagersCompMapPadding, _ringAccount } = this;
214
+ for (const centerID of centerIDs) {
215
+ const existingKeys = _ringAccount.ringKeys(centerID);
216
+ if (existingKeys.length) {
217
+ bufferOrchestrator.deleteBulk(existingKeys, bufferManagersCompMap);
218
+ this._textWritersMap.forEach((textWriter) => textWriter.deleteTextBulk(existingKeys));
219
+ }
220
+ }
221
+ for (const centerID of centerIDs) {
222
+ const paddingKeys = _ringAccount.ringBigPaddingKeys(centerID);
223
+ if (paddingKeys.length) {
224
+ paddingBufferOrchestrator.deleteBulk(paddingKeys, bufferManagersCompMapPadding);
225
+ }
226
+ }
227
+ this.paddingTextPlugin?.removeCenters(centerIDs);
228
+ this._ringAccount.removeCenters(centerIDs);
229
+ globe.DrawRender();
230
+ }
231
+ /**
232
+ * @method setOpacity @param { number } opacity
233
+ */
234
+ setOpacity(opacity) {
235
+ opacityCheck(opacity);
236
+ this._opacity = opacity;
237
+ this.paddingTextPlugin?.setOpacity(opacity);
238
+ this._textWritersMap.forEach((writer) => writer.setOpacity(opacity));
239
+ this.globe.DrawRender();
240
+ }
241
+ /**
242
+ * @method setOneDegreePaddingOn // performance consuming, might be removed
243
+ */
244
+ setOneDegreePaddingOn(isOneDegreePaddingOn) {
245
+ if (typeof isOneDegreePaddingOn !== "boolean")
246
+ throw new Error("Invalid value for one degree padding");
247
+ if (this._oneDegreePadding === isOneDegreePaddingOn)
248
+ return;
249
+ this._oneDegreePadding = isOneDegreePaddingOn;
250
+ this.globe.DrawRender();
251
+ }
252
+ setZAlphaOnDegreePadding(zAlphaOnDegreePadding) {
253
+ if (zAlphaOnDegreePadding !== 0 && zAlphaOnDegreePadding !== 1)
254
+ throw new Error("Invalid value for zAlphaOnDegreePadding");
255
+ if (this._zAlphaOnDegreePadding === zAlphaOnDegreePadding)
256
+ return;
257
+ this._zAlphaOnDegreePadding = zAlphaOnDegreePadding;
258
+ this.globe.DrawRender();
259
+ }
260
+ // PRIVATE METHODS
261
+ _initPrograms() {
262
+ const { globe } = this;
263
+ this._circleProgram2D = CircleCache2D.get(globe);
264
+ this._circleProgram3D = CircleCache3D.get(globe);
265
+ this._padding2dProgram = LinesColorInstancedFlatCache.get(globe);
266
+ this._padding3dProgram = CirclePadding3DCache.get(globe);
267
+ this._lineOnGlobe_bigPadding = LineOnGlobeCache.get(globe);
268
+ }
269
+ _initBufferManagers() {
270
+ const { gl } = this;
271
+ const initialCapacity = 10;
272
+ const bufferType = "DYNAMIC_DRAW";
273
+ // circle2d, circle3d, 1 degree paddings,
274
+ this.bufferOrchestrator = new BufferOrchestrator({ capacity: initialCapacity });
275
+ this.bufferManagersCompMap = new Map([
276
+ // circle 3D
277
+ ["centerCoords3d", {
278
+ 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
279
+ 'adaptor': (item) => new Float32Array(item.centerCoords3d),
280
+ }],
281
+ ["targetCoords3d", {
282
+ 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
283
+ 'adaptor': (item) => new Float32Array(item.targetCoords3d),
284
+ }],
285
+ ["rgba", {
286
+ 'bufferManager': new BufferManager(gl, 4, { bufferType, initialCapacity }),
287
+ 'adaptor': (item) => new Float32Array(item.hide === ENUM_HIDE.HIDE ? [0, 0, 0, 0] : item.rgba)
288
+ }],
289
+ ["radius3d", {
290
+ 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
291
+ 'adaptor': (item) => new Float32Array([item.radius])
292
+ }],
293
+ ["radius3dsmall", {
294
+ 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
295
+ 'adaptor': (item) => {
296
+ if (item.hide === ENUM_HIDE.HIDE_1_DEGREE_PADDINGS)
297
+ return new Float32Array([item.radius]);
298
+ return new Float32Array([item.radius - item.padding / 3]);
299
+ }
300
+ }],
301
+ ["circleDashAngle", {
302
+ 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
303
+ 'adaptor': (item) => new Float32Array([1]),
304
+ }],
305
+ ["dashOpacity", {
306
+ 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
307
+ 'adaptor': (item) => new Float32Array([1]),
308
+ }],
309
+ // circle 2D
310
+ ["centerCoords2dflatForPadding", {
311
+ 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT * 2, { bufferType, initialCapacity }),
312
+ 'adaptor': (item) => item.centerCoords2dflatForPadding,
313
+ }],
314
+ ["centerCoords2dflat", {
315
+ 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT * 2, { bufferType, initialCapacity }),
316
+ 'adaptor': (item) => item.centerCoords2dflat,
317
+ }],
318
+ ["rgbaMercator", {
319
+ 'bufferManager': new BufferManager(gl, 4 * CIRCLE_FLAT_EDGE_COUNT, { bufferType, initialCapacity }),
320
+ 'adaptor': (item) => populateFloat32Array.fillWithListData(CIRCLE_FLAT_EDGE_COUNT, item.hide === ENUM_HIDE.HIDE ? [0, 0, 0, 0] : item.rgba),
321
+ }],
322
+ ["circleDashAngleMercator", {
323
+ 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT, { bufferType, initialCapacity }),
324
+ 'adaptor': (item) => populateFloat32Array.fillFloat32Array(CIRCLE_FLAT_EDGE_COUNT, 1),
325
+ }],
326
+ ["dashOpacityMercator", {
327
+ 'bufferManager': new BufferManager(gl, CIRCLE_FLAT_EDGE_COUNT, { bufferType, initialCapacity }),
328
+ 'adaptor': (item) => populateFloat32Array.fillFloat32Array(CIRCLE_FLAT_EDGE_COUNT, 1),
329
+ }],
330
+ ]);
331
+ const obj = function (bufferManagerComp, divisor = 1) {
332
+ if (bufferManagerComp === null)
333
+ return null;
334
+ return { 'buffer': bufferManagerComp.bufferManager.buffer, 'stride': 0, 'offset': 0, divisor };
335
+ };
336
+ this._circle2DVao = this._circleProgram2D.createVAO(...["centerCoords2dflat", "rgbaMercator", "circleDashAngleMercator", "dashOpacityMercator"].map(key => obj(this.bufferManagersCompMap.get(key))));
337
+ this._circle3DVao = this._circleProgram3D.createVAO(...["centerCoords3d", "targetCoords3d", "rgba", "circleDashAngle", "dashOpacity"].map(key => obj(this.bufferManagersCompMap.get(key))));
338
+ this._oneDegree2DPaddingVao = this._padding2dProgram.createVAO({ buffer: this.bufferManagersCompMap.get("centerCoords2dflat").bufferManager.buffer, size: 2, stride: 0, offset: 0 }, { buffer: this.bufferManagersCompMap.get("centerCoords2dflatForPadding").bufferManager.buffer, size: 2, stride: 0, offset: 0 }, { buffer: this.bufferManagersCompMap.get("rgbaMercator").bufferManager.buffer, size: 4, stride: 0, offset: 0 });
339
+ // PADDING
340
+ // this one needs glue to assosiate rings and their big paddings since the count for center is not fixed
341
+ this.paddingBufferOrchestrator = new BufferOrchestrator({ capacity: initialCapacity });
342
+ this.bufferManagersCompMapPadding = new Map([
343
+ ["circlePoint2d", {
344
+ 'bufferManager': new BufferManager(gl, 2, { bufferType, initialCapacity }),
345
+ 'adaptor': (item) => item.circlePoint2d,
346
+ }],
347
+ ["paddingPoint2d", {
348
+ 'bufferManager': new BufferManager(gl, 2, { bufferType, initialCapacity }),
349
+ 'adaptor': (item) => item.paddingPoint2d,
350
+ }],
351
+ ["circlePoint3d", {
352
+ 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
353
+ 'adaptor': (item) => item.circlePoint3d
354
+ }],
355
+ ["paddingPoint3d", {
356
+ 'bufferManager': new BufferManager(gl, 3, { bufferType, initialCapacity }),
357
+ 'adaptor': (item) => item.paddingPoint3d
358
+ }],
359
+ ["rgba", {
360
+ 'bufferManager': new BufferManager(gl, 4, { bufferType, initialCapacity }),
361
+ 'adaptor': (item) => new Float32Array(item.rgba)
362
+ }],
363
+ // ["dashOpacity", {
364
+ // 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
365
+ // 'adaptor': (item) => new Float32Array([1]),
366
+ // }],
367
+ // ["dashRatio", {
368
+ // 'bufferManager': new BufferManager(gl, 1, { bufferType, initialCapacity }),
369
+ // 'adaptor': (item) => new Float32Array([1]),
370
+ // }],
371
+ ]);
372
+ this._bigPadding3dFlatVAO = this._lineOnGlobe_bigPadding.createVAO(//"dashRatio", "dashOpacity"
373
+ ...["circlePoint2d", "circlePoint3d", "paddingPoint2d", "paddingPoint3d", null, null, "rgba",].map(key => (key === null) ? null : obj(this.bufferManagersCompMapPadding.get(key))));
374
+ this._padding3dOneDegreeVao = this._padding3dProgram.createVAO(...["centerCoords3d", "radius3d", "radius3dsmall", "rgba"].map(key => obj(this.bufferManagersCompMap.get(key))));
375
+ }
376
+ // IMPLICIT METHODS
377
+ __reconstructCentralRingsBigPaddings(centerID) {
378
+ const { globe } = this;
379
+ const centerItem = this._ringAccount.getCenter(centerID);
380
+ if (centerItem === undefined)
381
+ throw new Error("Center not found");
382
+ const { long, lat, stepAngle, rgba, rings, hide = 0, textHide = 0, altitude: centerAltitude = 0 } = centerItem;
383
+ const result = [];
384
+ const color = hide === 1 ? new Float32Array([0, 0, 0, 0]) : new Float32Array(rgba);
385
+ for (const { ringID, radius, padding, altitude = centerAltitude } of rings) {
386
+ let azimuthAngle = 0;
387
+ while (azimuthAngle < 360) {
388
+ const circlePoint = globe.Math.FindPointByPolar(long, lat, radius, azimuthAngle); // long lat
389
+ const paddingPoint = globe.Math.FindPointByPolar(long, lat, radius - padding, azimuthAngle); // long lat
390
+ result.push({
391
+ key: ringBigPaddingKeyMethod(centerID, ringID, azimuthAngle),
392
+ circlePoint2d: new Float32Array(globe.api_GetMercator2DPoint(circlePoint.long, circlePoint.lat)),
393
+ paddingPoint2d: new Float32Array(globe.api_GetMercator2DPoint(paddingPoint.long, paddingPoint.lat)),
394
+ circlePoint3d: sphereCoord(circlePoint.long, circlePoint.lat, globe, altitude / 1000),
395
+ paddingPoint3d: sphereCoord(paddingPoint.long, paddingPoint.lat, globe, altitude / 1000),
396
+ rgba: color,
397
+ hide,
398
+ textHide
399
+ });
400
+ azimuthAngle += stepAngle;
401
+ }
402
+ }
403
+ return result;
404
+ }
405
+ __reconstructCentralRings(centerID) {
406
+ const { globe } = this;
407
+ const centerItem = this._ringAccount.getCenter(centerID);
408
+ if (centerItem === undefined)
409
+ throw new Error("Center not found");
410
+ const { long, lat, rgba, rings, hide = 0, textHide = 0, altitude: centralAltitude = 0 } = centerItem;
411
+ const centerCoords3d = sphereCoord(long, lat, globe, centralAltitude / 1000);
412
+ const result = [];
413
+ for (const { ringID, radius, padding, __identity__, altitude = centralAltitude } of rings) {
414
+ const key = __identity__;
415
+ const centerCoords2dflat = centerCoords2dflatDataCreatorWithRadius(globe, long, lat, radius, { edgeCount: CIRCLE_FLAT_EDGE_COUNT });
416
+ const radiusPadding = hide === ENUM_HIDE.HIDE_1_DEGREE_PADDINGS ? radius : radius - padding / 3;
417
+ const targetPoint = globe.Math.FindPointByPolar(long, lat, radius, 0); // long lat
418
+ const targetCoords3d = sphereCoord(targetPoint.long, targetPoint.lat, globe, altitude / 1000);
419
+ const centerCoords2dflatForPadding = centerCoords2dflatDataCreatorWithRadius(globe, long, lat, radiusPadding, { edgeCount: CIRCLE_FLAT_EDGE_COUNT });
420
+ result.push({
421
+ key,
422
+ centerCoords3d,
423
+ targetCoords3d,
424
+ centerCoords2dflat,
425
+ radius,
426
+ padding,
427
+ rgba,
428
+ centerCoords2dflatForPadding,
429
+ hide,
430
+ textHide
431
+ });
432
+ }
433
+ return result;
434
+ }
435
+ __reconstructCentralPaddingProperties(centerID) {
436
+ const centerItem = this._ringAccount.getCenter(centerID);
437
+ if (centerItem === undefined)
438
+ throw new Error("Center not found");
439
+ const { stepAngle, rgba, rings, hide = 0, textHide = 0 } = centerItem;
440
+ const result = [];
441
+ for (const { ringID, } of rings) {
442
+ let angle = 0;
443
+ while (angle < 360) {
444
+ result.push({
445
+ key: ringBigPaddingKeyMethod(centerID, ringID, angle),
446
+ rgba: hide === 1 ? new Float32Array([0, 0, 0, 0]) : rgba,
447
+ textHide
448
+ });
449
+ angle += stepAngle;
450
+ }
451
+ }
452
+ return result;
453
+ }
454
+ __reconstructCentralProperties(centerID) {
455
+ const centerItem = this._ringAccount.getCenter(centerID);
456
+ if (centerItem === undefined)
457
+ throw new Error("Center not found");
458
+ const { rgba, rings, hide = 0, textHide = 0 } = centerItem;
459
+ const result = [];
460
+ for (const { ringID, __identity__ } of rings) {
461
+ const key = __identity__;
462
+ result.push({
463
+ key,
464
+ rgba: hide === ENUM_HIDE.HIDE ? new Float32Array([0, 0, 0, 0]) : rgba,
465
+ textHide
466
+ });
467
+ }
468
+ return result;
469
+ }
470
+ // GLOBE API
471
+ init(globe, gl) {
472
+ this.globe = globe;
473
+ this.gl = gl;
474
+ this._initPrograms();
475
+ this._initBufferManagers();
476
+ if (this._showNumbers) {
477
+ this.paddingTextPlugin = new RangeRingAngleText(globe, this.id + "text", { style: this._numbersStyle, opacity: this._opacity });
478
+ delete this._numbersStyle;
479
+ }
480
+ }
481
+ draw3D() {
482
+ const { globe, gl, _circleProgram2D, _circleProgram3D, _padding2dProgram, _padding3dProgram, _lineOnGlobe_bigPadding, _circle2DVao, _circle3DVao, _oneDegree2DPaddingVao, _padding3dOneDegreeVao, _bigPadding3dFlatVAO, bufferOrchestrator, paddingBufferOrchestrator, _opacity, _oneDegreePadding, _zAlphaOnDegreePadding } = this;
483
+ gl.disable(gl.DEPTH_TEST);
484
+ const is3D = globe.api_GetCurrentGeometry() === 0;
485
+ // const lod = globe.api_GetCurrentLOD();
486
+ if (is3D) {
487
+ _circleProgram3D.draw(_circle3DVao, bufferOrchestrator.length, _opacity);
488
+ if (_oneDegreePadding)
489
+ _padding3dProgram.draw(_padding3dOneDegreeVao, bufferOrchestrator.length, 360, 1, _opacity, _zAlphaOnDegreePadding);
490
+ }
491
+ else {
492
+ _circleProgram2D.draw(_circle2DVao, bufferOrchestrator.length, CIRCLE_FLAT_EDGE_COUNT, _opacity);
493
+ // _padding2dProgram.draw(bigPaddingVAO, paddingBufferOrchestrator.length, _opacity);
494
+ if (_oneDegreePadding)
495
+ _padding2dProgram.draw(_oneDegree2DPaddingVao, bufferOrchestrator.length * CIRCLE_FLAT_EDGE_COUNT, _opacity, _zAlphaOnDegreePadding);
496
+ }
497
+ const drawOptions = { drawRange: { first: 0, count: paddingBufferOrchestrator.length } };
498
+ _lineOnGlobe_bigPadding.draw(_bigPadding3dFlatVAO, drawOptions, _opacity);
499
+ this._textWritersMap.forEach((textWriter) => textWriter.draw());
500
+ gl.enable(gl.DEPTH_TEST);
501
+ }
502
+ free() {
503
+ if (this._isFreed)
504
+ return;
505
+ const { globe } = this;
506
+ this.bufferManagersCompMap.forEach(({ bufferManager }) => bufferManager.free());
507
+ this.bufferManagersCompMapPadding.forEach(({ bufferManager }) => bufferManager.free());
508
+ // delete vaos
509
+ this.gl.deleteVertexArray(this._circle2DVao);
510
+ this.gl.deleteVertexArray(this._circle3DVao);
511
+ this.gl.deleteVertexArray(this._oneDegree2DPaddingVao);
512
+ this.gl.deleteVertexArray(this._padding3dOneDegreeVao);
513
+ this.gl.deleteVertexArray(this._bigPadding3dFlatVAO);
514
+ // delete programs
515
+ CircleCache2D.release(globe);
516
+ CircleCache3D.release(globe);
517
+ LinesColorInstancedFlatCache.release(globe);
518
+ CirclePadding3DCache.release(globe);
519
+ LineOnGlobeCache.release(globe);
520
+ this._circleProgram2D = null;
521
+ this._circleProgram3D = null;
522
+ this._padding2dProgram = null;
523
+ this._padding3dProgram = null;
524
+ this._lineOnGlobe_bigPadding = null;
525
+ this.paddingTextPlugin?.free();
526
+ this._isFreed = true;
527
+ }
528
+ __contextTextWriterUpdate(centerIDs, textWriterIDs = null) {
529
+ let textWriters = null;
530
+ if (textWriterIDs === null) {
531
+ textWriters = Array.from(this._textWritersMap.values());
532
+ }
533
+ else if (textWriterIDs.length === 0) {
534
+ return;
535
+ }
536
+ else {
537
+ textWriters = textWriterGetOrThrow(this._textWritersMap, textWriterIDs);
538
+ }
539
+ centerIDs.forEach((centerID) => { this._ringAccount.textUpdate(centerID, textWriters, this._textDataPreAdaptor); });
540
+ }
541
+ }
542
+ const textWriterGetOrThrow = mapGetOrThrow("textWriterIDs is invalid");
543
+ export { RangeRings, Z_ALPHA_MODE };