@pirireis/webglobeplugins 0.15.34 → 0.16.0

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 (481) hide show
  1. package/Math/angle-calculation.js +14 -13
  2. package/Math/arc-cdf-points.ts +329 -0
  3. package/Math/arc-generate-points-exponantial.ts +299 -0
  4. package/Math/arc.ts +299 -0
  5. package/Math/bounds/line-bbox.js +225 -186
  6. package/Math/circle-cdf-points.ts +143 -0
  7. package/Math/circle.ts +49 -0
  8. package/Math/constants.ts +12 -0
  9. package/Math/index.js +0 -1
  10. package/Math/juction/arc-plane.ts +129 -0
  11. package/Math/juction/line-sphere.ts +30 -0
  12. package/Math/juction/plane-plane.ts +64 -0
  13. package/Math/line.ts +84 -0
  14. package/Math/matrix4.ts +0 -0
  15. package/Math/mesh/mapbox-delaunay.js +607 -0
  16. package/Math/methods.ts +157 -0
  17. package/Math/plane.ts +92 -0
  18. package/Math/quaternion.ts +128 -0
  19. package/Math/roadmap.md +10 -0
  20. package/Math/templete-shapes/grid-visually-equal.ts +119 -0
  21. package/Math/types.ts +66 -0
  22. package/Math/utils.js +3 -2
  23. package/Math/vec3.ts +180 -0
  24. package/algorithms/search-binary.js +14 -16
  25. package/altitude-locator/adaptors.js +0 -1
  26. package/altitude-locator/keymethod.js +0 -1
  27. package/altitude-locator/plugin.js +446 -345
  28. package/altitude-locator/types.js +26 -21
  29. package/arrowfield/adaptor.js +11 -11
  30. package/arrowfield/index.js +3 -3
  31. package/arrowfield/plugin.js +128 -83
  32. package/bearing-line/index.js +2 -2
  33. package/bearing-line/plugin.js +520 -444
  34. package/circle-line-chain/chain-list-map.js +221 -201
  35. package/circle-line-chain/init.js +0 -1
  36. package/circle-line-chain/plugin.js +464 -411
  37. package/circle-line-chain/readme.md +57 -0
  38. package/circle-line-chain/util.js +1 -1
  39. package/compass-rose/compass-rose-padding-flat.js +274 -230
  40. package/compass-rose/compass-text-writer.js +173 -149
  41. package/compass-rose/index.js +3 -3
  42. package/compassrose/compassrose.js +341 -293
  43. package/compassrose/index.js +2 -2
  44. package/depth-locator/readme.md +26 -0
  45. package/dist/Math/angle-calculation.js +13 -0
  46. package/dist/Math/bounds/line-bbox.js +186 -0
  47. package/dist/Math/mesh/mapbox-delaunay.js +544 -0
  48. package/dist/Math/utils.js +2 -0
  49. package/dist/algorithms/search-binary.js +16 -0
  50. package/dist/altitude-locator/adaptors.js +1 -0
  51. package/dist/altitude-locator/keymethod.js +1 -0
  52. package/dist/altitude-locator/plugin.js +345 -0
  53. package/dist/altitude-locator/types.js +21 -0
  54. package/dist/arrowfield/adaptor.js +11 -0
  55. package/dist/arrowfield/index.js +3 -0
  56. package/dist/arrowfield/plugin.js +83 -0
  57. package/dist/bearing-line/index.js +2 -0
  58. package/dist/bearing-line/plugin.js +444 -0
  59. package/dist/circle-line-chain/chain-list-map.js +201 -0
  60. package/dist/circle-line-chain/init.js +1 -0
  61. package/dist/circle-line-chain/plugin.js +411 -0
  62. package/dist/circle-line-chain/util.js +1 -0
  63. package/dist/compass-rose/compass-rose-padding-flat.js +230 -0
  64. package/dist/compass-rose/compass-text-writer.js +149 -0
  65. package/dist/compass-rose/index.js +3 -0
  66. package/dist/compassrose/compassrose.js +293 -0
  67. package/dist/compassrose/index.js +2 -0
  68. package/dist/heatwave/index.js +3 -0
  69. package/dist/heatwave/isobar/objectarraylabels.js +200 -0
  70. package/dist/heatwave/isobar/plugin.js +302 -0
  71. package/dist/heatwave/isobar/quadtreecontours.js +298 -0
  72. package/dist/heatwave/plugins/heatwaveglobeshell.js +204 -0
  73. package/dist/index.js +12 -0
  74. package/dist/jest.config.js +7 -0
  75. package/dist/partialrings/buffer-manager.js +75 -0
  76. package/dist/partialrings/index.js +2 -0
  77. package/dist/partialrings/plugin.js +128 -0
  78. package/dist/partialrings/program.js +279 -0
  79. package/dist/pin/pin-object-array.js +300 -0
  80. package/dist/pin/pin-point-totem.js +60 -0
  81. package/dist/point-heat-map/adaptors/timetracksplugin-format-to-this.js +63 -0
  82. package/dist/point-heat-map/index.js +1 -0
  83. package/dist/point-heat-map/plugin-webworker.js +121 -0
  84. package/dist/point-heat-map/point-to-heat-map-flow.js +124 -0
  85. package/dist/point-tracks/key-methods.js +2 -0
  86. package/dist/point-tracks/plugin.js +393 -0
  87. package/dist/programs/arrowfield/index.js +2 -0
  88. package/dist/programs/arrowfield/logic.js +254 -0
  89. package/dist/programs/arrowfield/object.js +60 -0
  90. package/dist/programs/data2legend/density-to-legend.js +98 -0
  91. package/dist/programs/data2legend/point-to-density-texture.js +97 -0
  92. package/dist/programs/float2legendwithratio/index.js +2 -0
  93. package/dist/programs/float2legendwithratio/logic.js +167 -0
  94. package/dist/programs/float2legendwithratio/object.js +104 -0
  95. package/dist/programs/globe-util/is-globe-moved.js +19 -0
  96. package/dist/programs/globeshell/index.js +2 -0
  97. package/dist/programs/globeshell/wiggle/index.js +2 -0
  98. package/dist/programs/globeshell/wiggle/logic.js +342 -0
  99. package/dist/programs/globeshell/wiggle/object.js +66 -0
  100. package/dist/programs/helpers/blender/index.js +1 -0
  101. package/dist/programs/helpers/blender/program.js +76 -0
  102. package/dist/programs/helpers/fadeaway/index.js +2 -0
  103. package/dist/programs/helpers/fadeaway/logic.js +69 -0
  104. package/dist/programs/helpers/fadeaway/object.js +14 -0
  105. package/dist/programs/helpers/index.js +2 -0
  106. package/dist/programs/index.js +9 -0
  107. package/dist/programs/line-on-globe/circle-accurate-3d.js +138 -0
  108. package/dist/programs/line-on-globe/circle-accurate-flat.js +210 -0
  109. package/dist/programs/line-on-globe/degree-padding-around-circle-3d.js +156 -0
  110. package/dist/programs/line-on-globe/index.js +1 -0
  111. package/dist/programs/line-on-globe/lines-color-instanced-flat.js +131 -0
  112. package/dist/programs/line-on-globe/util.js +5 -0
  113. package/dist/programs/picking/pickable-polygon-renderer.js +184 -0
  114. package/dist/programs/picking/pickable-renderer.js +184 -0
  115. package/dist/programs/point-on-globe/element-globe-surface-glow.js +138 -0
  116. package/dist/programs/point-on-globe/element-point-glow.js +150 -0
  117. package/dist/programs/point-on-globe/square-pixel-point.js +171 -0
  118. package/dist/programs/polygon-on-globe/texture-dem-triangle-test-plugin.js +97 -0
  119. package/dist/programs/polygon-on-globe/texture-dem-triangles.js +167 -0
  120. package/dist/programs/rings/distancering/circleflatprogram.js +116 -0
  121. package/dist/programs/rings/distancering/circlepaddingfreeangleprogram.js +326 -0
  122. package/dist/programs/rings/distancering/circlepaddysharedbuffer.js +368 -0
  123. package/dist/programs/rings/distancering/index.js +6 -0
  124. package/dist/programs/rings/distancering/paddyflatprogram.js +127 -0
  125. package/dist/programs/rings/distancering/paddyflatprogram2d.js +129 -0
  126. package/dist/programs/rings/distancering/paddyflatprogram3d.js +128 -0
  127. package/dist/programs/rings/index.js +1 -0
  128. package/dist/programs/totems/gpu-selection-uniform-block.js +104 -0
  129. package/dist/programs/two-d/pixel-circle.js +1 -0
  130. package/dist/programs/two-d/pixel-padding-for-compass.js +159 -0
  131. package/dist/programs/util.js +14 -0
  132. package/dist/programs/vectorfields/index.js +3 -0
  133. package/dist/programs/vectorfields/logics/drawrectangleparticles.js +113 -0
  134. package/dist/programs/vectorfields/logics/index.js +2 -0
  135. package/dist/programs/vectorfields/logics/pixelbased.js +140 -0
  136. package/dist/programs/vectorfields/logics/ubo.js +60 -0
  137. package/dist/programs/vectorfields/pingpongbuffermanager.js +73 -0
  138. package/dist/rangerings/index.js +5 -0
  139. package/dist/rangerings/plugin.js +543 -0
  140. package/dist/rangerings/rangeringangletext.js +326 -0
  141. package/dist/rangerings/ring-account.js +112 -0
  142. package/dist/semiplugins/shape-on-terrain/terrain-cover/texture-dem-cover.js +1 -0
  143. package/dist/shaders/fragment-toy/firework.js +55 -0
  144. package/dist/shaders/fragment-toy/singularity.js +56 -0
  145. package/dist/timetracks/adaptors-line-strip.js +65 -0
  146. package/dist/timetracks/index.js +1 -0
  147. package/dist/timetracks/plugin-line-strip.js +240 -0
  148. package/dist/timetracks/program-line-strip.js +608 -0
  149. package/dist/timetracks/programpoint-line-strip.js +151 -0
  150. package/dist/util/account/bufferoffsetmanager.js +176 -0
  151. package/dist/util/account/index.js +3 -0
  152. package/dist/util/account/util.js +18 -0
  153. package/dist/util/algorithms/index.js +1 -0
  154. package/dist/util/algorithms/search-binary.js +25 -0
  155. package/dist/util/check/index.js +1 -0
  156. package/dist/util/gl-util/uniform-block/shader.js +1 -0
  157. package/dist/util/heatwavedatamanager/datamanager.js +149 -0
  158. package/dist/util/heatwavedatamanager/index.js +2 -0
  159. package/dist/util/index.js +13 -0
  160. package/dist/util/interpolation/index.js +1 -0
  161. package/dist/util/interpolation/timetrack/index.js +2 -0
  162. package/dist/util/interpolation/timetrack/timetrack-interpolator.js +79 -0
  163. package/dist/util/interpolation/timetrack/web-worker.js +46 -0
  164. package/dist/util/jshelpers/data-filler.js +17 -0
  165. package/dist/util/jshelpers/equality.js +18 -0
  166. package/dist/util/jshelpers/index.js +2 -0
  167. package/dist/util/jshelpers/timefilters.js +30 -0
  168. package/dist/util/picking/fence.js +43 -0
  169. package/dist/util/picking/picker-displayer.js +136 -0
  170. package/dist/util/programs/draw-texture-on-canvas.js +86 -0
  171. package/dist/util/programs/index.js +1 -0
  172. package/dist/util/programs/shapesonglobe.js +210 -0
  173. package/dist/util/programs/supersampletotextures.js +109 -0
  174. package/dist/util/programs/texturetoglobe.js +179 -0
  175. package/dist/util/shaderfunctions/index.js +2 -0
  176. package/dist/util/shaderfunctions/nodata.js +8 -0
  177. package/dist/util/shaderfunctions/noisefunctions.js +41 -0
  178. package/dist/util/surface-line-data/arcs-to-cuts.js +50 -0
  179. package/dist/util/surface-line-data/cut-arc.js +1 -0
  180. package/dist/util/surface-line-data/rbush-manager.js +1 -0
  181. package/dist/util/surface-line-data/types.js +1 -0
  182. package/dist/util/surface-line-data/web-worker.js +1 -0
  183. package/dist/util/webglobe/gldefaultstates.js +4 -0
  184. package/dist/util/webglobe/index.js +2 -0
  185. package/dist/util/webglobe/rasteroverlay.js +75 -0
  186. package/dist/waveparticles/adaptor.js +15 -0
  187. package/dist/waveparticles/index.js +3 -0
  188. package/dist/waveparticles/plugin.js +290 -0
  189. package/dist/wind/imagetovectorfieldandmagnitude.js +56 -0
  190. package/dist/wind/index.js +5 -0
  191. package/dist/wind/plugin.js +921 -0
  192. package/dist/wind/vectorfieldimage.js +23 -0
  193. package/dist/write-text/attached-text-writer.js +87 -0
  194. package/dist/write-text/context-text-bulk.js +185 -0
  195. package/dist/write-text/context-text.js +94 -0
  196. package/dist/write-text/context-text3old.js +152 -0
  197. package/dist/write-text/index.js +1 -0
  198. package/dist/write-text/writer-plugin.js +8 -0
  199. package/heatwave/index.js +4 -3
  200. package/heatwave/isobar/objectarraylabels.js +247 -200
  201. package/heatwave/isobar/plugin.js +339 -302
  202. package/heatwave/isobar/quadtreecontours.js +336 -298
  203. package/heatwave/plugins/heatwaveglobeshell.js +259 -204
  204. package/index.js +15 -12
  205. package/jest.config.js +6 -7
  206. package/package.json +6 -2
  207. package/partialrings/buffer-manager.js +89 -75
  208. package/partialrings/goals.md +17 -0
  209. package/partialrings/index.js +3 -2
  210. package/partialrings/plugin.js +160 -128
  211. package/partialrings/program.js +233 -188
  212. package/pin/pin-object-array.js +381 -300
  213. package/pin/pin-point-totem.js +77 -60
  214. package/point-heat-map/adaptors/timetracksplugin-format-to-this.js +78 -63
  215. package/point-heat-map/index.js +0 -1
  216. package/point-heat-map/plugin-webworker.js +148 -121
  217. package/point-heat-map/point-to-heat-map-flow.js +150 -124
  218. package/point-heat-map/readme.md +15 -0
  219. package/point-tracks/key-methods.js +3 -2
  220. package/point-tracks/plugin.js +480 -393
  221. package/programs/arrowfield/index.js +2 -2
  222. package/programs/arrowfield/logic.js +173 -141
  223. package/programs/arrowfield/object.js +89 -60
  224. package/programs/data2legend/density-to-legend.js +90 -73
  225. package/programs/data2legend/point-to-density-texture.js +87 -70
  226. package/programs/float2legendwithratio/index.js +3 -2
  227. package/programs/float2legendwithratio/logic.js +144 -118
  228. package/programs/float2legendwithratio/object.js +141 -104
  229. package/programs/globe-util/is-globe-moved.js +27 -19
  230. package/programs/globeshell/index.js +2 -2
  231. package/programs/globeshell/wiggle/index.js +3 -2
  232. package/programs/globeshell/wiggle/logic.js +272 -243
  233. package/programs/globeshell/wiggle/object.js +93 -66
  234. package/programs/helpers/blender/index.js +0 -1
  235. package/programs/helpers/blender/program.js +73 -58
  236. package/programs/helpers/fadeaway/index.js +3 -2
  237. package/programs/helpers/fadeaway/logic.js +53 -46
  238. package/programs/helpers/fadeaway/object.js +20 -14
  239. package/programs/helpers/index.js +2 -2
  240. package/programs/index.js +21 -9
  241. package/programs/line-on-globe/circle-accurate-3d.js +115 -87
  242. package/programs/line-on-globe/circle-accurate-flat.js +201 -149
  243. package/programs/line-on-globe/degree-padding-around-circle-3d.js +136 -104
  244. package/programs/line-on-globe/index.js +0 -1
  245. package/programs/line-on-globe/lines-color-instanced-flat.js +102 -83
  246. package/programs/line-on-globe/linestrip/data.ts +29 -0
  247. package/programs/line-on-globe/linestrip/linestrip.ts +201 -0
  248. package/programs/line-on-globe/naive-accurate-flexible.ts +258 -0
  249. package/programs/line-on-globe/util.js +8 -5
  250. package/programs/picking/pickable-polygon-renderer.js +215 -0
  251. package/programs/picking/pickable-renderer.js +129 -98
  252. package/programs/point-on-globe/element-globe-surface-glow.js +122 -93
  253. package/programs/point-on-globe/element-point-glow.js +114 -80
  254. package/programs/point-on-globe/square-pixel-point.js +138 -120
  255. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin.ts +120 -0
  256. package/programs/polygon-on-globe/texture-dem-triangles.ts +207 -0
  257. package/programs/programcache.ts +131 -0
  258. package/programs/rings/distancering/circleflatprogram.js +138 -116
  259. package/programs/rings/distancering/circlepaddingfreeangleprogram.js +323 -275
  260. package/programs/rings/distancering/circlepaddysharedbuffer.js +423 -368
  261. package/programs/rings/distancering/index.js +5 -6
  262. package/programs/rings/distancering/paddyflatprogram.js +148 -127
  263. package/programs/rings/distancering/paddyflatprogram2d.js +153 -129
  264. package/programs/rings/distancering/paddyflatprogram3d.js +149 -128
  265. package/programs/rings/index.js +1 -1
  266. package/programs/rings/partial-ring/piece-of-pie.ts +323 -0
  267. package/programs/totems/camerauniformblock.ts +310 -0
  268. package/programs/totems/canvas-webglobe-info.ts +156 -0
  269. package/programs/totems/globe-changes.ts +79 -0
  270. package/programs/totems/gpu-selection-uniform-block.js +127 -99
  271. package/programs/totems/index.ts +2 -0
  272. package/programs/two-d/pixel-circle.js +0 -1
  273. package/programs/two-d/pixel-padding-for-compass.js +112 -97
  274. package/programs/util.js +19 -14
  275. package/programs/vectorfields/index.js +3 -3
  276. package/programs/vectorfields/logics/constants.ts +5 -0
  277. package/programs/vectorfields/logics/drawrectangleparticles.js +78 -58
  278. package/programs/vectorfields/logics/index.js +4 -2
  279. package/programs/vectorfields/logics/pixelbased.js +92 -73
  280. package/programs/vectorfields/logics/ubo-new.ts +37 -0
  281. package/programs/vectorfields/logics/ubo.js +57 -51
  282. package/programs/vectorfields/pingpongbuffermanager.js +80 -73
  283. package/publish.bat +62 -0
  284. package/range-tools-on-terrain/bearing-line/adapters.ts +154 -0
  285. package/range-tools-on-terrain/bearing-line/plugin.ts +569 -0
  286. package/range-tools-on-terrain/bearing-line/types.ts +65 -0
  287. package/range-tools-on-terrain/circle-line-chain/adapters.ts +109 -0
  288. package/range-tools-on-terrain/circle-line-chain/chain-list-map.ts +446 -0
  289. package/range-tools-on-terrain/circle-line-chain/plugin.ts +607 -0
  290. package/range-tools-on-terrain/circle-line-chain/types.ts +43 -0
  291. package/range-tools-on-terrain/range-ring/adapters.ts +114 -0
  292. package/range-tools-on-terrain/range-ring/enum.ts +2 -0
  293. package/range-tools-on-terrain/range-ring/plugin.ts +447 -0
  294. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +396 -0
  295. package/range-tools-on-terrain/range-ring/types.ts +30 -0
  296. package/rangerings/enum.ts +2 -0
  297. package/rangerings/index.js +5 -5
  298. package/rangerings/plugin.js +644 -543
  299. package/rangerings/rangeringangletext.js +369 -326
  300. package/rangerings/ring-account.js +129 -112
  301. package/semiplugins/interface.ts +14 -0
  302. package/semiplugins/lightweight/line-plugin.ts +343 -0
  303. package/semiplugins/lightweight/piece-of-pie-plugin.ts +275 -0
  304. package/semiplugins/shape-on-terrain/arc-plugin.ts +602 -0
  305. package/semiplugins/shape-on-terrain/circle-plugin.ts +588 -0
  306. package/semiplugins/shape-on-terrain/goal.md +12 -0
  307. package/semiplugins/shape-on-terrain/padding-1-degree.ts +714 -0
  308. package/semiplugins/shape-on-terrain/terrain-cover/notes.md +90 -0
  309. package/semiplugins/shape-on-terrain/terrain-cover/texture-dem-cover.ts +0 -0
  310. package/semiplugins/type.ts +8 -0
  311. package/shaders/fragment-toy/firework.js +1 -1
  312. package/shaders/fragment-toy/singularity.js +5 -2
  313. package/tests/Math/arc-sampling-test.js +367 -0
  314. package/tests/Math/arc-sampling-test.ts +429 -0
  315. package/tests/Math/arc.test.ts +102 -0
  316. package/tests/Math/junction/arc-plane.test.ts +163 -0
  317. package/tests/Math/junction/plane-plane.test.ts +91 -0
  318. package/tests/Math/plane-test.ts +17 -0
  319. package/tests/Math/plane.test.ts +43 -0
  320. package/tests/Math/vec3.test.ts +14 -0
  321. package/timetracks/adaptors-line-strip.js +80 -65
  322. package/timetracks/index.js +0 -1
  323. package/timetracks/plugin-line-strip.js +295 -240
  324. package/timetracks/program-line-strip.js +491 -411
  325. package/timetracks/programpoint-line-strip.js +122 -98
  326. package/timetracks/readme.md +1 -0
  327. package/tsconfig.json +22 -0
  328. package/types.ts +265 -0
  329. package/util/account/bufferoffsetmanager.js +209 -176
  330. package/util/account/create-buffermap-orchastration.ts +85 -0
  331. package/util/account/index.js +6 -3
  332. package/util/account/single-attribute-buffer-management/buffer-manager.ts +149 -0
  333. package/util/account/single-attribute-buffer-management/buffer-orchestrator.ts +332 -0
  334. package/util/account/single-attribute-buffer-management/buffer-orchestrator1.ts +184 -0
  335. package/util/account/single-attribute-buffer-management/index.ts +11 -0
  336. package/util/account/single-attribute-buffer-management/object-store.ts +76 -0
  337. package/util/account/single-attribute-buffer-management/types.ts +43 -0
  338. package/util/account/util.js +22 -18
  339. package/util/algorithms/index.js +0 -1
  340. package/util/algorithms/search-binary.js +26 -25
  341. package/util/build-strategy/general-strategy.ts +99 -0
  342. package/util/build-strategy/static-dynamic.ts +50 -0
  343. package/util/check/index.js +0 -1
  344. package/util/check/typecheck.ts +74 -0
  345. package/util/frame-counter-trigger.ts +99 -0
  346. package/util/geometry/index.ts +64 -0
  347. package/util/gl-util/buffer/attribute-loader.ts +84 -0
  348. package/util/gl-util/buffer/index.ts +6 -0
  349. package/util/gl-util/draw-options/methods.ts +47 -0
  350. package/util/gl-util/uniform-block/manager.ts +210 -0
  351. package/util/gl-util/uniform-block/roadmap.md +70 -0
  352. package/util/gl-util/uniform-block/shader.js +0 -1
  353. package/util/gl-util/uniform-block/types.ts +20 -0
  354. package/util/heatwavedatamanager/datamanager.js +168 -149
  355. package/util/heatwavedatamanager/index.js +2 -2
  356. package/util/heatwavedatamanager/pointcoordsmeta.ts +28 -0
  357. package/util/heatwavedatamanager/texture-point-sampler.ts +198 -0
  358. package/util/index.js +13 -13
  359. package/util/interpolation/index.js +0 -1
  360. package/util/interpolation/timetrack/index.js +9 -2
  361. package/util/interpolation/timetrack/timetrack-interpolator.js +94 -79
  362. package/util/interpolation/timetrack/web-worker.js +51 -46
  363. package/util/jshelpers/data-filler.js +19 -17
  364. package/util/jshelpers/equality.js +17 -18
  365. package/util/jshelpers/index.js +1 -2
  366. package/util/jshelpers/timefilters.js +32 -30
  367. package/util/picking/fence.js +46 -43
  368. package/util/picking/picker-displayer.js +177 -136
  369. package/util/programs/draw-texture-on-canvas.js +82 -66
  370. package/util/programs/index.js +1 -1
  371. package/util/programs/shapesonglobe.js +203 -167
  372. package/util/programs/supersampletotextures.js +132 -99
  373. package/util/programs/texturetoglobe.js +152 -128
  374. package/util/shaderfunctions/geometrytransformations.ts +388 -0
  375. package/util/shaderfunctions/index.js +2 -2
  376. package/util/shaderfunctions/nodata.js +4 -2
  377. package/util/shaderfunctions/noisefunctions.js +10 -7
  378. package/util/surface-line-data/arc-bboxes.ts +42 -0
  379. package/util/surface-line-data/arcs-to-cuts.js +74 -50
  380. package/util/surface-line-data/cut-arc.js +0 -1
  381. package/util/surface-line-data/flow.ts +52 -0
  382. package/util/surface-line-data/rbush-manager.js +0 -1
  383. package/util/surface-line-data/types.ts +27 -0
  384. package/util/surface-line-data/web-worker.js +0 -1
  385. package/util/webglobe/gldefaultstates.js +5 -4
  386. package/util/webglobe/index.js +2 -2
  387. package/util/webglobe/rasteroverlay.js +96 -75
  388. package/util/webglobjectbuilders.ts +446 -0
  389. package/waveparticles/adaptor.js +16 -15
  390. package/waveparticles/index.js +3 -3
  391. package/waveparticles/plugin.js +342 -290
  392. package/wind/imagetovectorfieldandmagnitude.js +71 -56
  393. package/wind/index.js +5 -5
  394. package/wind/plugin.js +845 -670
  395. package/wind/vectorfieldimage.js +27 -23
  396. package/write-text/attached-text-writer.js +105 -87
  397. package/write-text/context-text-bulk.ts +268 -0
  398. package/write-text/context-text.js +125 -94
  399. package/write-text/context-text3.ts +253 -0
  400. package/write-text/context-text3old.js +179 -152
  401. package/write-text/context-text4.ts +243 -0
  402. package/write-text/index.js +1 -1
  403. package/write-text/writer-plugin.js +7 -8
  404. package/Math/frustum/camera.js +0 -24
  405. package/Math/frustum/from-globeinfo.js +0 -48
  406. package/util/account/single-attribute-buffer-management/types.js +0 -1
  407. /package/{Math → dist/Math}/arc-cdf-points.js +0 -0
  408. /package/{Math → dist/Math}/arc-generate-points-exponantial.js +0 -0
  409. /package/{Math → dist/Math}/arc.js +0 -0
  410. /package/{Math → dist/Math}/circle-cdf-points.js +0 -0
  411. /package/{Math → dist/Math}/circle.js +0 -0
  412. /package/{Math → dist/Math}/constants.js +0 -0
  413. /package/{Math/matrix4.js → dist/Math/index.js} +0 -0
  414. /package/{Math → dist/Math}/juction/arc-plane.js +0 -0
  415. /package/{Math → dist/Math}/juction/line-sphere.js +0 -0
  416. /package/{Math → dist/Math}/juction/plane-plane.js +0 -0
  417. /package/{Math → dist/Math}/line.js +0 -0
  418. /package/{util/surface-line-data/types.js → dist/Math/matrix4.js} +0 -0
  419. /package/{Math → dist/Math}/methods.js +0 -0
  420. /package/{Math → dist/Math}/plane.js +0 -0
  421. /package/{Math → dist/Math}/quaternion.js +0 -0
  422. /package/{Math → dist/Math}/templete-shapes/grid-visually-equal.js +0 -0
  423. /package/{Math/frustum → dist/Math}/types.js +0 -0
  424. /package/{Math → dist/Math}/vec3.js +0 -0
  425. /package/{programs → dist/programs}/line-on-globe/linestrip/data.js +0 -0
  426. /package/{programs → dist/programs}/line-on-globe/linestrip/linestrip.js +0 -0
  427. /package/{programs → dist/programs}/line-on-globe/naive-accurate-flexible.js +0 -0
  428. /package/{programs → dist/programs}/programcache.js +0 -0
  429. /package/{programs → dist/programs}/rings/partial-ring/piece-of-pie.js +0 -0
  430. /package/{programs → dist/programs}/totems/camerauniformblock.js +0 -0
  431. /package/{programs → dist/programs}/totems/canvas-webglobe-info.js +0 -0
  432. /package/{programs → dist/programs}/totems/globe-changes.js +0 -0
  433. /package/{programs → dist/programs}/totems/index.js +0 -0
  434. /package/{programs → dist/programs}/vectorfields/logics/constants.js +0 -0
  435. /package/{programs → dist/programs}/vectorfields/logics/ubo-new.js +0 -0
  436. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/bearing-line/adapters.js +0 -0
  437. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/bearing-line/plugin.js +0 -0
  438. /package/{Math → dist/range-tools-on-terrain/bearing-line}/types.js +0 -0
  439. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/circle-line-chain/adapters.js +0 -0
  440. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/circle-line-chain/chain-list-map.js +0 -0
  441. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/circle-line-chain/plugin.js +0 -0
  442. /package/{range-tools-on-terrain/bearing-line → dist/range-tools-on-terrain/circle-line-chain}/types.js +0 -0
  443. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/adapters.js +0 -0
  444. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/enum.js +0 -0
  445. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/plugin.js +0 -0
  446. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/rangeringangletext.js +0 -0
  447. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/types.js +0 -0
  448. /package/{rangerings → dist/rangerings}/enum.js +0 -0
  449. /package/{semiplugins → dist/semiplugins}/interface.js +0 -0
  450. /package/{semiplugins → dist/semiplugins}/lightweight/line-plugin.js +0 -0
  451. /package/{semiplugins → dist/semiplugins}/lightweight/piece-of-pie-plugin.js +0 -0
  452. /package/{semiplugins → dist/semiplugins}/shape-on-terrain/arc-plugin.js +0 -0
  453. /package/{semiplugins → dist/semiplugins}/shape-on-terrain/circle-plugin.js +0 -0
  454. /package/{semiplugins → dist/semiplugins}/shape-on-terrain/padding-1-degree.js +0 -0
  455. /package/{semiplugins → dist/semiplugins}/type.js +0 -0
  456. /package/{types.js → dist/types.js} +0 -0
  457. /package/{util → dist/util}/account/create-buffermap-orchastration.js +0 -0
  458. /package/{util → dist/util}/account/single-attribute-buffer-management/buffer-manager.js +0 -0
  459. /package/{util → dist/util}/account/single-attribute-buffer-management/buffer-orchestrator.js +0 -0
  460. /package/{util → dist/util}/account/single-attribute-buffer-management/buffer-orchestrator1.js +0 -0
  461. /package/{util → dist/util}/account/single-attribute-buffer-management/index.js +0 -0
  462. /package/{util → dist/util}/account/single-attribute-buffer-management/object-store.js +0 -0
  463. /package/{range-tools-on-terrain/circle-line-chain → dist/util/account/single-attribute-buffer-management}/types.js +0 -0
  464. /package/{util → dist/util}/build-strategy/general-strategy.js +0 -0
  465. /package/{util → dist/util}/build-strategy/static-dynamic.js +0 -0
  466. /package/{util → dist/util}/check/typecheck.js +0 -0
  467. /package/{util → dist/util}/frame-counter-trigger.js +0 -0
  468. /package/{util → dist/util}/geometry/index.js +0 -0
  469. /package/{util → dist/util}/gl-util/buffer/attribute-loader.js +0 -0
  470. /package/{util → dist/util}/gl-util/buffer/index.js +0 -0
  471. /package/{util → dist/util}/gl-util/draw-options/methods.js +0 -0
  472. /package/{util → dist/util}/gl-util/uniform-block/manager.js +0 -0
  473. /package/{util → dist/util}/gl-util/uniform-block/types.js +0 -0
  474. /package/{util → dist/util}/heatwavedatamanager/pointcoordsmeta.js +0 -0
  475. /package/{util → dist/util}/heatwavedatamanager/texture-point-sampler.js +0 -0
  476. /package/{util → dist/util}/shaderfunctions/geometrytransformations.js +0 -0
  477. /package/{util → dist/util}/surface-line-data/arc-bboxes.js +0 -0
  478. /package/{util → dist/util}/surface-line-data/flow.js +0 -0
  479. /package/{util → dist/util}/webglobjectbuilders.js +0 -0
  480. /package/{write-text → dist/write-text}/context-text3.js +0 -0
  481. /package/{write-text → dist/write-text}/context-text4.js +0 -0
@@ -1,543 +1,644 @@
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 };
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 };