@pirireis/webglobeplugins 0.16.0 → 0.16.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (480) hide show
  1. package/Math/angle-calculation.js +13 -14
  2. package/Math/bounds/line-bbox.js +186 -225
  3. package/Math/index.js +1 -0
  4. package/Math/mesh/mapbox-delaunay.js +544 -607
  5. package/Math/utils.js +2 -3
  6. package/algorithms/search-binary.js +16 -14
  7. package/altitude-locator/adaptors.js +1 -0
  8. package/altitude-locator/keymethod.js +1 -0
  9. package/altitude-locator/plugin.js +345 -446
  10. package/altitude-locator/types.js +21 -26
  11. package/arrowfield/adaptor.js +11 -11
  12. package/arrowfield/index.js +3 -3
  13. package/arrowfield/plugin.js +83 -128
  14. package/bearing-line/index.js +2 -2
  15. package/bearing-line/plugin.js +444 -520
  16. package/circle-line-chain/chain-list-map.js +201 -221
  17. package/circle-line-chain/init.js +1 -0
  18. package/circle-line-chain/plugin.js +411 -464
  19. package/circle-line-chain/util.js +1 -1
  20. package/compass-rose/compass-rose-padding-flat.js +230 -274
  21. package/compass-rose/compass-text-writer.js +149 -173
  22. package/compass-rose/index.js +3 -3
  23. package/compassrose/compassrose.js +293 -341
  24. package/compassrose/index.js +2 -2
  25. package/constants.js +3 -0
  26. package/heatwave/index.js +3 -4
  27. package/heatwave/isobar/objectarraylabels.js +200 -247
  28. package/heatwave/isobar/plugin.js +302 -339
  29. package/heatwave/isobar/quadtreecontours.js +298 -336
  30. package/heatwave/plugins/heatwaveglobeshell.js +204 -259
  31. package/index.js +12 -15
  32. package/jest.config.js +7 -6
  33. package/package.json +1 -4
  34. package/partialrings/buffer-manager.js +75 -89
  35. package/partialrings/index.js +2 -3
  36. package/partialrings/plugin.js +128 -160
  37. package/partialrings/program.js +188 -233
  38. package/pin/pin-object-array.js +300 -381
  39. package/pin/pin-point-totem.js +60 -77
  40. package/point-heat-map/adaptors/timetracksplugin-format-to-this.js +63 -78
  41. package/point-heat-map/index.js +1 -0
  42. package/point-heat-map/plugin-webworker.js +121 -148
  43. package/point-heat-map/point-to-heat-map-flow.js +124 -150
  44. package/point-tracks/key-methods.js +2 -3
  45. package/point-tracks/plugin.js +393 -480
  46. package/programs/arrowfield/index.js +2 -2
  47. package/programs/arrowfield/logic.js +141 -173
  48. package/programs/arrowfield/object.js +60 -89
  49. package/programs/data2legend/density-to-legend.js +73 -90
  50. package/programs/data2legend/point-to-density-texture.js +70 -87
  51. package/programs/float2legendwithratio/index.js +2 -3
  52. package/programs/float2legendwithratio/logic.js +118 -144
  53. package/programs/float2legendwithratio/object.js +104 -141
  54. package/programs/globe-util/is-globe-moved.js +19 -27
  55. package/programs/globeshell/index.js +2 -2
  56. package/programs/globeshell/wiggle/index.js +2 -3
  57. package/programs/globeshell/wiggle/logic.js +243 -272
  58. package/programs/globeshell/wiggle/object.js +66 -93
  59. package/programs/helpers/blender/index.js +1 -0
  60. package/programs/helpers/blender/program.js +58 -73
  61. package/programs/helpers/fadeaway/index.js +2 -3
  62. package/programs/helpers/fadeaway/logic.js +46 -53
  63. package/programs/helpers/fadeaway/object.js +14 -20
  64. package/programs/helpers/index.js +2 -2
  65. package/programs/index.js +9 -21
  66. package/programs/line-on-globe/circle-accurate-3d.js +87 -115
  67. package/programs/line-on-globe/circle-accurate-flat.js +149 -201
  68. package/programs/line-on-globe/degree-padding-around-circle-3d.js +104 -136
  69. package/programs/line-on-globe/index.js +1 -0
  70. package/programs/line-on-globe/lines-color-instanced-flat.js +83 -102
  71. package/programs/line-on-globe/util.js +5 -8
  72. package/programs/picking/pickable-polygon-renderer.js +98 -129
  73. package/programs/picking/pickable-renderer.js +98 -129
  74. package/programs/point-on-globe/element-globe-surface-glow.js +93 -122
  75. package/programs/point-on-globe/element-point-glow.js +80 -114
  76. package/programs/point-on-globe/square-pixel-point.js +120 -138
  77. package/programs/rings/distancering/circleflatprogram.js +116 -138
  78. package/programs/rings/distancering/circlepaddingfreeangleprogram.js +275 -323
  79. package/programs/rings/distancering/circlepaddysharedbuffer.js +368 -423
  80. package/programs/rings/distancering/index.js +6 -5
  81. package/programs/rings/distancering/paddyflatprogram.js +127 -148
  82. package/programs/rings/distancering/paddyflatprogram2d.js +129 -153
  83. package/programs/rings/distancering/paddyflatprogram3d.js +128 -149
  84. package/programs/rings/index.js +1 -1
  85. package/{dist/programs → programs}/totems/camerauniformblock.js +10 -3
  86. package/programs/totems/gpu-selection-uniform-block.js +99 -127
  87. package/programs/two-d/pixel-circle.js +1 -0
  88. package/programs/two-d/pixel-padding-for-compass.js +97 -112
  89. package/programs/util.js +14 -19
  90. package/programs/vectorfields/index.js +3 -3
  91. package/programs/vectorfields/logics/drawrectangleparticles.js +58 -78
  92. package/programs/vectorfields/logics/index.js +2 -4
  93. package/programs/vectorfields/logics/pixelbased.js +73 -92
  94. package/programs/vectorfields/logics/ubo.js +51 -57
  95. package/programs/vectorfields/pingpongbuffermanager.js +73 -80
  96. package/rangerings/index.js +5 -5
  97. package/rangerings/plugin.js +543 -644
  98. package/rangerings/rangeringangletext.js +326 -369
  99. package/rangerings/ring-account.js +112 -129
  100. package/shaders/fragment-toy/firework.js +1 -1
  101. package/shaders/fragment-toy/singularity.js +2 -5
  102. package/timetracks/adaptors-line-strip.js +65 -80
  103. package/timetracks/index.js +1 -0
  104. package/timetracks/plugin-line-strip.js +240 -295
  105. package/timetracks/program-line-strip.js +411 -491
  106. package/timetracks/programpoint-line-strip.js +98 -122
  107. package/util/account/bufferoffsetmanager.js +176 -209
  108. package/util/account/index.js +3 -6
  109. package/util/account/util.js +18 -22
  110. package/util/algorithms/index.js +1 -0
  111. package/util/algorithms/search-binary.js +25 -26
  112. package/util/check/index.js +1 -0
  113. package/util/geometry/index.js +121 -0
  114. package/util/gl-util/uniform-block/shader.js +1 -0
  115. package/util/heatwavedatamanager/datamanager.js +149 -168
  116. package/util/heatwavedatamanager/index.js +2 -2
  117. package/util/index.js +13 -13
  118. package/util/interpolation/index.js +1 -0
  119. package/util/interpolation/timetrack/index.js +2 -9
  120. package/util/interpolation/timetrack/timetrack-interpolator.js +79 -94
  121. package/util/interpolation/timetrack/web-worker.js +46 -51
  122. package/util/jshelpers/data-filler.js +17 -19
  123. package/util/jshelpers/equality.js +18 -17
  124. package/util/jshelpers/index.js +2 -1
  125. package/util/jshelpers/timefilters.js +30 -32
  126. package/util/picking/fence.js +43 -46
  127. package/util/picking/picker-displayer.js +136 -177
  128. package/util/programs/draw-texture-on-canvas.js +66 -82
  129. package/util/programs/index.js +1 -1
  130. package/util/programs/shapesonglobe.js +167 -203
  131. package/util/programs/supersampletotextures.js +99 -132
  132. package/util/programs/texturetoglobe.js +128 -152
  133. package/util/shaderfunctions/index.js +2 -2
  134. package/util/shaderfunctions/nodata.js +2 -4
  135. package/util/shaderfunctions/noisefunctions.js +7 -10
  136. package/util/surface-line-data/arcs-to-cuts.js +50 -74
  137. package/util/surface-line-data/cut-arc.js +1 -0
  138. package/util/surface-line-data/rbush-manager.js +1 -0
  139. package/util/surface-line-data/web-worker.js +1 -0
  140. package/util/webglobe/gldefaultstates.js +4 -5
  141. package/util/webglobe/index.js +2 -2
  142. package/util/webglobe/rasteroverlay.js +75 -96
  143. package/waveparticles/adaptor.js +15 -16
  144. package/waveparticles/index.js +3 -3
  145. package/waveparticles/plugin.js +290 -342
  146. package/wind/imagetovectorfieldandmagnitude.js +56 -71
  147. package/wind/index.js +5 -5
  148. package/wind/plugin.js +670 -845
  149. package/wind/vectorfieldimage.js +23 -27
  150. package/write-text/attached-text-writer.js +87 -105
  151. package/{dist/write-text → write-text}/context-text-bulk.js +28 -15
  152. package/write-text/context-text.js +94 -125
  153. package/write-text/context-text3old.js +152 -179
  154. package/write-text/index.js +1 -1
  155. package/write-text/writer-plugin.js +8 -7
  156. package/Math/arc-cdf-points.ts +0 -329
  157. package/Math/arc-generate-points-exponantial.ts +0 -299
  158. package/Math/arc.ts +0 -299
  159. package/Math/circle-cdf-points.ts +0 -143
  160. package/Math/circle.ts +0 -49
  161. package/Math/constants.ts +0 -12
  162. package/Math/juction/arc-plane.ts +0 -129
  163. package/Math/juction/line-sphere.ts +0 -30
  164. package/Math/juction/plane-plane.ts +0 -64
  165. package/Math/line.ts +0 -84
  166. package/Math/matrix4.ts +0 -0
  167. package/Math/methods.ts +0 -157
  168. package/Math/plane.ts +0 -92
  169. package/Math/quaternion.ts +0 -128
  170. package/Math/roadmap.md +0 -10
  171. package/Math/templete-shapes/grid-visually-equal.ts +0 -119
  172. package/Math/types.ts +0 -66
  173. package/Math/vec3.ts +0 -180
  174. package/circle-line-chain/readme.md +0 -57
  175. package/depth-locator/readme.md +0 -26
  176. package/dist/Math/angle-calculation.js +0 -13
  177. package/dist/Math/bounds/line-bbox.js +0 -186
  178. package/dist/Math/index.js +0 -1
  179. package/dist/Math/mesh/mapbox-delaunay.js +0 -544
  180. package/dist/Math/utils.js +0 -2
  181. package/dist/algorithms/search-binary.js +0 -16
  182. package/dist/altitude-locator/adaptors.js +0 -1
  183. package/dist/altitude-locator/keymethod.js +0 -1
  184. package/dist/altitude-locator/plugin.js +0 -345
  185. package/dist/altitude-locator/types.js +0 -21
  186. package/dist/arrowfield/adaptor.js +0 -11
  187. package/dist/arrowfield/index.js +0 -3
  188. package/dist/arrowfield/plugin.js +0 -83
  189. package/dist/bearing-line/index.js +0 -2
  190. package/dist/bearing-line/plugin.js +0 -444
  191. package/dist/circle-line-chain/chain-list-map.js +0 -201
  192. package/dist/circle-line-chain/init.js +0 -1
  193. package/dist/circle-line-chain/plugin.js +0 -411
  194. package/dist/circle-line-chain/util.js +0 -1
  195. package/dist/compass-rose/compass-rose-padding-flat.js +0 -230
  196. package/dist/compass-rose/compass-text-writer.js +0 -149
  197. package/dist/compass-rose/index.js +0 -3
  198. package/dist/compassrose/compassrose.js +0 -293
  199. package/dist/compassrose/index.js +0 -2
  200. package/dist/heatwave/index.js +0 -3
  201. package/dist/heatwave/isobar/objectarraylabels.js +0 -200
  202. package/dist/heatwave/isobar/plugin.js +0 -302
  203. package/dist/heatwave/isobar/quadtreecontours.js +0 -298
  204. package/dist/heatwave/plugins/heatwaveglobeshell.js +0 -204
  205. package/dist/index.js +0 -12
  206. package/dist/jest.config.js +0 -7
  207. package/dist/partialrings/buffer-manager.js +0 -75
  208. package/dist/partialrings/index.js +0 -2
  209. package/dist/partialrings/plugin.js +0 -128
  210. package/dist/partialrings/program.js +0 -279
  211. package/dist/pin/pin-object-array.js +0 -300
  212. package/dist/pin/pin-point-totem.js +0 -60
  213. package/dist/point-heat-map/adaptors/timetracksplugin-format-to-this.js +0 -63
  214. package/dist/point-heat-map/index.js +0 -1
  215. package/dist/point-heat-map/plugin-webworker.js +0 -121
  216. package/dist/point-heat-map/point-to-heat-map-flow.js +0 -124
  217. package/dist/point-tracks/key-methods.js +0 -2
  218. package/dist/point-tracks/plugin.js +0 -393
  219. package/dist/programs/arrowfield/index.js +0 -2
  220. package/dist/programs/arrowfield/logic.js +0 -254
  221. package/dist/programs/arrowfield/object.js +0 -60
  222. package/dist/programs/data2legend/density-to-legend.js +0 -98
  223. package/dist/programs/data2legend/point-to-density-texture.js +0 -97
  224. package/dist/programs/float2legendwithratio/index.js +0 -2
  225. package/dist/programs/float2legendwithratio/logic.js +0 -167
  226. package/dist/programs/float2legendwithratio/object.js +0 -104
  227. package/dist/programs/globe-util/is-globe-moved.js +0 -19
  228. package/dist/programs/globeshell/index.js +0 -2
  229. package/dist/programs/globeshell/wiggle/index.js +0 -2
  230. package/dist/programs/globeshell/wiggle/logic.js +0 -342
  231. package/dist/programs/globeshell/wiggle/object.js +0 -66
  232. package/dist/programs/helpers/blender/index.js +0 -1
  233. package/dist/programs/helpers/blender/program.js +0 -76
  234. package/dist/programs/helpers/fadeaway/index.js +0 -2
  235. package/dist/programs/helpers/fadeaway/logic.js +0 -69
  236. package/dist/programs/helpers/fadeaway/object.js +0 -14
  237. package/dist/programs/helpers/index.js +0 -2
  238. package/dist/programs/index.js +0 -9
  239. package/dist/programs/line-on-globe/circle-accurate-3d.js +0 -138
  240. package/dist/programs/line-on-globe/circle-accurate-flat.js +0 -210
  241. package/dist/programs/line-on-globe/degree-padding-around-circle-3d.js +0 -156
  242. package/dist/programs/line-on-globe/index.js +0 -1
  243. package/dist/programs/line-on-globe/lines-color-instanced-flat.js +0 -131
  244. package/dist/programs/line-on-globe/util.js +0 -5
  245. package/dist/programs/picking/pickable-polygon-renderer.js +0 -184
  246. package/dist/programs/picking/pickable-renderer.js +0 -184
  247. package/dist/programs/point-on-globe/element-globe-surface-glow.js +0 -138
  248. package/dist/programs/point-on-globe/element-point-glow.js +0 -150
  249. package/dist/programs/point-on-globe/square-pixel-point.js +0 -171
  250. package/dist/programs/rings/distancering/circleflatprogram.js +0 -116
  251. package/dist/programs/rings/distancering/circlepaddingfreeangleprogram.js +0 -326
  252. package/dist/programs/rings/distancering/circlepaddysharedbuffer.js +0 -368
  253. package/dist/programs/rings/distancering/index.js +0 -6
  254. package/dist/programs/rings/distancering/paddyflatprogram.js +0 -127
  255. package/dist/programs/rings/distancering/paddyflatprogram2d.js +0 -129
  256. package/dist/programs/rings/distancering/paddyflatprogram3d.js +0 -128
  257. package/dist/programs/rings/index.js +0 -1
  258. package/dist/programs/totems/gpu-selection-uniform-block.js +0 -104
  259. package/dist/programs/two-d/pixel-circle.js +0 -1
  260. package/dist/programs/two-d/pixel-padding-for-compass.js +0 -159
  261. package/dist/programs/util.js +0 -14
  262. package/dist/programs/vectorfields/index.js +0 -3
  263. package/dist/programs/vectorfields/logics/drawrectangleparticles.js +0 -113
  264. package/dist/programs/vectorfields/logics/index.js +0 -2
  265. package/dist/programs/vectorfields/logics/pixelbased.js +0 -140
  266. package/dist/programs/vectorfields/logics/ubo.js +0 -60
  267. package/dist/programs/vectorfields/pingpongbuffermanager.js +0 -73
  268. package/dist/rangerings/index.js +0 -5
  269. package/dist/rangerings/plugin.js +0 -543
  270. package/dist/rangerings/rangeringangletext.js +0 -326
  271. package/dist/rangerings/ring-account.js +0 -112
  272. package/dist/shaders/fragment-toy/firework.js +0 -55
  273. package/dist/shaders/fragment-toy/singularity.js +0 -56
  274. package/dist/timetracks/adaptors-line-strip.js +0 -65
  275. package/dist/timetracks/index.js +0 -1
  276. package/dist/timetracks/plugin-line-strip.js +0 -240
  277. package/dist/timetracks/program-line-strip.js +0 -608
  278. package/dist/timetracks/programpoint-line-strip.js +0 -151
  279. package/dist/util/account/bufferoffsetmanager.js +0 -176
  280. package/dist/util/account/index.js +0 -3
  281. package/dist/util/account/util.js +0 -18
  282. package/dist/util/algorithms/index.js +0 -1
  283. package/dist/util/algorithms/search-binary.js +0 -25
  284. package/dist/util/check/index.js +0 -1
  285. package/dist/util/geometry/index.js +0 -47
  286. package/dist/util/gl-util/uniform-block/shader.js +0 -1
  287. package/dist/util/heatwavedatamanager/datamanager.js +0 -149
  288. package/dist/util/heatwavedatamanager/index.js +0 -2
  289. package/dist/util/index.js +0 -13
  290. package/dist/util/interpolation/index.js +0 -1
  291. package/dist/util/interpolation/timetrack/index.js +0 -2
  292. package/dist/util/interpolation/timetrack/timetrack-interpolator.js +0 -79
  293. package/dist/util/interpolation/timetrack/web-worker.js +0 -46
  294. package/dist/util/jshelpers/data-filler.js +0 -17
  295. package/dist/util/jshelpers/equality.js +0 -18
  296. package/dist/util/jshelpers/index.js +0 -2
  297. package/dist/util/jshelpers/timefilters.js +0 -30
  298. package/dist/util/picking/fence.js +0 -43
  299. package/dist/util/picking/picker-displayer.js +0 -136
  300. package/dist/util/programs/draw-texture-on-canvas.js +0 -86
  301. package/dist/util/programs/index.js +0 -1
  302. package/dist/util/programs/shapesonglobe.js +0 -210
  303. package/dist/util/programs/supersampletotextures.js +0 -109
  304. package/dist/util/programs/texturetoglobe.js +0 -179
  305. package/dist/util/shaderfunctions/index.js +0 -2
  306. package/dist/util/shaderfunctions/nodata.js +0 -8
  307. package/dist/util/shaderfunctions/noisefunctions.js +0 -41
  308. package/dist/util/surface-line-data/arcs-to-cuts.js +0 -50
  309. package/dist/util/surface-line-data/cut-arc.js +0 -1
  310. package/dist/util/surface-line-data/rbush-manager.js +0 -1
  311. package/dist/util/surface-line-data/web-worker.js +0 -1
  312. package/dist/util/webglobe/gldefaultstates.js +0 -4
  313. package/dist/util/webglobe/index.js +0 -2
  314. package/dist/util/webglobe/rasteroverlay.js +0 -75
  315. package/dist/waveparticles/adaptor.js +0 -15
  316. package/dist/waveparticles/index.js +0 -3
  317. package/dist/waveparticles/plugin.js +0 -290
  318. package/dist/wind/imagetovectorfieldandmagnitude.js +0 -56
  319. package/dist/wind/index.js +0 -5
  320. package/dist/wind/plugin.js +0 -921
  321. package/dist/wind/vectorfieldimage.js +0 -23
  322. package/dist/write-text/attached-text-writer.js +0 -87
  323. package/dist/write-text/context-text.js +0 -94
  324. package/dist/write-text/context-text3old.js +0 -152
  325. package/dist/write-text/index.js +0 -1
  326. package/dist/write-text/writer-plugin.js +0 -8
  327. package/partialrings/goals.md +0 -17
  328. package/point-heat-map/readme.md +0 -15
  329. package/programs/line-on-globe/linestrip/data.ts +0 -29
  330. package/programs/line-on-globe/linestrip/linestrip.ts +0 -201
  331. package/programs/line-on-globe/naive-accurate-flexible.ts +0 -258
  332. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin.ts +0 -120
  333. package/programs/polygon-on-globe/texture-dem-triangles.ts +0 -207
  334. package/programs/programcache.ts +0 -131
  335. package/programs/rings/partial-ring/piece-of-pie.ts +0 -323
  336. package/programs/totems/camerauniformblock.ts +0 -310
  337. package/programs/totems/canvas-webglobe-info.ts +0 -156
  338. package/programs/totems/globe-changes.ts +0 -79
  339. package/programs/totems/index.ts +0 -2
  340. package/programs/vectorfields/logics/constants.ts +0 -5
  341. package/programs/vectorfields/logics/ubo-new.ts +0 -37
  342. package/publish.bat +0 -62
  343. package/range-tools-on-terrain/bearing-line/adapters.ts +0 -154
  344. package/range-tools-on-terrain/bearing-line/plugin.ts +0 -569
  345. package/range-tools-on-terrain/bearing-line/types.ts +0 -65
  346. package/range-tools-on-terrain/circle-line-chain/adapters.ts +0 -109
  347. package/range-tools-on-terrain/circle-line-chain/chain-list-map.ts +0 -446
  348. package/range-tools-on-terrain/circle-line-chain/plugin.ts +0 -607
  349. package/range-tools-on-terrain/circle-line-chain/types.ts +0 -43
  350. package/range-tools-on-terrain/range-ring/adapters.ts +0 -114
  351. package/range-tools-on-terrain/range-ring/enum.ts +0 -2
  352. package/range-tools-on-terrain/range-ring/plugin.ts +0 -447
  353. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +0 -396
  354. package/range-tools-on-terrain/range-ring/types.ts +0 -30
  355. package/rangerings/enum.ts +0 -2
  356. package/semiplugins/interface.ts +0 -14
  357. package/semiplugins/lightweight/line-plugin.ts +0 -343
  358. package/semiplugins/lightweight/piece-of-pie-plugin.ts +0 -275
  359. package/semiplugins/shape-on-terrain/arc-plugin.ts +0 -602
  360. package/semiplugins/shape-on-terrain/circle-plugin.ts +0 -588
  361. package/semiplugins/shape-on-terrain/goal.md +0 -12
  362. package/semiplugins/shape-on-terrain/padding-1-degree.ts +0 -714
  363. package/semiplugins/shape-on-terrain/terrain-cover/notes.md +0 -90
  364. package/semiplugins/shape-on-terrain/terrain-cover/texture-dem-cover.ts +0 -0
  365. package/semiplugins/type.ts +0 -8
  366. package/tests/Math/arc-sampling-test.js +0 -367
  367. package/tests/Math/arc-sampling-test.ts +0 -429
  368. package/tests/Math/arc.test.ts +0 -102
  369. package/tests/Math/junction/arc-plane.test.ts +0 -163
  370. package/tests/Math/junction/plane-plane.test.ts +0 -91
  371. package/tests/Math/plane-test.ts +0 -17
  372. package/tests/Math/plane.test.ts +0 -43
  373. package/tests/Math/vec3.test.ts +0 -14
  374. package/timetracks/readme.md +0 -1
  375. package/tsconfig.json +0 -22
  376. package/types.ts +0 -265
  377. package/util/account/create-buffermap-orchastration.ts +0 -85
  378. package/util/account/single-attribute-buffer-management/buffer-manager.ts +0 -149
  379. package/util/account/single-attribute-buffer-management/buffer-orchestrator.ts +0 -332
  380. package/util/account/single-attribute-buffer-management/buffer-orchestrator1.ts +0 -184
  381. package/util/account/single-attribute-buffer-management/index.ts +0 -11
  382. package/util/account/single-attribute-buffer-management/object-store.ts +0 -76
  383. package/util/account/single-attribute-buffer-management/types.ts +0 -43
  384. package/util/build-strategy/general-strategy.ts +0 -99
  385. package/util/build-strategy/static-dynamic.ts +0 -50
  386. package/util/check/typecheck.ts +0 -74
  387. package/util/frame-counter-trigger.ts +0 -99
  388. package/util/geometry/index.ts +0 -64
  389. package/util/gl-util/buffer/attribute-loader.ts +0 -84
  390. package/util/gl-util/buffer/index.ts +0 -6
  391. package/util/gl-util/draw-options/methods.ts +0 -47
  392. package/util/gl-util/uniform-block/manager.ts +0 -210
  393. package/util/gl-util/uniform-block/roadmap.md +0 -70
  394. package/util/gl-util/uniform-block/types.ts +0 -20
  395. package/util/heatwavedatamanager/pointcoordsmeta.ts +0 -28
  396. package/util/heatwavedatamanager/texture-point-sampler.ts +0 -198
  397. package/util/shaderfunctions/geometrytransformations.ts +0 -388
  398. package/util/surface-line-data/arc-bboxes.ts +0 -42
  399. package/util/surface-line-data/flow.ts +0 -52
  400. package/util/surface-line-data/types.ts +0 -27
  401. package/util/webglobjectbuilders.ts +0 -446
  402. package/write-text/context-text-bulk.ts +0 -268
  403. package/write-text/context-text3.ts +0 -253
  404. package/write-text/context-text4.ts +0 -243
  405. /package/{dist/Math → Math}/arc-cdf-points.js +0 -0
  406. /package/{dist/Math → Math}/arc-generate-points-exponantial.js +0 -0
  407. /package/{dist/Math → Math}/arc.js +0 -0
  408. /package/{dist/Math → Math}/circle-cdf-points.js +0 -0
  409. /package/{dist/Math → Math}/circle.js +0 -0
  410. /package/{dist/Math → Math}/constants.js +0 -0
  411. /package/{dist/Math → Math}/juction/arc-plane.js +0 -0
  412. /package/{dist/Math → Math}/juction/line-sphere.js +0 -0
  413. /package/{dist/Math → Math}/juction/plane-plane.js +0 -0
  414. /package/{dist/Math → Math}/line.js +0 -0
  415. /package/{dist/Math → Math}/matrix4.js +0 -0
  416. /package/{dist/Math → Math}/methods.js +0 -0
  417. /package/{dist/Math → Math}/plane.js +0 -0
  418. /package/{dist/Math → Math}/quaternion.js +0 -0
  419. /package/{dist/Math → Math}/templete-shapes/grid-visually-equal.js +0 -0
  420. /package/{dist/Math → Math}/types.js +0 -0
  421. /package/{dist/Math → Math}/vec3.js +0 -0
  422. /package/{dist/programs → programs}/line-on-globe/linestrip/data.js +0 -0
  423. /package/{dist/programs → programs}/line-on-globe/linestrip/linestrip.js +0 -0
  424. /package/{dist/programs → programs}/line-on-globe/naive-accurate-flexible.js +0 -0
  425. /package/{dist/programs → programs}/polygon-on-globe/texture-dem-triangle-test-plugin.js +0 -0
  426. /package/{dist/programs → programs}/polygon-on-globe/texture-dem-triangles.js +0 -0
  427. /package/{dist/programs → programs}/programcache.js +0 -0
  428. /package/{dist/programs → programs}/rings/partial-ring/piece-of-pie.js +0 -0
  429. /package/{dist/programs → programs}/totems/canvas-webglobe-info.js +0 -0
  430. /package/{dist/programs → programs}/totems/globe-changes.js +0 -0
  431. /package/{dist/programs → programs}/totems/index.js +0 -0
  432. /package/{dist/programs → programs}/vectorfields/logics/constants.js +0 -0
  433. /package/{dist/programs → programs}/vectorfields/logics/ubo-new.js +0 -0
  434. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/bearing-line/adapters.js +0 -0
  435. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/bearing-line/plugin.js +0 -0
  436. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/bearing-line/types.js +0 -0
  437. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/adapters.js +0 -0
  438. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/chain-list-map.js +0 -0
  439. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/plugin.js +0 -0
  440. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/circle-line-chain/types.js +0 -0
  441. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/adapters.js +0 -0
  442. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/enum.js +0 -0
  443. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/plugin.js +0 -0
  444. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/rangeringangletext.js +0 -0
  445. /package/{dist/range-tools-on-terrain → range-tools-on-terrain}/range-ring/types.js +0 -0
  446. /package/{dist/rangerings → rangerings}/enum.js +0 -0
  447. /package/{dist/semiplugins → semiplugins}/interface.js +0 -0
  448. /package/{dist/semiplugins → semiplugins}/lightweight/line-plugin.js +0 -0
  449. /package/{dist/semiplugins → semiplugins}/lightweight/piece-of-pie-plugin.js +0 -0
  450. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/arc-plugin.js +0 -0
  451. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/circle-plugin.js +0 -0
  452. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/padding-1-degree.js +0 -0
  453. /package/{dist/semiplugins → semiplugins}/shape-on-terrain/terrain-cover/texture-dem-cover.js +0 -0
  454. /package/{dist/semiplugins → semiplugins}/type.js +0 -0
  455. /package/{dist/types.js → types.js} +0 -0
  456. /package/{dist/util → util}/account/create-buffermap-orchastration.js +0 -0
  457. /package/{dist/util → util}/account/single-attribute-buffer-management/buffer-manager.js +0 -0
  458. /package/{dist/util → util}/account/single-attribute-buffer-management/buffer-orchestrator.js +0 -0
  459. /package/{dist/util → util}/account/single-attribute-buffer-management/buffer-orchestrator1.js +0 -0
  460. /package/{dist/util → util}/account/single-attribute-buffer-management/index.js +0 -0
  461. /package/{dist/util → util}/account/single-attribute-buffer-management/object-store.js +0 -0
  462. /package/{dist/util → util}/account/single-attribute-buffer-management/types.js +0 -0
  463. /package/{dist/util → util}/build-strategy/general-strategy.js +0 -0
  464. /package/{dist/util → util}/build-strategy/static-dynamic.js +0 -0
  465. /package/{dist/util → util}/check/typecheck.js +0 -0
  466. /package/{dist/util → util}/frame-counter-trigger.js +0 -0
  467. /package/{dist/util → util}/gl-util/buffer/attribute-loader.js +0 -0
  468. /package/{dist/util → util}/gl-util/buffer/index.js +0 -0
  469. /package/{dist/util → util}/gl-util/draw-options/methods.js +0 -0
  470. /package/{dist/util → util}/gl-util/uniform-block/manager.js +0 -0
  471. /package/{dist/util → util}/gl-util/uniform-block/types.js +0 -0
  472. /package/{dist/util → util}/heatwavedatamanager/pointcoordsmeta.js +0 -0
  473. /package/{dist/util → util}/heatwavedatamanager/texture-point-sampler.js +0 -0
  474. /package/{dist/util → util}/shaderfunctions/geometrytransformations.js +0 -0
  475. /package/{dist/util → util}/surface-line-data/arc-bboxes.js +0 -0
  476. /package/{dist/util → util}/surface-line-data/flow.js +0 -0
  477. /package/{dist/util → util}/surface-line-data/types.js +0 -0
  478. /package/{dist/util → util}/webglobjectbuilders.js +0 -0
  479. /package/{dist/write-text → write-text}/context-text3.js +0 -0
  480. /package/{dist/write-text → write-text}/context-text4.js +0 -0
