@pirireis/webglobeplugins 0.15.34 → 0.16.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (481) hide show
  1. package/Math/angle-calculation.js +14 -13
  2. package/Math/arc-cdf-points.ts +329 -0
  3. package/Math/arc-generate-points-exponantial.ts +299 -0
  4. package/Math/arc.ts +299 -0
  5. package/Math/bounds/line-bbox.js +225 -186
  6. package/Math/circle-cdf-points.ts +143 -0
  7. package/Math/circle.ts +49 -0
  8. package/Math/constants.ts +12 -0
  9. package/Math/index.js +0 -1
  10. package/Math/juction/arc-plane.ts +129 -0
  11. package/Math/juction/line-sphere.ts +30 -0
  12. package/Math/juction/plane-plane.ts +64 -0
  13. package/Math/line.ts +84 -0
  14. package/Math/matrix4.ts +0 -0
  15. package/Math/mesh/mapbox-delaunay.js +607 -0
  16. package/Math/methods.ts +157 -0
  17. package/Math/plane.ts +92 -0
  18. package/Math/quaternion.ts +128 -0
  19. package/Math/roadmap.md +10 -0
  20. package/Math/templete-shapes/grid-visually-equal.ts +119 -0
  21. package/Math/types.ts +66 -0
  22. package/Math/utils.js +3 -2
  23. package/Math/vec3.ts +180 -0
  24. package/algorithms/search-binary.js +14 -16
  25. package/altitude-locator/adaptors.js +0 -1
  26. package/altitude-locator/keymethod.js +0 -1
  27. package/altitude-locator/plugin.js +446 -345
  28. package/altitude-locator/types.js +26 -21
  29. package/arrowfield/adaptor.js +11 -11
  30. package/arrowfield/index.js +3 -3
  31. package/arrowfield/plugin.js +128 -83
  32. package/bearing-line/index.js +2 -2
  33. package/bearing-line/plugin.js +520 -444
  34. package/circle-line-chain/chain-list-map.js +221 -201
  35. package/circle-line-chain/init.js +0 -1
  36. package/circle-line-chain/plugin.js +464 -411
  37. package/circle-line-chain/readme.md +57 -0
  38. package/circle-line-chain/util.js +1 -1
  39. package/compass-rose/compass-rose-padding-flat.js +274 -230
  40. package/compass-rose/compass-text-writer.js +173 -149
  41. package/compass-rose/index.js +3 -3
  42. package/compassrose/compassrose.js +341 -293
  43. package/compassrose/index.js +2 -2
  44. package/depth-locator/readme.md +26 -0
  45. package/dist/Math/angle-calculation.js +13 -0
  46. package/dist/Math/bounds/line-bbox.js +186 -0
  47. package/dist/Math/mesh/mapbox-delaunay.js +544 -0
  48. package/dist/Math/utils.js +2 -0
  49. package/dist/algorithms/search-binary.js +16 -0
  50. package/dist/altitude-locator/adaptors.js +1 -0
  51. package/dist/altitude-locator/keymethod.js +1 -0
  52. package/dist/altitude-locator/plugin.js +345 -0
  53. package/dist/altitude-locator/types.js +21 -0
  54. package/dist/arrowfield/adaptor.js +11 -0
  55. package/dist/arrowfield/index.js +3 -0
  56. package/dist/arrowfield/plugin.js +83 -0
  57. package/dist/bearing-line/index.js +2 -0
  58. package/dist/bearing-line/plugin.js +444 -0
  59. package/dist/circle-line-chain/chain-list-map.js +201 -0
  60. package/dist/circle-line-chain/init.js +1 -0
  61. package/dist/circle-line-chain/plugin.js +411 -0
  62. package/dist/circle-line-chain/util.js +1 -0
  63. package/dist/compass-rose/compass-rose-padding-flat.js +230 -0
  64. package/dist/compass-rose/compass-text-writer.js +149 -0
  65. package/dist/compass-rose/index.js +3 -0
  66. package/dist/compassrose/compassrose.js +293 -0
  67. package/dist/compassrose/index.js +2 -0
  68. package/dist/heatwave/index.js +3 -0
  69. package/dist/heatwave/isobar/objectarraylabels.js +200 -0
  70. package/dist/heatwave/isobar/plugin.js +302 -0
  71. package/dist/heatwave/isobar/quadtreecontours.js +298 -0
  72. package/dist/heatwave/plugins/heatwaveglobeshell.js +204 -0
  73. package/dist/index.js +12 -0
  74. package/dist/jest.config.js +7 -0
  75. package/dist/partialrings/buffer-manager.js +75 -0
  76. package/dist/partialrings/index.js +2 -0
  77. package/dist/partialrings/plugin.js +128 -0
  78. package/dist/partialrings/program.js +279 -0
  79. package/dist/pin/pin-object-array.js +300 -0
  80. package/dist/pin/pin-point-totem.js +60 -0
  81. package/dist/point-heat-map/adaptors/timetracksplugin-format-to-this.js +63 -0
  82. package/dist/point-heat-map/index.js +1 -0
  83. package/dist/point-heat-map/plugin-webworker.js +121 -0
  84. package/dist/point-heat-map/point-to-heat-map-flow.js +124 -0
  85. package/dist/point-tracks/key-methods.js +2 -0
  86. package/dist/point-tracks/plugin.js +393 -0
  87. package/dist/programs/arrowfield/index.js +2 -0
  88. package/dist/programs/arrowfield/logic.js +254 -0
  89. package/dist/programs/arrowfield/object.js +60 -0
  90. package/dist/programs/data2legend/density-to-legend.js +98 -0
  91. package/dist/programs/data2legend/point-to-density-texture.js +97 -0
  92. package/dist/programs/float2legendwithratio/index.js +2 -0
  93. package/dist/programs/float2legendwithratio/logic.js +167 -0
  94. package/dist/programs/float2legendwithratio/object.js +104 -0
  95. package/dist/programs/globe-util/is-globe-moved.js +19 -0
  96. package/dist/programs/globeshell/index.js +2 -0
  97. package/dist/programs/globeshell/wiggle/index.js +2 -0
  98. package/dist/programs/globeshell/wiggle/logic.js +342 -0
  99. package/dist/programs/globeshell/wiggle/object.js +66 -0
  100. package/dist/programs/helpers/blender/index.js +1 -0
  101. package/dist/programs/helpers/blender/program.js +76 -0
  102. package/dist/programs/helpers/fadeaway/index.js +2 -0
  103. package/dist/programs/helpers/fadeaway/logic.js +69 -0
  104. package/dist/programs/helpers/fadeaway/object.js +14 -0
  105. package/dist/programs/helpers/index.js +2 -0
  106. package/dist/programs/index.js +9 -0
  107. package/dist/programs/line-on-globe/circle-accurate-3d.js +138 -0
  108. package/dist/programs/line-on-globe/circle-accurate-flat.js +210 -0
  109. package/dist/programs/line-on-globe/degree-padding-around-circle-3d.js +156 -0
  110. package/dist/programs/line-on-globe/index.js +1 -0
  111. package/dist/programs/line-on-globe/lines-color-instanced-flat.js +131 -0
  112. package/dist/programs/line-on-globe/util.js +5 -0
  113. package/dist/programs/picking/pickable-polygon-renderer.js +184 -0
  114. package/dist/programs/picking/pickable-renderer.js +184 -0
  115. package/dist/programs/point-on-globe/element-globe-surface-glow.js +138 -0
  116. package/dist/programs/point-on-globe/element-point-glow.js +150 -0
  117. package/dist/programs/point-on-globe/square-pixel-point.js +171 -0
  118. package/dist/programs/polygon-on-globe/texture-dem-triangle-test-plugin.js +97 -0
  119. package/dist/programs/polygon-on-globe/texture-dem-triangles.js +167 -0
  120. package/dist/programs/rings/distancering/circleflatprogram.js +116 -0
  121. package/dist/programs/rings/distancering/circlepaddingfreeangleprogram.js +326 -0
  122. package/dist/programs/rings/distancering/circlepaddysharedbuffer.js +368 -0
  123. package/dist/programs/rings/distancering/index.js +6 -0
  124. package/dist/programs/rings/distancering/paddyflatprogram.js +127 -0
  125. package/dist/programs/rings/distancering/paddyflatprogram2d.js +129 -0
  126. package/dist/programs/rings/distancering/paddyflatprogram3d.js +128 -0
  127. package/dist/programs/rings/index.js +1 -0
  128. package/dist/programs/totems/gpu-selection-uniform-block.js +104 -0
  129. package/dist/programs/two-d/pixel-circle.js +1 -0
  130. package/dist/programs/two-d/pixel-padding-for-compass.js +159 -0
  131. package/dist/programs/util.js +14 -0
  132. package/dist/programs/vectorfields/index.js +3 -0
  133. package/dist/programs/vectorfields/logics/drawrectangleparticles.js +113 -0
  134. package/dist/programs/vectorfields/logics/index.js +2 -0
  135. package/dist/programs/vectorfields/logics/pixelbased.js +140 -0
  136. package/dist/programs/vectorfields/logics/ubo.js +60 -0
  137. package/dist/programs/vectorfields/pingpongbuffermanager.js +73 -0
  138. package/dist/rangerings/index.js +5 -0
  139. package/dist/rangerings/plugin.js +543 -0
  140. package/dist/rangerings/rangeringangletext.js +326 -0
  141. package/dist/rangerings/ring-account.js +112 -0
  142. package/dist/semiplugins/shape-on-terrain/terrain-cover/texture-dem-cover.js +1 -0
  143. package/dist/shaders/fragment-toy/firework.js +55 -0
  144. package/dist/shaders/fragment-toy/singularity.js +56 -0
  145. package/dist/timetracks/adaptors-line-strip.js +65 -0
  146. package/dist/timetracks/index.js +1 -0
  147. package/dist/timetracks/plugin-line-strip.js +240 -0
  148. package/dist/timetracks/program-line-strip.js +608 -0
  149. package/dist/timetracks/programpoint-line-strip.js +151 -0
  150. package/dist/util/account/bufferoffsetmanager.js +176 -0
  151. package/dist/util/account/index.js +3 -0
  152. package/dist/util/account/util.js +18 -0
  153. package/dist/util/algorithms/index.js +1 -0
  154. package/dist/util/algorithms/search-binary.js +25 -0
  155. package/dist/util/check/index.js +1 -0
  156. package/dist/util/gl-util/uniform-block/shader.js +1 -0
  157. package/dist/util/heatwavedatamanager/datamanager.js +149 -0
  158. package/dist/util/heatwavedatamanager/index.js +2 -0
  159. package/dist/util/index.js +13 -0
  160. package/dist/util/interpolation/index.js +1 -0
  161. package/dist/util/interpolation/timetrack/index.js +2 -0
  162. package/dist/util/interpolation/timetrack/timetrack-interpolator.js +79 -0
  163. package/dist/util/interpolation/timetrack/web-worker.js +46 -0
  164. package/dist/util/jshelpers/data-filler.js +17 -0
  165. package/dist/util/jshelpers/equality.js +18 -0
  166. package/dist/util/jshelpers/index.js +2 -0
  167. package/dist/util/jshelpers/timefilters.js +30 -0
  168. package/dist/util/picking/fence.js +43 -0
  169. package/dist/util/picking/picker-displayer.js +136 -0
  170. package/dist/util/programs/draw-texture-on-canvas.js +86 -0
  171. package/dist/util/programs/index.js +1 -0
  172. package/dist/util/programs/shapesonglobe.js +210 -0
  173. package/dist/util/programs/supersampletotextures.js +109 -0
  174. package/dist/util/programs/texturetoglobe.js +179 -0
  175. package/dist/util/shaderfunctions/index.js +2 -0
  176. package/dist/util/shaderfunctions/nodata.js +8 -0
  177. package/dist/util/shaderfunctions/noisefunctions.js +41 -0
  178. package/dist/util/surface-line-data/arcs-to-cuts.js +50 -0
  179. package/dist/util/surface-line-data/cut-arc.js +1 -0
  180. package/dist/util/surface-line-data/rbush-manager.js +1 -0
  181. package/dist/util/surface-line-data/types.js +1 -0
  182. package/dist/util/surface-line-data/web-worker.js +1 -0
  183. package/dist/util/webglobe/gldefaultstates.js +4 -0
  184. package/dist/util/webglobe/index.js +2 -0
  185. package/dist/util/webglobe/rasteroverlay.js +75 -0
  186. package/dist/waveparticles/adaptor.js +15 -0
  187. package/dist/waveparticles/index.js +3 -0
  188. package/dist/waveparticles/plugin.js +290 -0
  189. package/dist/wind/imagetovectorfieldandmagnitude.js +56 -0
  190. package/dist/wind/index.js +5 -0
  191. package/dist/wind/plugin.js +921 -0
  192. package/dist/wind/vectorfieldimage.js +23 -0
  193. package/dist/write-text/attached-text-writer.js +87 -0
  194. package/dist/write-text/context-text-bulk.js +185 -0
  195. package/dist/write-text/context-text.js +94 -0
  196. package/dist/write-text/context-text3old.js +152 -0
  197. package/dist/write-text/index.js +1 -0
  198. package/dist/write-text/writer-plugin.js +8 -0
  199. package/heatwave/index.js +4 -3
  200. package/heatwave/isobar/objectarraylabels.js +247 -200
  201. package/heatwave/isobar/plugin.js +339 -302
  202. package/heatwave/isobar/quadtreecontours.js +336 -298
  203. package/heatwave/plugins/heatwaveglobeshell.js +259 -204
  204. package/index.js +15 -12
  205. package/jest.config.js +6 -7
  206. package/package.json +6 -2
  207. package/partialrings/buffer-manager.js +89 -75
  208. package/partialrings/goals.md +17 -0
  209. package/partialrings/index.js +3 -2
  210. package/partialrings/plugin.js +160 -128
  211. package/partialrings/program.js +233 -188
  212. package/pin/pin-object-array.js +381 -300
  213. package/pin/pin-point-totem.js +77 -60
  214. package/point-heat-map/adaptors/timetracksplugin-format-to-this.js +78 -63
  215. package/point-heat-map/index.js +0 -1
  216. package/point-heat-map/plugin-webworker.js +148 -121
  217. package/point-heat-map/point-to-heat-map-flow.js +150 -124
  218. package/point-heat-map/readme.md +15 -0
  219. package/point-tracks/key-methods.js +3 -2
  220. package/point-tracks/plugin.js +480 -393
  221. package/programs/arrowfield/index.js +2 -2
  222. package/programs/arrowfield/logic.js +173 -141
  223. package/programs/arrowfield/object.js +89 -60
  224. package/programs/data2legend/density-to-legend.js +90 -73
  225. package/programs/data2legend/point-to-density-texture.js +87 -70
  226. package/programs/float2legendwithratio/index.js +3 -2
  227. package/programs/float2legendwithratio/logic.js +144 -118
  228. package/programs/float2legendwithratio/object.js +141 -104
  229. package/programs/globe-util/is-globe-moved.js +27 -19
  230. package/programs/globeshell/index.js +2 -2
  231. package/programs/globeshell/wiggle/index.js +3 -2
  232. package/programs/globeshell/wiggle/logic.js +272 -243
  233. package/programs/globeshell/wiggle/object.js +93 -66
  234. package/programs/helpers/blender/index.js +0 -1
  235. package/programs/helpers/blender/program.js +73 -58
  236. package/programs/helpers/fadeaway/index.js +3 -2
  237. package/programs/helpers/fadeaway/logic.js +53 -46
  238. package/programs/helpers/fadeaway/object.js +20 -14
  239. package/programs/helpers/index.js +2 -2
  240. package/programs/index.js +21 -9
  241. package/programs/line-on-globe/circle-accurate-3d.js +115 -87
  242. package/programs/line-on-globe/circle-accurate-flat.js +201 -149
  243. package/programs/line-on-globe/degree-padding-around-circle-3d.js +136 -104
  244. package/programs/line-on-globe/index.js +0 -1
  245. package/programs/line-on-globe/lines-color-instanced-flat.js +102 -83
  246. package/programs/line-on-globe/linestrip/data.ts +29 -0
  247. package/programs/line-on-globe/linestrip/linestrip.ts +201 -0
  248. package/programs/line-on-globe/naive-accurate-flexible.ts +258 -0
  249. package/programs/line-on-globe/util.js +8 -5
  250. package/programs/picking/pickable-polygon-renderer.js +215 -0
  251. package/programs/picking/pickable-renderer.js +129 -98
  252. package/programs/point-on-globe/element-globe-surface-glow.js +122 -93
  253. package/programs/point-on-globe/element-point-glow.js +114 -80
  254. package/programs/point-on-globe/square-pixel-point.js +138 -120
  255. package/programs/polygon-on-globe/texture-dem-triangle-test-plugin.ts +120 -0
  256. package/programs/polygon-on-globe/texture-dem-triangles.ts +207 -0
  257. package/programs/programcache.ts +131 -0
  258. package/programs/rings/distancering/circleflatprogram.js +138 -116
  259. package/programs/rings/distancering/circlepaddingfreeangleprogram.js +323 -275
  260. package/programs/rings/distancering/circlepaddysharedbuffer.js +423 -368
  261. package/programs/rings/distancering/index.js +5 -6
  262. package/programs/rings/distancering/paddyflatprogram.js +148 -127
  263. package/programs/rings/distancering/paddyflatprogram2d.js +153 -129
  264. package/programs/rings/distancering/paddyflatprogram3d.js +149 -128
  265. package/programs/rings/index.js +1 -1
  266. package/programs/rings/partial-ring/piece-of-pie.ts +323 -0
  267. package/programs/totems/camerauniformblock.ts +310 -0
  268. package/programs/totems/canvas-webglobe-info.ts +156 -0
  269. package/programs/totems/globe-changes.ts +79 -0
  270. package/programs/totems/gpu-selection-uniform-block.js +127 -99
  271. package/programs/totems/index.ts +2 -0
  272. package/programs/two-d/pixel-circle.js +0 -1
  273. package/programs/two-d/pixel-padding-for-compass.js +112 -97
  274. package/programs/util.js +19 -14
  275. package/programs/vectorfields/index.js +3 -3
  276. package/programs/vectorfields/logics/constants.ts +5 -0
  277. package/programs/vectorfields/logics/drawrectangleparticles.js +78 -58
  278. package/programs/vectorfields/logics/index.js +4 -2
  279. package/programs/vectorfields/logics/pixelbased.js +92 -73
  280. package/programs/vectorfields/logics/ubo-new.ts +37 -0
  281. package/programs/vectorfields/logics/ubo.js +57 -51
  282. package/programs/vectorfields/pingpongbuffermanager.js +80 -73
  283. package/publish.bat +62 -0
  284. package/range-tools-on-terrain/bearing-line/adapters.ts +154 -0
  285. package/range-tools-on-terrain/bearing-line/plugin.ts +569 -0
  286. package/range-tools-on-terrain/bearing-line/types.ts +65 -0
  287. package/range-tools-on-terrain/circle-line-chain/adapters.ts +109 -0
  288. package/range-tools-on-terrain/circle-line-chain/chain-list-map.ts +446 -0
  289. package/range-tools-on-terrain/circle-line-chain/plugin.ts +607 -0
  290. package/range-tools-on-terrain/circle-line-chain/types.ts +43 -0
  291. package/range-tools-on-terrain/range-ring/adapters.ts +114 -0
  292. package/range-tools-on-terrain/range-ring/enum.ts +2 -0
  293. package/range-tools-on-terrain/range-ring/plugin.ts +447 -0
  294. package/range-tools-on-terrain/range-ring/rangeringangletext.ts +396 -0
  295. package/range-tools-on-terrain/range-ring/types.ts +30 -0
  296. package/rangerings/enum.ts +2 -0
  297. package/rangerings/index.js +5 -5
  298. package/rangerings/plugin.js +644 -543
  299. package/rangerings/rangeringangletext.js +369 -326
  300. package/rangerings/ring-account.js +129 -112
  301. package/semiplugins/interface.ts +14 -0
  302. package/semiplugins/lightweight/line-plugin.ts +343 -0
  303. package/semiplugins/lightweight/piece-of-pie-plugin.ts +275 -0
  304. package/semiplugins/shape-on-terrain/arc-plugin.ts +602 -0
  305. package/semiplugins/shape-on-terrain/circle-plugin.ts +588 -0
  306. package/semiplugins/shape-on-terrain/goal.md +12 -0
  307. package/semiplugins/shape-on-terrain/padding-1-degree.ts +714 -0
  308. package/semiplugins/shape-on-terrain/terrain-cover/notes.md +90 -0
  309. package/semiplugins/shape-on-terrain/terrain-cover/texture-dem-cover.ts +0 -0
  310. package/semiplugins/type.ts +8 -0
  311. package/shaders/fragment-toy/firework.js +1 -1
  312. package/shaders/fragment-toy/singularity.js +5 -2
  313. package/tests/Math/arc-sampling-test.js +367 -0
  314. package/tests/Math/arc-sampling-test.ts +429 -0
  315. package/tests/Math/arc.test.ts +102 -0
  316. package/tests/Math/junction/arc-plane.test.ts +163 -0
  317. package/tests/Math/junction/plane-plane.test.ts +91 -0
  318. package/tests/Math/plane-test.ts +17 -0
  319. package/tests/Math/plane.test.ts +43 -0
  320. package/tests/Math/vec3.test.ts +14 -0
  321. package/timetracks/adaptors-line-strip.js +80 -65
  322. package/timetracks/index.js +0 -1
  323. package/timetracks/plugin-line-strip.js +295 -240
  324. package/timetracks/program-line-strip.js +491 -411
  325. package/timetracks/programpoint-line-strip.js +122 -98
  326. package/timetracks/readme.md +1 -0
  327. package/tsconfig.json +22 -0
  328. package/types.ts +265 -0
  329. package/util/account/bufferoffsetmanager.js +209 -176
  330. package/util/account/create-buffermap-orchastration.ts +85 -0
  331. package/util/account/index.js +6 -3
  332. package/util/account/single-attribute-buffer-management/buffer-manager.ts +149 -0
  333. package/util/account/single-attribute-buffer-management/buffer-orchestrator.ts +332 -0
  334. package/util/account/single-attribute-buffer-management/buffer-orchestrator1.ts +184 -0
  335. package/util/account/single-attribute-buffer-management/index.ts +11 -0
  336. package/util/account/single-attribute-buffer-management/object-store.ts +76 -0
  337. package/util/account/single-attribute-buffer-management/types.ts +43 -0
  338. package/util/account/util.js +22 -18
  339. package/util/algorithms/index.js +0 -1
  340. package/util/algorithms/search-binary.js +26 -25
  341. package/util/build-strategy/general-strategy.ts +99 -0
  342. package/util/build-strategy/static-dynamic.ts +50 -0
  343. package/util/check/index.js +0 -1
  344. package/util/check/typecheck.ts +74 -0
  345. package/util/frame-counter-trigger.ts +99 -0
  346. package/util/geometry/index.ts +64 -0
  347. package/util/gl-util/buffer/attribute-loader.ts +84 -0
  348. package/util/gl-util/buffer/index.ts +6 -0
  349. package/util/gl-util/draw-options/methods.ts +47 -0
  350. package/util/gl-util/uniform-block/manager.ts +210 -0
  351. package/util/gl-util/uniform-block/roadmap.md +70 -0
  352. package/util/gl-util/uniform-block/shader.js +0 -1
  353. package/util/gl-util/uniform-block/types.ts +20 -0
  354. package/util/heatwavedatamanager/datamanager.js +168 -149
  355. package/util/heatwavedatamanager/index.js +2 -2
  356. package/util/heatwavedatamanager/pointcoordsmeta.ts +28 -0
  357. package/util/heatwavedatamanager/texture-point-sampler.ts +198 -0
  358. package/util/index.js +13 -13
  359. package/util/interpolation/index.js +0 -1
  360. package/util/interpolation/timetrack/index.js +9 -2
  361. package/util/interpolation/timetrack/timetrack-interpolator.js +94 -79
  362. package/util/interpolation/timetrack/web-worker.js +51 -46
  363. package/util/jshelpers/data-filler.js +19 -17
  364. package/util/jshelpers/equality.js +17 -18
  365. package/util/jshelpers/index.js +1 -2
  366. package/util/jshelpers/timefilters.js +32 -30
  367. package/util/picking/fence.js +46 -43
  368. package/util/picking/picker-displayer.js +177 -136
  369. package/util/programs/draw-texture-on-canvas.js +82 -66
  370. package/util/programs/index.js +1 -1
  371. package/util/programs/shapesonglobe.js +203 -167
  372. package/util/programs/supersampletotextures.js +132 -99
  373. package/util/programs/texturetoglobe.js +152 -128
  374. package/util/shaderfunctions/geometrytransformations.ts +388 -0
  375. package/util/shaderfunctions/index.js +2 -2
  376. package/util/shaderfunctions/nodata.js +4 -2
  377. package/util/shaderfunctions/noisefunctions.js +10 -7
  378. package/util/surface-line-data/arc-bboxes.ts +42 -0
  379. package/util/surface-line-data/arcs-to-cuts.js +74 -50
  380. package/util/surface-line-data/cut-arc.js +0 -1
  381. package/util/surface-line-data/flow.ts +52 -0
  382. package/util/surface-line-data/rbush-manager.js +0 -1
  383. package/util/surface-line-data/types.ts +27 -0
  384. package/util/surface-line-data/web-worker.js +0 -1
  385. package/util/webglobe/gldefaultstates.js +5 -4
  386. package/util/webglobe/index.js +2 -2
  387. package/util/webglobe/rasteroverlay.js +96 -75
  388. package/util/webglobjectbuilders.ts +446 -0
  389. package/waveparticles/adaptor.js +16 -15
  390. package/waveparticles/index.js +3 -3
  391. package/waveparticles/plugin.js +342 -290
  392. package/wind/imagetovectorfieldandmagnitude.js +71 -56
  393. package/wind/index.js +5 -5
  394. package/wind/plugin.js +845 -670
  395. package/wind/vectorfieldimage.js +27 -23
  396. package/write-text/attached-text-writer.js +105 -87
  397. package/write-text/context-text-bulk.ts +268 -0
  398. package/write-text/context-text.js +125 -94
  399. package/write-text/context-text3.ts +253 -0
  400. package/write-text/context-text3old.js +179 -152
  401. package/write-text/context-text4.ts +243 -0
  402. package/write-text/index.js +1 -1
  403. package/write-text/writer-plugin.js +7 -8
  404. package/Math/frustum/camera.js +0 -24
  405. package/Math/frustum/from-globeinfo.js +0 -48
  406. package/util/account/single-attribute-buffer-management/types.js +0 -1
  407. /package/{Math → dist/Math}/arc-cdf-points.js +0 -0
  408. /package/{Math → dist/Math}/arc-generate-points-exponantial.js +0 -0
  409. /package/{Math → dist/Math}/arc.js +0 -0
  410. /package/{Math → dist/Math}/circle-cdf-points.js +0 -0
  411. /package/{Math → dist/Math}/circle.js +0 -0
  412. /package/{Math → dist/Math}/constants.js +0 -0
  413. /package/{Math/matrix4.js → dist/Math/index.js} +0 -0
  414. /package/{Math → dist/Math}/juction/arc-plane.js +0 -0
  415. /package/{Math → dist/Math}/juction/line-sphere.js +0 -0
  416. /package/{Math → dist/Math}/juction/plane-plane.js +0 -0
  417. /package/{Math → dist/Math}/line.js +0 -0
  418. /package/{util/surface-line-data/types.js → dist/Math/matrix4.js} +0 -0
  419. /package/{Math → dist/Math}/methods.js +0 -0
  420. /package/{Math → dist/Math}/plane.js +0 -0
  421. /package/{Math → dist/Math}/quaternion.js +0 -0
  422. /package/{Math → dist/Math}/templete-shapes/grid-visually-equal.js +0 -0
  423. /package/{Math/frustum → dist/Math}/types.js +0 -0
  424. /package/{Math → dist/Math}/vec3.js +0 -0
  425. /package/{programs → dist/programs}/line-on-globe/linestrip/data.js +0 -0
  426. /package/{programs → dist/programs}/line-on-globe/linestrip/linestrip.js +0 -0
  427. /package/{programs → dist/programs}/line-on-globe/naive-accurate-flexible.js +0 -0
  428. /package/{programs → dist/programs}/programcache.js +0 -0
  429. /package/{programs → dist/programs}/rings/partial-ring/piece-of-pie.js +0 -0
  430. /package/{programs → dist/programs}/totems/camerauniformblock.js +0 -0
  431. /package/{programs → dist/programs}/totems/canvas-webglobe-info.js +0 -0
  432. /package/{programs → dist/programs}/totems/globe-changes.js +0 -0
  433. /package/{programs → dist/programs}/totems/index.js +0 -0
  434. /package/{programs → dist/programs}/vectorfields/logics/constants.js +0 -0
  435. /package/{programs → dist/programs}/vectorfields/logics/ubo-new.js +0 -0
  436. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/bearing-line/adapters.js +0 -0
  437. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/bearing-line/plugin.js +0 -0
  438. /package/{Math → dist/range-tools-on-terrain/bearing-line}/types.js +0 -0
  439. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/circle-line-chain/adapters.js +0 -0
  440. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/circle-line-chain/chain-list-map.js +0 -0
  441. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/circle-line-chain/plugin.js +0 -0
  442. /package/{range-tools-on-terrain/bearing-line → dist/range-tools-on-terrain/circle-line-chain}/types.js +0 -0
  443. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/adapters.js +0 -0
  444. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/enum.js +0 -0
  445. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/plugin.js +0 -0
  446. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/rangeringangletext.js +0 -0
  447. /package/{range-tools-on-terrain → dist/range-tools-on-terrain}/range-ring/types.js +0 -0
  448. /package/{rangerings → dist/rangerings}/enum.js +0 -0
  449. /package/{semiplugins → dist/semiplugins}/interface.js +0 -0
  450. /package/{semiplugins → dist/semiplugins}/lightweight/line-plugin.js +0 -0
  451. /package/{semiplugins → dist/semiplugins}/lightweight/piece-of-pie-plugin.js +0 -0
  452. /package/{semiplugins → dist/semiplugins}/shape-on-terrain/arc-plugin.js +0 -0
  453. /package/{semiplugins → dist/semiplugins}/shape-on-terrain/circle-plugin.js +0 -0
  454. /package/{semiplugins → dist/semiplugins}/shape-on-terrain/padding-1-degree.js +0 -0
  455. /package/{semiplugins → dist/semiplugins}/type.js +0 -0
  456. /package/{types.js → dist/types.js} +0 -0
  457. /package/{util → dist/util}/account/create-buffermap-orchastration.js +0 -0
  458. /package/{util → dist/util}/account/single-attribute-buffer-management/buffer-manager.js +0 -0
  459. /package/{util → dist/util}/account/single-attribute-buffer-management/buffer-orchestrator.js +0 -0
  460. /package/{util → dist/util}/account/single-attribute-buffer-management/buffer-orchestrator1.js +0 -0
  461. /package/{util → dist/util}/account/single-attribute-buffer-management/index.js +0 -0
  462. /package/{util → dist/util}/account/single-attribute-buffer-management/object-store.js +0 -0
  463. /package/{range-tools-on-terrain/circle-line-chain → dist/util/account/single-attribute-buffer-management}/types.js +0 -0
  464. /package/{util → dist/util}/build-strategy/general-strategy.js +0 -0
  465. /package/{util → dist/util}/build-strategy/static-dynamic.js +0 -0
  466. /package/{util → dist/util}/check/typecheck.js +0 -0
  467. /package/{util → dist/util}/frame-counter-trigger.js +0 -0
  468. /package/{util → dist/util}/geometry/index.js +0 -0
  469. /package/{util → dist/util}/gl-util/buffer/attribute-loader.js +0 -0
  470. /package/{util → dist/util}/gl-util/buffer/index.js +0 -0
  471. /package/{util → dist/util}/gl-util/draw-options/methods.js +0 -0
  472. /package/{util → dist/util}/gl-util/uniform-block/manager.js +0 -0
  473. /package/{util → dist/util}/gl-util/uniform-block/types.js +0 -0
  474. /package/{util → dist/util}/heatwavedatamanager/pointcoordsmeta.js +0 -0
  475. /package/{util → dist/util}/heatwavedatamanager/texture-point-sampler.js +0 -0
  476. /package/{util → dist/util}/shaderfunctions/geometrytransformations.js +0 -0
  477. /package/{util → dist/util}/surface-line-data/arc-bboxes.js +0 -0
  478. /package/{util → dist/util}/surface-line-data/flow.js +0 -0
  479. /package/{util → dist/util}/webglobjectbuilders.js +0 -0
  480. /package/{write-text → dist/write-text}/context-text3.js +0 -0
  481. /package/{write-text → dist/write-text}/context-text4.js +0 -0
