@pirireis/webglobeplugins 0.15.35 → 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,25 +1,26 @@
1
- /**
2
- * @typedef {Array<number>} ListLike
3
- * @typedef {number || null} Index
4
- */
5
- /**
6
- * @param {ListLike} container
7
- * @param {number} value
8
- * @returns {Index}
9
- */
10
- const findFirstIndexInRange = (container, value) => {
11
- let start = 0;
12
- let end = container.length - 1;
13
- let mid = 0;
14
- while (start <= end) {
15
- mid = Math.floor((start + end) / 2);
16
- if (container[mid] <= value && value <= container[mid + 1])
17
- return mid;
18
- if (container[mid] < value)
19
- start = mid + 1;
20
- else
21
- end = mid - 1;
22
- }
23
- return null;
24
- };
25
- export { findFirstIndexInRange };
1
+ /**
2
+ * @typedef {Array<number>} ListLike
3
+ * @typedef {number || null} Index
4
+ */
5
+
6
+ /**
7
+ * @param {ListLike} container
8
+ * @param {number} value
9
+ * @returns {Index}
10
+ */
11
+ const findFirstIndexInRange = (container, value) => {
12
+ let start = 0;
13
+ let end = container.length - 1;
14
+ let mid = 0;
15
+ while (start <= end) {
16
+ mid = Math.floor((start + end) / 2);
17
+ if (container[mid] <= value && value <= container[mid + 1]) return mid;
18
+ if (container[mid] < value) start = mid + 1;
19
+ else end = mid - 1;
20
+ }
21
+ return null;
22
+ }
23
+
24
+
25
+ export { findFirstIndexInRange };
26
+
@@ -0,0 +1,99 @@
1
+ /**
2
+ * # Considerations ---
3
+ * - RABIT LOD change should trigger build immediately
4
+ * - CRUD operations should trigger build immediately
5
+ * - CameraAngle Change should trigger build immediately for Plugins employ DENSITY variation mechanism
6
+ *
7
+ */
8
+
9
+ import { Globe, GlobeLookInfo } from '../../types';
10
+
11
+
12
+ enum State {
13
+ STATIC = "STATIC",
14
+ DYNAMIC = "DYNAMIC",
15
+ TRANSIENT = "TRANSIENT"
16
+ }
17
+
18
+
19
+
20
+
21
+ class GeneralStrategy {
22
+ globe: Globe;
23
+ private _state: State = State.DYNAMIC;
24
+ private _transitionLevel: number = 8; // Default transition level
25
+ private _lastLOD: number = 1000; // an extreme value to trigger initial build
26
+ private _lastCameraPosition: [number, number, number] = [0, 0, 0]; // Initial camera position
27
+ private _lastLookInfo: GlobeLookInfo = {
28
+ CenterLong: 0,
29
+ CenterLat: 0,
30
+ Distance: 0,
31
+ Tilt: 0,
32
+ NorthAng: 0
33
+ }
34
+ private _currentLOD: number = 1000; // an extreme value to trigger initial build
35
+ private _currentCameraPosition: [number, number, number] = [0, 0, 0]; // Initial camera position
36
+ private _currentLookInfo: GlobeLookInfo = {
37
+ CenterLong: 0,
38
+ CenterLat: 0,
39
+ Distance: 0,
40
+ Tilt: 0,
41
+ NorthAng: 0
42
+ }
43
+
44
+ // private _staticBuildThreshold: number = 8; // Default static build threshold
45
+ // private _triggerStaticBuild: boolean = false;
46
+
47
+
48
+ // private _isMovedParams: boolean = false
49
+ // private _isCameraChangedParams: boolean = false
50
+ // private _elevationChangedParams: boolean = false
51
+
52
+
53
+
54
+ constructor(
55
+
56
+ globe: Globe,
57
+ transitionLevel: number = 8
58
+ ) {
59
+ // Initialization logic if needed
60
+ this.globe = globe;
61
+ this._transitionLevel = transitionLevel;
62
+
63
+
64
+
65
+ }
66
+
67
+ calculateState() {
68
+
69
+
70
+ }
71
+
72
+ getState(): State {
73
+ return this._state;
74
+ }
75
+
76
+ // Additional methods and properties can be added here as needed
77
+
78
+
79
+ // @ts-ignore
80
+ _isMoved(): boolean {
81
+
82
+ }
83
+
84
+ // @ts-ignore
85
+ _isCameraChanged(): boolean {
86
+ }
87
+
88
+ // @ts-ignore
89
+ _elevationChanged(): boolean {
90
+
91
+ }
92
+
93
+ // @ts-ignore
94
+ // _triggerStaticBuild(): boolean {
95
+ // if (this._lastLOD < this._staticBuildThreshold && this._currentLOD < this._staticBuildThreshold) {
96
+ // this._triggerStaticBuild = true;
97
+ // }
98
+ // }
99
+ }
@@ -0,0 +1,50 @@
1
+ import { Globe } from '../../types';
2
+
3
+ export enum StaticDynamicState {
4
+ STATIC = "STATIC",
5
+ DYNAMIC = "DYNAMIC",
6
+ TO_STATIC = "TO_STATIC" // TODO: Change this not bidirectional, go to static
7
+
8
+ }
9
+
10
+
11
+ export class StaticDynamicStrategy {
12
+ globe: Globe;
13
+ private _staticDynamicState: StaticDynamicState = StaticDynamicState.DYNAMIC;
14
+ private _transitionLevel: number = 8; // Default transition level
15
+ private _lastStaticDynamicState: StaticDynamicState = StaticDynamicState.STATIC;
16
+ private _lastGeometry: 0 | 1 = null!
17
+ private _toStatic: () => void;
18
+ constructor(globe: Globe, transitionLevel: number = 8, toStatic: () => void) {
19
+ this.globe = globe;
20
+ this._transitionLevel = transitionLevel;
21
+ this._toStatic = toStatic;
22
+
23
+ this.updateState();
24
+ }
25
+
26
+ updateState() {
27
+ const currentLOD = this.globe.api_GetCurrentLODWithDecimal();
28
+ const state = currentLOD < this._transitionLevel ? StaticDynamicState.STATIC : StaticDynamicState.DYNAMIC;
29
+ const currentGeometry = this.globe.api_GetCurrentGeometry();
30
+ if (this._lastStaticDynamicState === StaticDynamicState.DYNAMIC && state === StaticDynamicState.STATIC) {
31
+ this._staticDynamicState = StaticDynamicState.TO_STATIC;
32
+ this._toStatic();
33
+ } else if ((currentGeometry !== this._lastGeometry) && state === StaticDynamicState.STATIC) {
34
+ this._staticDynamicState = StaticDynamicState.TO_STATIC;
35
+ this._toStatic();
36
+ } else {
37
+ this._staticDynamicState = state;
38
+ }
39
+ this._lastStaticDynamicState = this._staticDynamicState;
40
+ this._lastGeometry = currentGeometry;
41
+ }
42
+
43
+
44
+
45
+
46
+ getState(): StaticDynamicState {
47
+ return this._staticDynamicState;
48
+ }
49
+
50
+ }
@@ -1 +0,0 @@
1
- "use strict";
@@ -0,0 +1,74 @@
1
+ // Generic
2
+
3
+ import { Color } from "../../types";
4
+
5
+ interface TextFont {
6
+ name: string;
7
+ textColor: string;
8
+ hollowColor: string;
9
+ size: number;
10
+ bold: boolean;
11
+ italic: boolean;
12
+ }
13
+
14
+ const doesOwnProperties = (properties: string[], errorMessage: string) => {
15
+ return (object: Record<string, any>): void => {
16
+ properties.forEach(element => {
17
+ if (!object.hasOwnProperty(element)) throw new TypeError(errorMessage + ':' + element);
18
+ });
19
+ }
20
+ }
21
+
22
+ export const isHexColor = (hexColor: string): boolean => /^#[0-9A-F]{6}$/i.test(hexColor);
23
+ export const isHexColorWithOpacity = (hexColor: string): boolean => /^#[0-9A-F]{6}[0-9a-f]{0,2}$/i.test(hexColor);
24
+
25
+ export const colorCheck = (color: Color): void => {
26
+ if (Array.isArray(color)) {
27
+ if (color.length !== 4) throw new TypeError("Color must be an array 4 numbers RGBA");
28
+ color.forEach(c => {
29
+ if (typeof c !== "number") throw new TypeError("Color array must contain only numbers");
30
+ if (c < 0 || c > 1) throw new RangeError("Color values must be between 0 and 1");
31
+ });
32
+ }
33
+ }
34
+
35
+ export const opacityCheck = (opacity: number | any): void => {
36
+ if (typeof opacity !== "number") throw new TypeError("style.opacity must a number");
37
+ if (opacity < 0 || 1 < opacity) throw new RangeError("Opacity Range Must be 0-1");
38
+ }
39
+
40
+ // Text Related
41
+
42
+ const fontCheckTypes = doesOwnProperties(["name", "textColor", "hollowColor", "size", "bold", "italic"], "font does not have");
43
+ const fontCheckColors = (textColor: string, hollowColor: string): boolean => isHexColor(textColor) && isHexColor(hollowColor);
44
+
45
+ export const isTextFont = (textFont: TextFont): void => {
46
+ fontCheckTypes(textFont);
47
+ fontCheckColors(textFont.textColor, textFont.hollowColor);
48
+ if (typeof textFont.size !== "number") throw new TypeError("textFont size is not a number");
49
+ }
50
+
51
+ export const constraintFloat = (x: number, lowerBound: number | null = null, upperBound: number | null = null): void => {
52
+ if (typeof x !== "number") throw new Error("type must be numberic");
53
+ if (lowerBound === null && upperBound === null) return;
54
+ if (lowerBound !== null && lowerBound > x) throw new Error(`input must be greater than ${lowerBound}`);
55
+ if (upperBound !== null && x > upperBound) throw new Error(`input must be less than ${upperBound}`);
56
+ }
57
+
58
+ export const isBoolean = (x: any): void => {
59
+ if (typeof x !== "boolean") throw new TypeError("type must be boolean");
60
+ }
61
+
62
+
63
+ export const mapGetOrThrow = (errorNote: string) => {
64
+ return (mapInstance: Map<string, any>, ids: string[]) => {
65
+ if (!ids) throw new Error("There is no map keys to get");
66
+ const result = [];
67
+ for (let i = 0; i < ids.length; i++) {
68
+ const e = mapInstance.get(ids[i]);
69
+ if (e === undefined) throw new Error(errorNote + " " + ids[i]);
70
+ result.push(e);
71
+ }
72
+ return result;
73
+ }
74
+ }
@@ -0,0 +1,99 @@
1
+ import { CameraUniformBlockTotemCache, CameraUniformBlockTotem } from "../programs/totems/camerauniformblock";
2
+ import { Globe, GlobeChanges } from "../types";
3
+
4
+ type UpdateCallback = (globeChanges: GlobeChanges) => void;
5
+
6
+ export class FrameCounterTrigger {
7
+ private globe: Globe;
8
+ private count: number = 0;
9
+ private threshold: number;
10
+ private timeoutMs: number;
11
+ private timeoutId: ReturnType<typeof setTimeout> | null = null;
12
+ readonly accumulatedChanges: GlobeChanges = {
13
+ geometry: false,
14
+ look: false,
15
+ lod: false,
16
+ lod2DWheel: false,
17
+ elevationScale: false,
18
+ screenMoved: false
19
+ };
20
+ private cameraBlockTotem: CameraUniformBlockTotem;
21
+ private updateCallback: UpdateCallback;
22
+
23
+ constructor(globe: Globe, threshold: number, timeoutMs: number, updateCallback: UpdateCallback) {
24
+ this.threshold = threshold;
25
+ this.timeoutMs = timeoutMs;
26
+ this.updateCallback = updateCallback;
27
+ this.globe = globe;
28
+ this.cameraBlockTotem = CameraUniformBlockTotemCache.get(globe);
29
+
30
+ }
31
+
32
+ trigger(level: number | null = null) {
33
+ const globeChanges = this.cameraBlockTotem.getGlobeChanges();
34
+ if (!globeChanges.screenMoved) return;
35
+ this.setChanges(globeChanges);
36
+ if (globeChanges.geometry || globeChanges.elevationScale || globeChanges.lod2DWheel) {
37
+ this.triggerUpdate();
38
+ return;
39
+ }
40
+
41
+ this.count++;
42
+ if (this.count === 1) {
43
+ this.startTimeout();
44
+ }
45
+ if (this.count >= this.threshold) {
46
+ this.triggerUpdate();
47
+ }
48
+ }
49
+
50
+ private startTimeout() {
51
+ this.clearTimeout();
52
+ this.timeoutId = setTimeout(() => {
53
+ this.triggerUpdate();
54
+ }, this.timeoutMs);
55
+ }
56
+
57
+ private triggerUpdate() {
58
+ this.clearTimeout();
59
+ this.updateCallback(this.accumulatedChanges);
60
+ this.reset();
61
+ }
62
+
63
+ private clearTimeout() {
64
+ if (this.timeoutId) {
65
+ clearTimeout(this.timeoutId);
66
+ this.timeoutId = null;
67
+ }
68
+ }
69
+
70
+ private setChanges(changes: GlobeChanges) {
71
+ // accumulate true states until reset
72
+ this.accumulatedChanges.geometry = this.accumulatedChanges.geometry || changes.geometry;
73
+ this.accumulatedChanges.look = this.accumulatedChanges.look || changes.look;
74
+ this.accumulatedChanges.lod = this.accumulatedChanges.lod || changes.lod;
75
+ this.accumulatedChanges.elevationScale = this.accumulatedChanges.elevationScale || changes.elevationScale;
76
+ this.accumulatedChanges.screenMoved = this.accumulatedChanges.screenMoved || changes.screenMoved;
77
+ this.accumulatedChanges.lod2DWheel = this.accumulatedChanges.lod2DWheel || changes.lod2DWheel;
78
+ }
79
+
80
+
81
+ getLevel() {
82
+ return this.accumulatedChanges;
83
+ }
84
+
85
+ reset() {
86
+ this.count = 0;
87
+ this.accumulatedChanges.geometry = false;
88
+ this.accumulatedChanges.look = false;
89
+ this.accumulatedChanges.lod = false;
90
+ this.accumulatedChanges.lod2DWheel = false;
91
+ this.accumulatedChanges.elevationScale = false;
92
+ this.accumulatedChanges.screenMoved = false;
93
+ this.clearTimeout();
94
+ }
95
+
96
+ free() {
97
+ CameraUniformBlockTotemCache.release(this.globe);
98
+ }
99
+ }
@@ -0,0 +1,64 @@
1
+ import { Globe } from "../../types";
2
+
3
+
4
+ interface PixelXY {
5
+ x: number;
6
+ y: number;
7
+ }
8
+
9
+
10
+
11
+ function latLongToPixelXY(latitude: number, longitude: number): PixelXY {
12
+ return {
13
+ x: (longitude + 180) / 360,
14
+ y: (90 - latitude) / 180
15
+ };
16
+ }
17
+
18
+ /**
19
+ * createBBoxMatrix( minX, maxX, minY, maxY)
20
+ * use this matrix to transform a point from 0 to 1 range to the bounding box
21
+ * for example: Transform image coordinates to map coordinates
22
+ * glsl`vec3 pos = u_bbox_matrix * vec3(v_particle_pos.x, v_particle_pos.y, 1.0);`
23
+ */
24
+ function createBBoxMatrix(minX: number, maxX: number, minY: number, maxY: number): Float32Array {
25
+ return new Float32Array([
26
+ maxX - minX, 0, 0,
27
+ 0, maxY - minY, 0,
28
+ minX, minY, 1
29
+ ])
30
+ }
31
+
32
+ function latLongBboxtoPixelXYBbox(minX: number, minY: number, maxX: number, maxY: number): Float32Array {
33
+ const minXY = latLongToPixelXY(minY, minX);
34
+ const maxXY = latLongToPixelXY(maxY, maxX);
35
+ return createBBoxMatrix(minXY.x, maxXY.x, minXY.y, maxXY.y);
36
+ }
37
+
38
+ /**
39
+ *
40
+ * @param array - The array to normalize
41
+ * @param newLength - The target length for the normalized array
42
+ * @returns Normalized Float32Array
43
+ */
44
+ function normalize(array: ArrayLike<number>, newLength: number = 1): Float32Array {
45
+ let total = 0;
46
+ for (let i = 0; i < array.length; i++) {
47
+ total += array[i] * array[i];
48
+ }
49
+ const len = newLength / Math.sqrt(total);
50
+ const result = new Float32Array(array.length);
51
+ for (let i = 0; i < array.length; i++) {
52
+ result[i] = array[i] * len;
53
+ }
54
+ return result;
55
+ }
56
+
57
+
58
+ // TODO carry the usefull content to math module.
59
+ function sphereCoord(long: number, lat: number, globe: Globe, height: number = 0): Float32Array {
60
+ return normalize(globe.api_GetCartesian3DPoint(long, lat, 0, false), 6378.137 + height);
61
+ }
62
+
63
+ export { createBBoxMatrix, latLongToPixelXY, latLongBboxtoPixelXYBbox, sphereCoord, normalize };
64
+ export type { PixelXY, Globe };
@@ -0,0 +1,84 @@
1
+ import { BufferAndReadInfo, AttributeLoaderOptions } from "../../../types";
2
+
3
+
4
+ /**
5
+ * @typedef BufferAndReadInfo Buffers can be intertwined or interleaved.
6
+ * This object forces user to adapt generic convention of buffer and read information.
7
+ * @type {Object}
8
+ * @property {WebGLBuffer} buffer
9
+ * @property {number} stride
10
+ * @property {number} offset
11
+ */
12
+
13
+ /**
14
+ *
15
+ * @param {WebGLBuffer} gl
16
+ * @param {BufferAndReadInfo} bufferAndReadInfo
17
+ * @param {number} index
18
+ * @param {number} size
19
+ * @param {Object} options
20
+ * @param {*} options.type | default gl.FLOAT, gl.UNSIGNED_BYTE, gl.SHORT, gl.UNSIGNED_SHORT, gl.INT, gl.UNSIGNED_INT
21
+ * @param {number} options.divisor
22
+ * @param {Array<number>} options.escapeValues
23
+ * @returns
24
+ */
25
+
26
+
27
+
28
+ const attributeLoader = (
29
+ gl: WebGL2RenderingContext,
30
+ bufferAndReadInfo: BufferAndReadInfo | null,
31
+ index: number,
32
+ size: number,
33
+ {
34
+ divisor = null,
35
+ type = null,
36
+ escapeValues = null,
37
+ normalized = false
38
+ }: AttributeLoaderOptions = {}) => {
39
+ if (bufferAndReadInfo == null || bufferAndReadInfo.buffer == null) {
40
+ if (escapeValues) constantFunction(gl, index, size, escapeValues);
41
+ return;
42
+ }
43
+
44
+ const { buffer, stride, offset } = bufferAndReadInfo;
45
+ if (!gl || !buffer) {
46
+ throw new Error("Invalid WebGL context or buffer");
47
+ }
48
+ if (index < 0) {
49
+ throw new Error("Attribute index must be non-negative");
50
+ }
51
+ if (stride < 0 || offset < 0) {
52
+ throw new Error("Stride and offset must be non-negative");
53
+ }
54
+ const attribType = type === null ? gl.FLOAT : type;
55
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
56
+ gl.enableVertexAttribArray(index);
57
+ gl.vertexAttribPointer(index, size, attribType, normalized, stride, offset);
58
+ if (divisor !== null) {
59
+ gl.vertexAttribDivisor(index, divisor);
60
+ }
61
+ }
62
+
63
+ /**
64
+ *
65
+ * @param {WebGLBuffer} buffer
66
+ * @param {number} stride
67
+ * @param {number} offset
68
+ * @returns {BufferAndReadInfo}
69
+ */
70
+ const createBufferAndReadInfo = (buffer: WebGLBuffer | null, stride: number = 0, offset: number = 0): BufferAndReadInfo | null => {
71
+ if (buffer == null) return null;
72
+ return { buffer, stride, offset };
73
+ }
74
+
75
+
76
+
77
+ const constantFunction = (gl: WebGL2RenderingContext, index: number, size: number, escapeValues: Array<number>) => {
78
+ const func = `vertexAttrib${size}f`;
79
+ // @ts-ignore
80
+ gl[func](index, ...escapeValues);
81
+ }
82
+
83
+
84
+ export { attributeLoader, createBufferAndReadInfo };
@@ -0,0 +1,6 @@
1
+ // import './types';
2
+
3
+ import { attributeLoader } from './attribute-loader';
4
+
5
+
6
+ export { attributeLoader };
@@ -0,0 +1,47 @@
1
+ import { DrawRangeIndexParams, DrawRange } from "../../../types"
2
+ /**
3
+ * Draws instanced geometry using WebGL2.
4
+ */
5
+ const drawInstanced = (
6
+ gl: WebGL2RenderingContext,
7
+ mode: GLenum,
8
+ drawOptions: DrawRangeIndexParams,
9
+ vertexCount: number
10
+ ): void => {
11
+ const { drawRange, elementBufferIndexType = gl.UNSIGNED_INT } = drawOptions;
12
+ const { first = 0, count } = drawRange;
13
+ if (drawOptions.elementBuffer) {
14
+ gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, drawOptions.elementBuffer ?? null);
15
+ gl.drawElementsInstanced(mode, vertexCount, elementBufferIndexType, first, count);
16
+ gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null);
17
+ } else {
18
+ gl.drawArraysInstanced(mode, first, vertexCount, count);
19
+ }
20
+ }
21
+
22
+ /**
23
+ * Draws geometry using WebGL2.
24
+ */
25
+ const drawArrays = (
26
+ gl: WebGL2RenderingContext,
27
+ defaultMode: GLenum,
28
+ drawOptions: DrawRangeIndexParams
29
+ ): void => {
30
+ const {
31
+ drawRange,
32
+ elementBuffer,
33
+ elementBufferIndexType = gl.UNSIGNED_INT,
34
+ drawMode = null
35
+ } = drawOptions;
36
+ const { first = 0, count } = drawRange;
37
+ const mode = drawMode ?? defaultMode;
38
+ if (elementBuffer) {
39
+ gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, elementBuffer);
40
+ gl.drawElements(mode, count, elementBufferIndexType, first);
41
+ gl.bindBuffer(gl.ELEMENT_ARRAY_BUFFER, null);
42
+ } else {
43
+ gl.drawArrays(mode, first, count);
44
+ }
45
+ }
46
+
47
+ export { drawArrays, drawInstanced }