@@ -1,64 +0,0 @@
1
- import { Plane, Line, Vec3 } from "../types";
2
- import { EPSILON } from "../constants";
3
- import { copy, create, dot, cross, lengthSquared } from "../vec3";
4
-
5
- const _normal1 = create();
6
- const _normal2 = create();
7
-
8
- export function planePlaneJuction(out: Line, plane1: Plane, plane2: Plane): boolean {
9
- copy(_normal1, plane1.normal);
10
- copy(_normal2, plane2.normal);
11
- const distance1 = plane1.distance;
12
- const distance2 = plane2.distance;
13
-
14
- const { origin, direction } = out;
15
-
16
- const d = dot(_normal1, _normal2);
17
-
18
- if (Math.abs(d) > 1 - EPSILON) {
19
- return false; // Planes are parallel, no intersection
20
- }
21
-
22
- cross(direction, _normal1, _normal2);
23
-
24
- const magnitudeSquired = lengthSquared(out.direction);
25
- if (magnitudeSquired < EPSILON) {
26
- return false; // No valid intersection line
27
- }
28
-
29
- const magnitude = Math.sqrt(magnitudeSquired);
30
- direction[0] /= magnitude;
31
- direction[1] /= magnitude;
32
- direction[2] /= magnitude;
33
-
34
-
35
-
36
- let determinant: number;
37
- // Calculate the intersection point
38
- // set z = 0
39
- determinant = _normal1[0] * _normal2[1] - _normal1[1] * _normal2[0];
40
- if (Math.abs(determinant) > EPSILON) {
41
- origin[0] = (distance1 * _normal2[1] - distance2 * _normal1[1]) / determinant;
42
- origin[1] = (distance2 * _normal1[0] - distance1 * _normal2[0]) / determinant;
43
- origin[2] = 0;
44
- } else {
45
- // set y = 0
46
- determinant = _normal1[0] * _normal2[2] - _normal1[2] * _normal2[0];
47
- if (Math.abs(determinant) > EPSILON) {
48
- origin[0] = (distance1 * _normal2[2] - distance2 * _normal1[2]) / determinant;
49
- origin[1] = 0;
50
- origin[2] = (distance2 * _normal1[0] - distance1 * _normal2[0]) / determinant;
51
- } else {
52
- // set x = 0
53
- determinant = _normal1[1] * _normal2[2] - _normal1[2] * _normal2[1];
54
- if (Math.abs(determinant) > EPSILON) {
55
- origin[0] = 0;
56
- origin[1] = (distance1 * _normal2[2] - distance2 * _normal1[2]) / determinant;
57
- origin[2] = (distance2 * _normal1[1] - distance1 * _normal2[1]) / determinant;
58
- } else {
59
- return false; // No valid intersection point
60
- }
61
- }
62
- }
63
- return true;
64
- }
package/Math/line.ts DELETED
@@ -1,84 +0,0 @@
1
- import { EPSILON } from './constants';
2
- import { Vec3, Line, Quaternion } from './types';
3
- import {
4
- subtract,
5
- applyQuaternion as vec3applyQuaternion,
6
- add,
7
- multiplyScalar,
8
- normalize,
9
- dot,
10
- cross,
11
- lengthSquared,
12
- clone as vec3clone,
13
- create as vec3create,
14
- copy as vec3copy
15
- } from './vec3';
16
-
17
-
18
- const _0vector = /*@__PURE__*/ vec3create(0, 0, 0);
19
-
20
-
21
- function create(origin = vec3create(), direction = vec3create()): Line {
22
- const direction_ = vec3clone(direction);
23
- normalize(direction_, direction_);
24
- return {
25
- origin: vec3clone(origin),
26
- direction: direction_
27
- };
28
- }
29
-
30
- function set(out: Line, origin: Vec3, direction: Vec3) {
31
- vec3copy(out.origin, origin);
32
- vec3copy(out.direction, direction);
33
- }
34
-
35
- function copy(out: Line, a: Line) {
36
- out.origin = vec3copy(out.origin, a.origin);
37
- out.direction = vec3copy(out.direction, a.direction);
38
- }
39
-
40
- function clone(a: Line): Line {
41
- return {
42
- origin: vec3clone(a.origin),
43
- direction: vec3clone(a.direction)
44
- }
45
- }
46
-
47
- function fromTwoPoints(out: Line, a: Vec3, b: Vec3) {
48
- subtract(out.direction, b, a);
49
- normalize(out.direction, out.direction);
50
- vec3copy(out.origin, a);
51
- }
52
-
53
- function at(out: Vec3, line: Line, distance: number) {
54
- multiplyScalar(_0vector, line.direction, distance);
55
- add(out, _0vector, line.origin);
56
- }
57
-
58
-
59
- function closestPoint(out: Vec3, line: Line, point: Vec3) {
60
- subtract(_0vector, point, line.origin);
61
- const dot_ = dot(_0vector, line.direction);
62
- vec3copy(out, line.direction);
63
- multiplyScalar(out, out, dot_);
64
- add(out, out, line.origin);
65
- }
66
-
67
-
68
- function contains(line: Line, point: Vec3): boolean {
69
- subtract(_0vector, point, line.origin);
70
- cross(_0vector, _0vector, line.direction);
71
- return lengthSquared(_0vector) < EPSILON;
72
- }
73
-
74
- function applyQuaternion(out: Line, line: Line, quaternion: Quaternion) {
75
- vec3applyQuaternion(out.origin, line.origin, quaternion);
76
- vec3applyQuaternion(out.direction, line.direction, quaternion);
77
- normalize(out.direction, out.direction);
78
- }
79
-
80
- export {
81
- create,
82
- set,
83
- copy, clone, fromTwoPoints, at, closestPoint, contains, applyQuaternion
84
- }
package/Math/matrix4.ts DELETED
File without changes
package/Math/methods.ts DELETED
@@ -1,157 +0,0 @@
1
- import { WORLD_RADIUS_3D, WORLD_RADIUS_MERCATOR } from './constants';
2
- import { Vec3, Vec2, Vec4, Fraction, WGS84, LongLat } from './types';
3
- import { dot as dot3, copy as copy3 } from './vec3';
4
- import { Globe } from '../types';
5
-
6
- export const RADIANS = Math.PI / 180;
7
-
8
- const _0vec3 = [0, 0, 0] as Vec3;
9
- const _0vec2 = [0, 0] as Vec2;
10
- export const cartesian3dToRadian = (output: WGS84,
11
- cartesian: Vec3): void => {
12
- const x = cartesian[0];
13
- const y = cartesian[1];
14
- const z = cartesian[2];
15
- output[0] = Math.atan2(y, x); // longitude
16
- output[1] = Math.asin(z); // latitude
17
- };
18
-
19
- export const radianToMercator = (xy: Vec2): Vec2 => {
20
- return [
21
- WORLD_RADIUS_MERCATOR * xy[0],
22
- WORLD_RADIUS_MERCATOR * Math.log(Math.tan(Math.PI / 4 + xy[1] / 2))
23
- ];
24
- };
25
-
26
- export const radianToCartesian3d = (xy: Vec2): Vec3 => {
27
- const x = Math.cos(xy[1]) * Math.cos(xy[0]);
28
- const y = Math.cos(xy[1]) * Math.sin(xy[0]);
29
- const z = -Math.sin(xy[1]);
30
- return [x, y, z];
31
- };
32
-
33
- export const sphericalLinearInterpolation_UnitVector = (
34
- output: Vec3,
35
- normalizedA: Vec3,
36
- normalizedB: Vec3,
37
- ratio: Fraction
38
- ): void => {
39
- const theta = Math.acos(dot3(normalizedA, normalizedB));
40
- if (theta < 0.000001) {
41
- copy3(output, normalizedA);
42
- return;
43
- }
44
- const sinTheta = Math.sin(theta);
45
- output[0] = (Math.sin((1.0 - ratio) * theta) * normalizedA[0] + Math.sin(ratio * theta) * normalizedB[0]) / sinTheta;
46
- output[1] = (Math.sin((1.0 - ratio) * theta) * normalizedA[1] + Math.sin(ratio * theta) * normalizedB[1]) / sinTheta;
47
- output[2] = (Math.sin((1.0 - ratio) * theta) * normalizedA[2] + Math.sin(ratio * theta) * normalizedB[2]) / sinTheta;
48
- };
49
-
50
-
51
- export const sphericalLinearInterpolation_Mercator = (
52
- output: Vec2,
53
- normalizedA: Vec3,
54
- normalizedB: Vec3,
55
- ratio: Fraction
56
- ): void => {
57
- sphericalLinearInterpolation_UnitVector(_0vec3, normalizedA, normalizedB, ratio);
58
- cartesian3dToRadian(_0vec2, _0vec3);
59
- output[0] = WORLD_RADIUS_MERCATOR * _0vec2[0];
60
- output[1] = WORLD_RADIUS_MERCATOR * Math.log(Math.tan(Math.PI / 4 + _0vec2[1] / 2));
61
- }
62
-
63
-
64
-
65
- export const sphericalLinearInterpolation_Cartesian3d = (
66
- output: Vec3,
67
- a: Vec4,
68
- b: Vec4,
69
- ratio: Fraction
70
- ): void => {
71
- sphericalLinearInterpolation_UnitVector(
72
- _0vec3,
73
- [a[0], a[1], a[2]],
74
- [b[0], b[1], b[2]],
75
- ratio
76
- );
77
- const height = a[3] + (b[3] - a[3]) * ratio;
78
- output[0] = _0vec3[0] * height;
79
- output[1] = _0vec3[1] * height;
80
- output[2] = _0vec3[2] * height;
81
- }
82
-
83
-
84
-
85
-
86
- export const wgs84ToCartesian3d = (output: Vec3, long: number, lat: number, height: number): void => {
87
- const longRad = long * RADIANS;
88
- const latRad = lat * RADIANS;
89
- const x = Math.cos(latRad) * Math.cos(longRad);
90
- const y = Math.cos(latRad) * Math.sin(longRad);
91
- const z = Math.sin(latRad);
92
- const radius = WORLD_RADIUS_3D + height;
93
- output[0] = x * radius;
94
- output[1] = y * radius;
95
- output[2] = z * radius;
96
- };
97
-
98
- export const wgs84ToMercator = (long: number, lat: number): Vec2 => {
99
- return [
100
- WORLD_RADIUS_MERCATOR * long * RADIANS,
101
- WORLD_RADIUS_MERCATOR * Math.log(Math.tan(Math.PI / 4 + lat * RADIANS / 2))
102
- ];
103
- };
104
-
105
- export const pixelXYToRadians = (pixelXY: Vec2): Vec2 => {
106
- const long = (2.0 * pixelXY[0] - 1.0) * Math.PI;
107
- const lat = (2.0 * pixelXY[1] - 1.0) * Math.PI / 2.0;
108
- return [long, lat];
109
- };
110
-
111
- export const pixelXYLenghtToUnitVectorWithHeight = (pixelXYHeight: [number, number, number]): Vec4 => {
112
- const [long, lat] = pixelXYToRadians([pixelXYHeight[0], pixelXYHeight[1]]);
113
- const radius = WORLD_RADIUS_3D + pixelXYHeight[2];
114
- return [...radianToCartesian3d([long, lat]), radius];
115
- };
116
-
117
-
118
-
119
- export const globe3Dcoordinates = (globe: Globe, longlats: number[] | Float64Array, height = 0, msl = false, { paddingCount = 0, paddingValue = NaN }: { paddingCount?: number; paddingValue?: number }
120
- ): Float32Array => {
121
- const len = longlats.length / 2;
122
- const result = new Float32Array(len * 3 + paddingCount * 3).fill(paddingValue);
123
- for (let i = 0; i < len; i++) {
124
- const long = longlats[i * 2];
125
- const lat = longlats[i * 2 + 1];
126
- const xyz = globe.api_GetCartesian3DPoint(long, lat, height, msl);
127
- result.set(xyz, i * 3);
128
- }
129
- return result;
130
- };
131
-
132
-
133
- const manhattanDistance = (a: Vec2, b: Vec2): number => {
134
- return Math.abs(a[0] - b[0]) + Math.abs(a[1] - b[1]);
135
- };
136
-
137
- export const globe2Dcoordinates = (globe: Globe, distanceFilterMeter: number = WORLD_RADIUS_MERCATOR) => (
138
- longlats: number[] | Float64Array,
139
- { paddingCount = 0, paddingValue = NaN }: { paddingCount?: number; paddingValue?: number }
140
- ): Float32Array => {
141
- let _lastXY: Vec2 = [NaN, NaN];
142
- const len = longlats.length / 2;
143
- const result = new Float32Array(len * 2 + paddingCount * 2).fill(paddingValue);
144
- for (let i = 0; i < len; i++) {
145
-
146
- const long = longlats[i * 2];
147
- const lat = longlats[i * 2 + 1];
148
- const xy = globe.api_GetMercator2DPoint(long, lat);
149
- if (manhattanDistance(_lastXY, xy) > distanceFilterMeter) {
150
- result.set([paddingValue, paddingValue], i * 2);
151
- } else {
152
- result.set(xy, i * 2);
153
- }
154
- _lastXY = xy;
155
- }
156
- return result;
157
- };
package/Math/plane.ts DELETED
@@ -1,92 +0,0 @@
1
- import { Vec3, Plane } from "./types";
2
-
3
- import { EPSILON } from "./constants";
4
- import {
5
- copy as vec3copy, create as vec3create, clone as vec3clone, set as vec3set, dot,
6
- subtract, multiplyScalar, cross, normalize,
7
- equals as vec3equals
8
- } from "./vec3";
9
- const _0vector = /*@__PURE__*/ vec3create(0, 0, 0);
10
- const _1vector = /*@__PURE__*/ vec3create(1, 1, 1);
11
-
12
-
13
- function create(normal = vec3create(), distance = 0): Plane {
14
- return {
15
- normal: vec3clone(normal),
16
- distance: distance
17
- };
18
- }
19
-
20
-
21
- function set(out: Plane, normal: Vec3, distance: number): Plane {
22
- vec3copy(out.normal, normal);
23
- out.distance = distance;
24
- return out;
25
- }
26
-
27
-
28
- function fromValues(out: Plane, nx: number, ny: number, nz: number, distance: number) {
29
- vec3set(out.normal, nx, ny, nz);
30
- out.distance = distance;
31
- }
32
-
33
-
34
- function copy(out: Plane, a: Plane): Plane {
35
- vec3copy(out.normal, a.normal);
36
- out.distance = a.distance;
37
- return out;
38
- }
39
-
40
-
41
- function clone(a: Plane): Plane {
42
- return {
43
- normal: vec3clone(a.normal),
44
- distance: a.distance
45
- };
46
- }
47
-
48
-
49
- function distanceToPoint(plane: Plane, point: Vec3): number {
50
- return dot(plane.normal, point) - plane.distance;
51
- }
52
-
53
-
54
- function projectPoint(out: Vec3, plane: Plane, point: Vec3) {
55
- const distance = distanceToPoint(plane, point);
56
- multiplyScalar(out, plane.normal, distance);
57
- subtract(out, point, out);
58
- }
59
-
60
-
61
- function equals(plane: Plane, other: Plane): boolean {
62
- return vec3equals(plane.normal, other.normal) && Math.abs(plane.distance - other.distance) < EPSILON;
63
- }
64
-
65
-
66
-
67
- function fromNormalAndCoplanarPoint(out: Plane, normal: Vec3, point: Vec3) {
68
- vec3copy(out.normal, normal);
69
- out.distance = dot(point, normal);
70
- }
71
-
72
-
73
-
74
- function fromPoints(out: Plane, a: Vec3, b: Vec3, c: Vec3) {
75
- subtract(_0vector, b, a);
76
- subtract(_1vector, c, a);
77
- cross(out.normal, _0vector, _1vector);
78
- normalize(out.normal, out.normal);
79
- out.distance = dot(out.normal, a);
80
- }
81
-
82
-
83
-
84
- function getUnitSphereRadiusAngle(plane: Plane): number {
85
- return Math.acos(Math.max(Math.min(plane.distance, 1), -1));
86
- }
87
-
88
-
89
- export {
90
- create, set, fromValues, copy, clone, distanceToPoint, projectPoint,
91
- equals, fromNormalAndCoplanarPoint, fromPoints, getUnitSphereRadiusAngle
92
- }
@@ -1,128 +0,0 @@
1
- import { Vec3, Quaternion } from './types';
2
- import { dot } from './vec3';
3
- import { EPSILON } from './constants';
4
-
5
- function create(x = 0, y = 0, z = 0, w = 1): Quaternion {
6
- return [x, y, z, w];
7
- }
8
-
9
- function set(out: Quaternion, x: number, y: number, z: number, w: number) {
10
- out[0] = x;
11
- out[1] = y;
12
- out[2] = z;
13
- out[3] = w;
14
- }
15
-
16
- function copy(out: Quaternion, a: Quaternion) {
17
- out[0] = a[0];
18
- out[1] = a[1];
19
- out[2] = a[2];
20
- out[3] = a[3];
21
- }
22
-
23
- function clone(a: Quaternion): Quaternion {
24
- return [a[0], a[1], a[2], a[3]];
25
- }
26
- function lengthSquared(a: Quaternion): number {
27
- return a[0] * a[0] + a[1] * a[1] + a[2] * a[2] + a[3] * a[3];
28
- }
29
-
30
- function length(a: Quaternion): number {
31
- return Math.sqrt(lengthSquared(a));
32
- }
33
-
34
- function normalize(out: Quaternion, input: Quaternion) {
35
- const len = Math.sqrt(lengthSquared(input));
36
- if (len < EPSILON) {
37
- set(out, 0, 0, 0, 1);
38
- }
39
- else {
40
- const invLen = 1 / len;
41
- set(out, input[0] * invLen, input[1] * invLen, input[2] * invLen, input[3] * invLen);
42
- }
43
- }
44
-
45
-
46
- function multiply(out: Quaternion, a: Quaternion, b: Quaternion): Quaternion {
47
- const x = a[0] * b[3] + a[3] * b[0] + a[1] * b[2] - a[2] * b[1];
48
- const y = a[1] * b[3] + a[3] * b[1] + a[2] * b[0] - a[0] * b[2];
49
- const z = a[2] * b[3] + a[3] * b[2] + a[0] * b[1] - a[1] * b[0];
50
- const w = a[3] * b[3] - a[0] * b[0] - a[1] * b[1] - a[2] * b[2];
51
- set(out, x, y, z, w);
52
- return out;
53
- }
54
-
55
- function randomUnit(out: Quaternion): Quaternion {
56
- const u1 = Math.random();
57
- const u2 = Math.random();
58
- const u3 = Math.random();
59
- const sqrt1MinusU1 = Math.sqrt(1 - u1);
60
- const sqrtU1 = Math.sqrt(u1);
61
- const x = sqrt1MinusU1 * Math.sin(2 * Math.PI * u2);
62
- const y = sqrt1MinusU1 * Math.cos(2 * Math.PI * u2);
63
- const z = sqrtU1 * Math.sin(2 * Math.PI * u3);
64
- const w = sqrtU1 * Math.cos(2 * Math.PI * u3);
65
- set(out, x, y, z, w);
66
- normalize(out, out);
67
- return out;
68
- }
69
-
70
- function rotateQuaternion(out: Quaternion, a: Quaternion, b: Quaternion) {
71
- const x = a[0] * b[3] + a[3] * b[0] + a[1] * b[2] - a[2] * b[1];
72
- const y = a[1] * b[3] + a[3] * b[1] + a[2] * b[0] - a[0] * b[2];
73
- const z = a[2] * b[3] + a[3] * b[2] + a[0] * b[1] - a[1] * b[0];
74
- const w = a[3] * b[3] - a[0] * b[0] - a[1] * b[1] - a[2] * b[2];
75
- set(out, x, y, z, w);
76
- normalize(out, out);
77
- }
78
-
79
-
80
- function fromUnitVectors(out: Quaternion, from: Vec3, to: Vec3) {
81
-
82
- const d = dot(from, to) + 1;
83
- if (d < EPSILON) {
84
- if (Math.abs(from[0]) > Math.abs(from[2])) {
85
- set(out, -from[1], from[0], 0, 0);
86
- } else {
87
- set(out, 0, -from[2], from[1], 0);
88
- }
89
- } else {
90
- const x = from[1] * to[2] - from[2] * to[1];
91
- const y = from[2] * to[0] - from[0] * to[2];
92
- const z = from[0] * to[1] - from[1] * to[0];
93
- set(out, x, y, z, d);
94
- }
95
- }
96
-
97
-
98
- function fromTwoQuaternions(out: Quaternion, from: Quaternion, to: Quaternion) {
99
- const x = from[0] * to[3] + from[3] * to[0] + from[1] * to[2] - from[2] * to[1];
100
- const y = from[1] * to[3] + from[3] * to[1] + from[2] * to[0] - from[0] * to[2];
101
- const z = from[2] * to[3] + from[3] * to[2] + from[0] * to[1] - from[1] * to[0];
102
- const w = from[3] * to[3] - from[0] * to[0] - from[1] * to[1] - from[2] * to[2];
103
- set(out, x, y, z, w);
104
- normalize(out, out);
105
- }
106
-
107
- function conjugate(out: Quaternion, a: Quaternion) {
108
- set(out, -a[0], -a[1], -a[2], a[3]);
109
- }
110
-
111
- function fromAxisAngle(out: Quaternion, axis: Vec3, angle: number) {
112
- const halfAngle = angle / 2;
113
- const s = Math.sin(halfAngle);
114
- set(out, axis[0] * s, axis[1] * s, axis[2] * s, Math.cos(halfAngle));
115
- }
116
-
117
- function reverse(out: Quaternion, a: Quaternion) {
118
- out[0] = -a[0];
119
- out[1] = -a[1];
120
- out[2] = -a[2];
121
- out[3] = a[3];
122
- }
123
-
124
- export {
125
- create, set, copy, clone, length, lengthSquared, normalize, multiply,
126
- randomUnit, rotateQuaternion, fromUnitVectors, fromTwoQuaternions,
127
- conjugate, fromAxisAngle, reverse
128
- }
package/Math/roadmap.md DELETED
@@ -1,10 +0,0 @@
1
-
2
- There is an arc on a unit sphere. The sphere center is at the origin. The arc is represented with start and points.
3
-
4
- And there is a plane the intersects with the same sphere. Represented with vector and distance from origin.
5
-
6
- I want to know the relative position of points to the plane. If they are at the same direction with the plane vector or not.
7
-
8
- If two points are on the same side of the plane. If so, do they closer to origin then plane or not.
9
-
10
- If two points are on different side of the plane, I want to know the intersection point of arc and plane.
@@ -1,119 +0,0 @@
1
- import { LongLat, Globe, Meter, Radians, CentigradeDegree } from "../../types";
2
-
3
-
4
-
5
- /**
6
- * Createa a grıd of longitude/latitude points visually equal on the mercator projectıon.
7
- */
8
-
9
- function mercatorMeterToLongLat(
10
- mercatorX: number,
11
- mercatorY: number
12
- ): LongLat {
13
- const R = 6378137; // Earth radius in meters
14
- const lng = (mercatorX / R) * (180 / Math.PI);
15
- const lat = (2 * Math.atan(Math.exp(mercatorY / R)) - Math.PI / 2) * (180 / Math.PI);
16
- return [lng, lat];
17
- }
18
-
19
-
20
- function createGrid(sizeX: number, sizeY: number): any[][] {
21
- const grid: LongLat[][] = [];
22
- for (let y = 0; y < sizeY; y++) {
23
- const row = new Array<any>(sizeX);
24
- grid.push(row);
25
- }
26
-
27
- return grid;
28
- }
29
-
30
- function moveByAngle(
31
- origin: [Meter, Meter],
32
- angle: Radians,
33
- distance: Meter
34
- ): [Meter, Meter] {
35
- const long = origin[0] + distance * Math.cos(angle);
36
- const lat = origin[1] + distance * Math.sin(angle);
37
- return [long, lat];
38
- }
39
-
40
-
41
-
42
- export function createfillGrid(
43
- globe: Globe,
44
- origin: LongLat,
45
- startX: number, startY: number,
46
- rowSize: number, columnSize: number,
47
- cellSizeX: Meter, cellSizeY: Meter,
48
- rotaionAngle: CentigradeDegree = 0
49
- ): LongLat[][] {
50
-
51
- const originMercator = globe.api_GetMercator2DPoint(origin[0], origin[1]);
52
- const angleRadians = rotaionAngle * (Math.PI / 180);
53
- const grid = createGrid(rowSize, columnSize);
54
-
55
- // Set the origin point first
56
- grid[startY][startX] = originMercator;
57
-
58
- // fill single vertical row from origin - to the right
59
- let lastPoint = originMercator;
60
- for (let i = startX + 1; i < rowSize; i++) {
61
- const [long, lat] = moveByAngle(
62
- lastPoint,
63
- angleRadians,
64
- cellSizeX
65
- );
66
- lastPoint = [long, lat];
67
- grid[startY][i] = [long, lat];
68
- }
69
-
70
- // fill single vertical row from origin - to the left
71
- lastPoint = originMercator;
72
- for (let i = startX - 1; i >= 0; i--) {
73
- const [long, lat] = moveByAngle(
74
- lastPoint,
75
- Math.PI + angleRadians,
76
- cellSizeX
77
- );
78
- lastPoint = [long, lat];
79
- grid[startY][i] = [long, lat];
80
- }
81
-
82
- // fill single horizontal from origin from startY to 0
83
- console.log("grid", grid);
84
-
85
- for (let i = startY - 1; i >= 0; i--) {
86
- for (let j = 0; j < rowSize; j++) {
87
- const [long, lat] = moveByAngle(
88
- grid[i + 1][j],
89
- angleRadians - Math.PI / 2,
90
- cellSizeY
91
- );
92
- grid[i][j] = [long, lat];
93
- }
94
- }
95
-
96
- // fill single horizontal from origin from startY to last row
97
- for (let i = startY + 1; i < columnSize; i++) {
98
- for (let j = 0; j < rowSize; j++) {
99
- const [long, lat] = moveByAngle(
100
- grid[i - 1][j],
101
- angleRadians + Math.PI / 2,
102
- cellSizeY
103
- );
104
- grid[i][j] = [long, lat];
105
- }
106
- }
107
-
108
- // Convert from mercator meters to longitude/latitude
109
- for (let i = 0; i < columnSize; i++) {
110
- for (let j = 0; j < rowSize; j++) {
111
- const [long, lat] = mercatorMeterToLongLat(
112
- grid[i][j][0],
113
- grid[i][j][1]
114
- );
115
- grid[i][j] = [long, lat];
116
- }
117
- }
118
- return grid;
119
- }