@@ -0,0 +1,279 @@
1
+ import { createProgram, shaderfunctions } from "../util";
2
+ import { CameraUniformBlockTotem, CameraUniformBlockString, noRegisterGlobeProgramCache, globeProgramCache } from "../programs";
3
+ import BufferManager from "./buffer-manager";
4
+ import { POLE, PI, longLatRadToMercator, mercatorXYToGLPosition, longLatRadToCartesian3D, circleLimpFromLongLatRadCenterCartesian3D, circleLimpFromLongLatRadCenterMercatorRealDistance, cartesian3DToGLPosition } from "../util/shaderfunctions/geometrytransformations";
5
+ /**
6
+ * TODO:
7
+ * 1. Triangle face looks at screen. if rotation angle is positive the last vertex must be the faintest.
8
+ *
9
+ */
10
+ const drawModeMap = Object.freeze({
11
+ LINE_STRIP: 0,
12
+ TRIANGLE_FAN: 1,
13
+ });
14
+ const vertexShaderSource = `#version 300 es
15
+
16
+ ${CameraUniformBlockString}
17
+ ${PI}
18
+ ${longLatRadToMercator}
19
+ ${mercatorXYToGLPosition}
20
+ ${longLatRadToCartesian3D}
21
+ ${circleLimpFromLongLatRadCenterCartesian3D}
22
+ ${circleLimpFromLongLatRadCenterMercatorRealDistance}
23
+ ${cartesian3DToGLPosition}
24
+
25
+ uniform float edge_count;
26
+ uniform int draw_mode; // %2 => 0: LINE_STRIP, 1: TRIANGLE_FAN
27
+ uniform float plugin_alpha_multiplier;
28
+ //, lat, startAngle, tailAngle, ...rgba, radius, rgbaMode
29
+ in vec2 center; // long, lat in radian
30
+ in float start_angle; // the start of partial circle from bearing point
31
+ in float tail_angle; // the rotation of the partial circle
32
+ in vec4 color;
33
+ in float radius; // in meter
34
+ in float color_mode; // 0.0: constant, 1.0: fading, 2.0: hide
35
+ // flat out int vid;
36
+ // flat out float v_phase;
37
+ out vec2 v_pos;
38
+ out vec4 v_color;
39
+ // flat out float v_angle;
40
+
41
+ void main() {
42
+ // vid = gl_VertexID;
43
+ if (color_mode == 2.0 || radius == 0.0) { return; }
44
+ float color_mode_ = color_mode;
45
+ if ( draw_mode == 0 && color_mode == 1.0) {color_mode_ = 0.0;}
46
+ float vertexID = float(gl_VertexID);
47
+ float radius_ = radius;
48
+ float alpha = plugin_alpha_multiplier;
49
+ if (draw_mode == 1) { // TRIANGLE_FAN
50
+ if (gl_VertexID == 0) {
51
+ radius_ = 0.0;
52
+ if ( color_mode == 1.0 ) { alpha = 0.0; }
53
+ }
54
+ vertexID -= 1.0;
55
+ }
56
+ float phase = ( vertexID / (edge_count - 1.0) );
57
+ // v_angle = tail_angle;
58
+
59
+ if ( color_mode_ == 1.0 ) {
60
+ if ( tail_angle < 0.0 ) {
61
+ v_color = vec4( color.rgb , color.a * ( 1.0 - phase ) * alpha );
62
+ } else {
63
+ v_color = vec4( color.rgb , color.a * phase * alpha );
64
+ }
65
+ } else {
66
+ v_color = vec4( color.rgb , color.a * alpha );
67
+ }
68
+ if ( color_mode == 0.0 && draw_mode == 1 ) {
69
+ v_color.a /= 2.0;
70
+ }
71
+ float angle;
72
+ if ( tail_angle > 0.0 ) {
73
+ angle = tail_angle * (-phase + 1.0) + start_angle;
74
+ } else {
75
+ angle = tail_angle * phase + start_angle;
76
+ }
77
+ if (is3D) {
78
+
79
+ vec3 pos = circleLimpFromLongLatRadCenterCartesian3D(center, radius_, angle);
80
+ v_pos = vec2(0.0, 0.0);
81
+ gl_Position = cartesian3DToGLPosition(pos);
82
+ }
83
+ else {
84
+
85
+ vec2 pos = circleLimpFromLongLatRadCenterMercatorRealDistance(center, radius_, angle);
86
+ v_pos = pos;
87
+ gl_Position = mercatorXYToGLPosition(pos);
88
+ }
89
+
90
+ gl_PointSize = 10.0;
91
+ }`;
92
+ const fragmentShaderSource = `#version 300 es` + POLE + PI + `
93
+ precision highp float;
94
+ // flat in int vid;
95
+ in vec4 v_color;
96
+ in vec2 v_pos;
97
+ // flat in float v_phase;
98
+ // in float v_angle;
99
+ out vec4 outColor;
100
+ void main() {
101
+ // if( vid % 2 == 0 ) { discard; }
102
+ // if ( mod(v_angle, PI / 36.0 ) < (PI / 72.0)) { discard; }
103
+ // if ( mod(v_angle * v_phase, PI / 90.0 ) < (PI / 180.0)) { discard; }
104
+ if ( v_pos.x < -POLE || v_pos.x > POLE || v_pos.y < -POLE || v_pos.y > POLE ) { discard; }
105
+ outColor = v_color;
106
+ }`;
107
+ export const ITEM_SIZE = 10;
108
+ export class Logic {
109
+ constructor(globe) {
110
+ this.globe = globe;
111
+ this.gl = globe.gl;
112
+ this._lastMode = 0;
113
+ this._lastEdgeCount = 64;
114
+ this._lastAlphaMultiplier = 1.0;
115
+ this.program = createProgram(this.gl, vertexShaderSource, fragmentShaderSource);
116
+ const { gl, program } = this;
117
+ { // set attributes locations
118
+ gl.bindAttribLocation(program, 0, 'center');
119
+ gl.bindAttribLocation(program, 1, 'start_angle');
120
+ gl.bindAttribLocation(program, 2, 'tail_angle');
121
+ gl.bindAttribLocation(program, 3, 'color');
122
+ gl.bindAttribLocation(program, 4, 'radius');
123
+ gl.bindAttribLocation(program, 5, 'color_mode');
124
+ // vao
125
+ // instanced draw read 1
126
+ }
127
+ { // Uniforms
128
+ this._edgeCountLocation = gl.getUniformLocation(program, 'edge_count');
129
+ this._draw_modeLocation = gl.getUniformLocation(program, 'draw_mode');
130
+ this._plugin_alpha_multiplierLocation = gl.getUniformLocation(program, 'plugin_alpha_multiplier');
131
+ const currentProgram = gl.getParameter(gl.CURRENT_PROGRAM);
132
+ gl.useProgram(program);
133
+ gl.uniform1i(this._draw_modeLocation, this._lastMode);
134
+ gl.uniform1f(this._edgeCountLocation, this._lastEdgeCount);
135
+ gl.uniform1f(this._plugin_alpha_multiplierLocation, 1.0);
136
+ this.cameraBlockBindingPoint = 0;
137
+ this.cameraBlockTotem = globeProgramCache.getProgram(globe, CameraUniformBlockTotem);
138
+ const cameraBlockIndex = gl.getUniformBlockIndex(program, "CameraUniformBlock");
139
+ gl.uniformBlockBinding(program, cameraBlockIndex, this.cameraBlockBindingPoint);
140
+ gl.useProgram(currentProgram);
141
+ }
142
+ }
143
+ draw(length, vao, edgeCount, alphaMultiplier, drawMode) {
144
+ const { gl, program, cameraBlockTotem, cameraBlockBindingPoint } = this;
145
+ // gl.disable(gl.DEPTH_TEST);
146
+ gl.useProgram(program);
147
+ if (drawMode !== this._lastMode) {
148
+ gl.uniform1i(this._draw_modeLocation, drawModeMap[drawMode]);
149
+ this._lastMode = drawMode;
150
+ }
151
+ if (edgeCount !== this._lastEdgeCount) {
152
+ gl.uniform1f(this._edgeCountLocation, edgeCount);
153
+ this._lastEdgeCount = edgeCount;
154
+ }
155
+ if (alphaMultiplier !== this._lastAlphaMultiplier) {
156
+ gl.uniform1f(this._plugin_alpha_multiplierLocation, alphaMultiplier);
157
+ this._lastAlphaMultiplier = alphaMultiplier;
158
+ }
159
+ const overdraw = drawModeMap[drawMode];
160
+ cameraBlockTotem.bind(cameraBlockBindingPoint);
161
+ gl.bindVertexArray(vao);
162
+ gl.drawArraysInstanced(gl[drawMode], 0, edgeCount + overdraw, length);
163
+ cameraBlockTotem.unbind(cameraBlockBindingPoint);
164
+ gl.bindVertexArray(null);
165
+ // gl.enable(gl.DEPTH_TEST);
166
+ }
167
+ free() {
168
+ noRegisterGlobeProgramCache.releaseProgram(this.globe, CameraUniformBlockTotem);
169
+ this.gl.deleteProgram(this.program);
170
+ this.program = null;
171
+ }
172
+ getVaoBuffer() {
173
+ const { gl } = this;
174
+ const vao = gl.createVertexArray();
175
+ const buffer = gl.createBuffer();
176
+ gl.bindVertexArray(vao);
177
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
178
+ const stride = ITEM_SIZE * 4;
179
+ let offset = 0;
180
+ gl.enableVertexAttribArray(0);
181
+ gl.vertexAttribPointer(0, 2, gl.FLOAT, false, stride, offset);
182
+ offset += 2 * 4;
183
+ gl.enableVertexAttribArray(1);
184
+ gl.vertexAttribPointer(1, 1, gl.FLOAT, false, stride, offset);
185
+ offset += 1 * 4;
186
+ gl.enableVertexAttribArray(2);
187
+ gl.vertexAttribPointer(2, 1, gl.FLOAT, false, stride, offset);
188
+ offset += 1 * 4;
189
+ gl.enableVertexAttribArray(3);
190
+ gl.vertexAttribPointer(3, 4, gl.FLOAT, false, stride, offset);
191
+ offset += 4 * 4;
192
+ gl.enableVertexAttribArray(4);
193
+ gl.vertexAttribPointer(4, 1, gl.FLOAT, false, stride, offset);
194
+ offset += 1 * 4;
195
+ gl.enableVertexAttribArray(5);
196
+ gl.vertexAttribPointer(5, 1, gl.FLOAT, false, stride, offset);
197
+ gl.vertexAttribDivisor(0, 1);
198
+ gl.vertexAttribDivisor(1, 1);
199
+ gl.vertexAttribDivisor(2, 1);
200
+ gl.vertexAttribDivisor(3, 1);
201
+ gl.vertexAttribDivisor(4, 1);
202
+ gl.vertexAttribDivisor(5, 1);
203
+ gl.bindVertexArray(null);
204
+ gl.bindBuffer(gl.ARRAY_BUFFER, null);
205
+ return {
206
+ vao,
207
+ buffer,
208
+ };
209
+ }
210
+ /**
211
+ * in vec2 center; // long, lat in radian
212
+ in float start_angle; // the start of partial circle from bearing point
213
+ in float tail_angle; // the rotation of the partial circle
214
+ in vec4 color;
215
+ in float radius; // in meter
216
+ in float color_mode; // 0.0: constant, 1.0: fading, 2.0: hide
217
+ */
218
+ createVAO(centerObj, startAngleObj, tailAngleObj, colorObj, radiusObj, colorModeObj) {
219
+ const { gl } = this;
220
+ const vao = gl.createVertexArray();
221
+ gl.bindVertexArray(vao);
222
+ {
223
+ const { buffer, stride, offset } = centerObj;
224
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
225
+ gl.enableVertexAttribArray(0);
226
+ gl.vertexAttribPointer(0, 2, gl.FLOAT, false, stride, offset);
227
+ gl.vertexAttribDivisor(0, 1);
228
+ }
229
+ {
230
+ const { buffer, stride, offset } = startAngleObj;
231
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
232
+ gl.enableVertexAttribArray(1);
233
+ gl.vertexAttribPointer(1, 1, gl.FLOAT, false, stride, offset);
234
+ gl.vertexAttribDivisor(1, 1);
235
+ }
236
+ {
237
+ const { buffer, stride, offset } = tailAngleObj;
238
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
239
+ gl.enableVertexAttribArray(2);
240
+ gl.vertexAttribPointer(2, 1, gl.FLOAT, false, stride, offset);
241
+ gl.vertexAttribDivisor(2, 1);
242
+ }
243
+ {
244
+ const { buffer, stride, offset } = colorObj;
245
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
246
+ gl.enableVertexAttribArray(3);
247
+ gl.vertexAttribPointer(3, 4, gl.FLOAT, false, stride, offset);
248
+ gl.vertexAttribDivisor(3, 1);
249
+ }
250
+ {
251
+ const { buffer, stride, offset } = radiusObj;
252
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
253
+ gl.enableVertexAttribArray(4);
254
+ gl.vertexAttribPointer(4, 1, gl.FLOAT, false, stride, offset);
255
+ gl.vertexAttribDivisor(4, 1);
256
+ }
257
+ {
258
+ const { buffer, stride, offset } = colorModeObj;
259
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
260
+ gl.enableVertexAttribArray(5);
261
+ gl.vertexAttribPointer(5, 1, gl.FLOAT, false, stride, offset);
262
+ gl.vertexAttribDivisor(5, 1);
263
+ }
264
+ gl.bindVertexArray(null);
265
+ gl.bindBuffer(gl.ARRAY_BUFFER, null);
266
+ return vao;
267
+ }
268
+ getBufferManagerAndVao({ capacity = 10, bufferType = "DYNAMIC_DRAW" } = {}) {
269
+ const { vao, buffer } = this.getVaoBuffer();
270
+ return {
271
+ bufferManager: new BufferManager(this.globe, this.gl, buffer, { capacity, bufferType }),
272
+ vao
273
+ };
274
+ }
275
+ }
276
+ export const programCache = Object.freeze({
277
+ get: (globe) => noRegisterGlobeProgramCache.getProgram(globe, Logic),
278
+ release: (globe) => noRegisterGlobeProgramCache.releaseProgram(globe, Logic)
279
+ });
@@ -0,0 +1,300 @@
1
+ /**
2
+ * IconData;
3
+ * iconMap, iconCoords for objectArray
4
+ *
5
+ * Pin data:
6
+ * long, lat, payload
7
+ *
8
+ * methods insertPin pin and its data
9
+ * methods deletePin
10
+ *
11
+ * Behaviur injection:
12
+ * hover
13
+ * move
14
+ * pick drop
15
+ * mouseclicks
16
+ * keyboard clicks
17
+ * mouse curser changes ( this can be implemented inside above methods)
18
+ */
19
+ import { CSGlobe, CSIconTypes, CSObjectTypes, CSObjectArrayUpdateTypes, } from "@pirireis/webglobe";
20
+ import AlarmTimeLineFadeInFadeOut from "../../plugins/alarms/alarmFadeInFadeOutPlugin/AlarmTimeLineFadeInFadeOutPlugin";
21
+ /**
22
+ * @typedef {Object} IconPayload
23
+ * @property {string} app6DCode
24
+ * @property {string} accsCode
25
+ */
26
+ /**
27
+ * @typedef {IconPayload & Object.<string, any>} PointPayload
28
+ */
29
+ /**
30
+ * @typedef {Object} CanChangeOptions
31
+ * @property {boolean} [attribs=false]
32
+ * @property {boolean} [icon=false]
33
+ * @property {boolean} [label=false]
34
+ * @property {boolean} [heading=false]
35
+ */
36
+ /**
37
+ * @typedef {Object} PointObjectArray
38
+ * @property {number[]} coords [longitude1, latitude1, longitude2, latitude2, ....]
39
+ * @property {number[]} coordsZ [z1, z2, ....]
40
+ * @property {PointPayload[]} attribs
41
+ */
42
+ function addIconMap(globe, mapName = "IconMapName", ICON_MAP_URL, ICON_MAP_JSON_URL) {
43
+ globe.api_AddIconMap('IconMapName', ICON_MAP_URL, ICON_MAP_JSON_URL);
44
+ }
45
+ class ObjectArray {
46
+ constructor(symbolSet, style) {
47
+ this.symbolSet = symbolSet;
48
+ this.style = style;
49
+ }
50
+ setSymbolSet(symbolSet) {
51
+ this.symbolSet = symbolSet;
52
+ }
53
+ }
54
+ class PinPointObjectArray {
55
+ constructor(id, globe, symbolSet, // iconMapName
56
+ style, callBacks = {
57
+ mouseDown: (pinItem, event) => { },
58
+ mouseMove: (pinItem, event) => { },
59
+ mouseUp: (pinItem, event) => { },
60
+ mouseClick: (pinItem, event) => { },
61
+ mouseDblClick: (pinItem, event) => { },
62
+ } = {}) {
63
+ this.id = id;
64
+ this.globe = globe;
65
+ this.symbolSet = symbolSet;
66
+ this.style = style;
67
+ this.iconMapName = iconMapName;
68
+ this.callBacks = callBacks;
69
+ // this item will be used
70
+ this.currentItem = null;
71
+ }
72
+ insertPins(pins) {
73
+ }
74
+ deletePins(pinsIDs) {
75
+ const deleteBucket = {
76
+ coords: [],
77
+ coordsZ: [],
78
+ attribs: []
79
+ };
80
+ }
81
+ _queryByScreenFindFirst() {
82
+ const { clientX, clientY } = this.globe.api_GetMousePos();
83
+ const allObjects = this.globe.queryByScreen(clientX, clientY);
84
+ for (let i = 0; i < allObjects.length; i++) {
85
+ const { obj, owner } = allObjects[i];
86
+ if (owner === this.objectArray) {
87
+ return obj;
88
+ }
89
+ }
90
+ }
91
+ // mouseDown(x, y, event) {
92
+ // return false
93
+ // }
94
+ // // mouse'a basılıp hareket ettirildiğinde, mouseDown'dan true dönmüşse çağrılır
95
+ // mouseMove(x, y, event) {
96
+ // }
97
+ // // mouse bırakıldığında çağrılır
98
+ // mouseUp(x, y, event) {
99
+ // }
100
+ // // harita üzerinde tıklandığında çağrılır
101
+ // mouseClick() {
102
+ // return false
103
+ // }
104
+ // // harita üzerinde çift tıklandığında çağrılır
105
+ // mouseDblClick() {
106
+ // return false
107
+ // }
108
+ free() {
109
+ this.globe.api_ClearMouseEvents(); // TODO
110
+ }
111
+ _setMouseEvent() {
112
+ const { globe } = this;
113
+ globe.api_SetMouseEvents();
114
+ }
115
+ _getIdForGlobe() {
116
+ const { globe, objectArray } = this;
117
+ const callback = () => {
118
+ const allObjects = globe.api_queryByScreen();
119
+ };
120
+ return `${this.id}_pinObjectArrayMouseEvent`;
121
+ }
122
+ }
123
+ class ObjectArrayLabels {
124
+ /**
125
+ * @param {number | string} id
126
+ * @param {CSGlobe} globe
127
+ */
128
+ constructor(id, globe, labelStyle = null) {
129
+ this.id = id;
130
+ this.setGlobe(globe);
131
+ this.data = [
132
+ {
133
+ coords: [],
134
+ coordsZ: [],
135
+ attribs: [],
136
+ },
137
+ ];
138
+ this.primaryKey = "id";
139
+ this.objectType = CSObjectTypes.POINT;
140
+ this.filter = null;
141
+ this.bbox = null;
142
+ this.startLod = 2;
143
+ this.endLod = 19;
144
+ this.query = true;
145
+ this.reportObj = function (values, mouseEvent) { };
146
+ this._idCollector = new Set();
147
+ this._setStyle(labelStyle);
148
+ }
149
+ _setStyle(labelStyle) {
150
+ this.style = this.globe.ObjectArray.GetDefaultStyle();
151
+ if (labelStyle) {
152
+ this.style.labels[0] = labelStyle;
153
+ }
154
+ else {
155
+ this.style.labels[0].vAlignment = 2; // dikey olarak tam noktanın ortası
156
+ this.style.labels[0].hAlignment = 2; // yatay olarak tam noktanın ortası
157
+ this.style.labels[0].size = 11;
158
+ this.style.labels[0].drawAlways = true;
159
+ this.style.labels[0].fontFamily.name = "arial";
160
+ this.style.labels[0].fontFamily.bold = false;
161
+ this.style.labels[0].fontFamily.hollow = true;
162
+ this.style.labels[0].fontFamily.hollowWidth = 1;
163
+ this.style.labels[0].fontFamily.hollowOpacity = 1;
164
+ }
165
+ this.style.labels[0].text = "${value}";
166
+ this.style.fidKey = this.primaryKey;
167
+ this.style.iconType = CSIconTypes.NOICON; // milIcon ekleyebilmek için icon tipi MAP olmalı
168
+ }
169
+ /**
170
+ * @param {CSGlobe} [globe]
171
+ */
172
+ setGlobe(globe) {
173
+ if (!globe)
174
+ return;
175
+ this.globe = globe;
176
+ }
177
+ addToMap() {
178
+ this.globe.ObjectArray.Add(this);
179
+ }
180
+ removeFromMap() {
181
+ this.flush();
182
+ this.globe.ObjectArray.Delete(this.id);
183
+ }
184
+ /**
185
+ * Haritaya kullanılacak veriyi verir. Her çağrıldığında tüm hesaplamalar yeniden yapılır
186
+ * @param {PointObjectArray} data
187
+ */
188
+ setData(data) {
189
+ this.globe.ObjectArray.SetData(this, [data]);
190
+ }
191
+ /**
192
+ * @param {PointObjectArray} data
193
+ * @param {CSObjectArrayUpdateTypes} operation
194
+ * @param {CanChangeOptions} [canChange]
195
+ */
196
+ updateData(data, operation, canChange) {
197
+ this.globe.ObjectArray.UpdateData(this, operation, [data], canChange);
198
+ }
199
+ flush() {
200
+ const deleteBucket = {
201
+ coords: [],
202
+ coordsZ: [],
203
+ attribs: [],
204
+ };
205
+ this.setData(deleteBucket);
206
+ this._idCollector = new Set();
207
+ }
208
+ /**
209
+ * Haritaya kullanılacak veriyi verir. Her çağrıldığında tüm hesaplamalar yeniden yapılmaz, ancak ön hesaplama maliyeti vardır
210
+ * @param {PointObjectArray} data
211
+ */
212
+ setControlledData(data) {
213
+ const paritalData = {
214
+ add: {
215
+ coords: [],
216
+ coordsZ: [],
217
+ attribs: [],
218
+ },
219
+ update: {
220
+ coords: [],
221
+ coordsZ: [],
222
+ attribs: [],
223
+ },
224
+ delete: {
225
+ coords: [],
226
+ coordsZ: [],
227
+ attribs: [],
228
+ },
229
+ canChange: {
230
+ // Tüm değişimler gözardı edilecek
231
+ attribs: false,
232
+ icon: false,
233
+ label: false,
234
+ heading: false,
235
+ },
236
+ };
237
+ // İlk toplu ekleme adımı
238
+ if (this._idCollector.size === 0) {
239
+ this.setData(data);
240
+ // Eklenen id'ler set edildi
241
+ for (let i = 0; i < data.attribs.length; i++) {
242
+ const currentPayload = data.attribs[i];
243
+ const id = currentPayload[this.primaryKey];
244
+ this._idCollector.add(id);
245
+ }
246
+ return;
247
+ }
248
+ /** @type {Set<string>} */
249
+ const dataIds = new Set();
250
+ for (let i = 0; i < data.attribs.length; i++) {
251
+ const currentPayload = data.attribs[i];
252
+ const id = currentPayload[this.primaryKey];
253
+ let bucket = paritalData.add;
254
+ dataIds.add(id);
255
+ if (this._idCollector.has(id)) {
256
+ bucket = paritalData.update;
257
+ }
258
+ else {
259
+ this._idCollector.add(id);
260
+ }
261
+ bucket.coords.push(data.coords[2 * i], data.coords[2 * i + 1]);
262
+ bucket.coordsZ.push(data.coordsZ[i]);
263
+ bucket.attribs.push(currentPayload);
264
+ }
265
+ // Artık varolmayan elemenları sil
266
+ const deleteBucket = paritalData.delete;
267
+ this._idCollector.forEach((id) => {
268
+ if (!dataIds.has(id)) {
269
+ this._idCollector.delete(id);
270
+ deleteBucket.coords.push(0, 0);
271
+ deleteBucket.coordsZ.push(0);
272
+ deleteBucket.attribs.push({
273
+ [this.primaryKey]: id,
274
+ });
275
+ }
276
+ });
277
+ if (paritalData.add.coords.length > 0) {
278
+ this.updateData(paritalData.add, CSObjectArrayUpdateTypes.ADD);
279
+ }
280
+ if (paritalData.update.coords.length > 0) {
281
+ this.updateData(paritalData.update, CSObjectArrayUpdateTypes.UPDATE, paritalData.canChange);
282
+ }
283
+ if (paritalData.delete.coords.length > 0) {
284
+ this.updateData(paritalData.delete, CSObjectArrayUpdateTypes.DELETE);
285
+ }
286
+ }
287
+ setPrimarykey(key) {
288
+ this.primaryKey = key;
289
+ }
290
+ setSymbolSet(symbolSet) {
291
+ this.symbolSet = symbolSet;
292
+ }
293
+ getLabelStyle() {
294
+ return this.style.labels[0];
295
+ }
296
+ setLabelStyle(style) {
297
+ this.style.labels[0] = style;
298
+ }
299
+ }
300
+ export default ObjectArrayLabels;
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+ /**
3
+ * This class registered as globe plugin one for each globe. to the head of plugin call stack.
4
+ */
5
+ class PinPointTotem {
6
+ constructor(globe) {
7
+ this.objectArrayMap = new Map();
8
+ }
9
+ /**
10
+ * objectArray
11
+ * callbacks ={
12
+ * mouseDown,
13
+ * mouseMove,
14
+ * mouseUp,
15
+ * mouseClick,
16
+ * mouseDbClick,
17
+ * keyDown,
18
+ * keyUp
19
+ * }
20
+ */
21
+ registerPinMap(objectArray, callbacks) {
22
+ this.objectArrayMap.set(objectArray, callbacks);
23
+ }
24
+ unregisterPinMap(objectArray) {
25
+ if (this.objectArrayMap.has(objectArray)) {
26
+ this.objectArrayMap.delete(objectArray);
27
+ }
28
+ else {
29
+ console.warn('PinPointTotem objectArrayMap does not contain the objectArray');
30
+ }
31
+ }
32
+ // GlobeMethods
33
+ // haritada sol butona basıldığında çağrılır
34
+ mouseDown(x, y, event) {
35
+ return false;
36
+ }
37
+ // mouse'a basılıp hareket ettirildiğinde, mouseDown'dan true dönmüşse çağrılır
38
+ mouseMove(x, y, event) {
39
+ }
40
+ // mouse up'ın left'i mouseDown'dan true dönmüşse çağrılır, edit mode içindir
41
+ // right'i ise sağ tıka basılıp bırakıldığında çağrılır
42
+ mouseUp(x, y, event) {
43
+ }
44
+ // harita üzerinde tıklandığında çağrılır
45
+ mouseClick(x, y, event) {
46
+ return false;
47
+ }
48
+ // harita üzerinde çift tıklandığında çağrılır
49
+ mouseDblClick(x, y, event) {
50
+ return false;
51
+ }
52
+ // klavyeden bir tuşa basıldığı anda ve tuşa basılı kalınmaya devam edildiği durumlarda çalışır
53
+ keyDown(event) {
54
+ return false;
55
+ }
56
+ // klavyedeki bir tuştan parmak çekildiği anda çalışır
57
+ keyUp(event) {
58
+ return false;
59
+ }
60
+ }
@@ -0,0 +1,63 @@
1
+ /**
2
+ * @typedef {Float32Array} TimeTrackMultiColorData | A linestring is representation, let A{a1, a2, a3}, B{b1, b2} be the points of the line.
3
+ * TimeTrackMultiColorData is [
4
+ * a1x, a1y, a1z, a1time, a1r, a1g, a1b, a1time, a3time,
5
+ * a2x, a2y, a2z, a2time, a2r, a2g, a2b, a1time, a3time,
6
+ * a3x, a3y, a3z, a3time, a3r, a3g, a3b, a1time, a3time,
7
+ * 0, 0, 0, 0, -1, -1, -1, 0, 0,
8
+ * b1x, b1y, b1z, b1time, b1r, b1g, b1b, b1time, b2time,
9
+ * b2x, b2y, b2z, b2time, b2r, b2g, b2b, BstartTime, BendTime
10
+ * ]
11
+ * there is a cutting point between A and B
12
+ *
13
+ */
14
+ /**
15
+ * ABOVE
16
+ * TO
17
+ * BELOW
18
+
19
+ /**
20
+ * @typedef {Array<number>} vec3 [x, y, z]
21
+ * @typedef {Array<number>} vec2 [x, y]
22
+ * @typedef {Array<number>} vec4 [x, y, z, w]
23
+ * @typedef {number} fraction a number between 0 and 1
24
+ * @typedef {Array<number>} wgs84 [long, lat]
25
+ */
26
+ /**
27
+ * @typedef Timetrack
28
+ * @property {Array<vec4>}} coordinates [x,y,z, length]
29
+ * @property {Array<Number>} times
30
+ * @param {Array<Timetrack>} timeTracks
31
+ */
32
+ import { pixelXYLenghtToUnitVectorWithHeight } from "../../Math/methods";
33
+ const processACut = (array, offset) => {
34
+ // first 3 values of array
35
+ const v3 = array.slice(offset, offset + 3);
36
+ const v4 = pixelXYLenghtToUnitVectorWithHeight(v3);
37
+ const time = array[offset + 3];
38
+ return [v4, time];
39
+ };
40
+ const timeTrackPluginDataToPointHeatInterpolatorAdapter = (timeTrackPluginData) => {
41
+ const timeTracks = [];
42
+ let offset = 0;
43
+ let timeTrack = {
44
+ coordinates: [],
45
+ times: []
46
+ };
47
+ while (offset < timeTrackPluginData.length) {
48
+ if (!timeTrackPluginData[offset]) {
49
+ timeTracks.push(timeTrack);
50
+ timeTrack = {
51
+ coordinates: [],
52
+ times: []
53
+ };
54
+ offset += 9;
55
+ }
56
+ const point = processACut(timeTrackPluginData, offset);
57
+ offset += 9;
58
+ timeTrack.coordinates.push(point[0]);
59
+ timeTrack.times.push(point[1]);
60
+ }
61
+ return timeTracks;
62
+ };
63
+ export { timeTrackPluginDataToPointHeatInterpolatorAdapter };
@@ -0,0 +1 @@
1
+ "use strict";